author | wenzelm |
Tue, 19 Apr 2011 15:58:05 +0200 | |
changeset 42403 | 38b29c9fc742 |
parent 42370 | 244911efd275 |
child 42484 | 2777a27506d0 |
permissions | -rw-r--r-- |
5363 | 1 |
Isabelle NEWS -- history user-relevant changes |
2 |
============================================== |
|
2553 | 3 |
|
41651 | 4 |
New in this Isabelle version |
5 |
---------------------------- |
|
6 |
||
41703
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
7 |
*** General *** |
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
8 |
|
41955
703ea96b13c6
files are identified via SHA1 digests -- discontinued ISABELLE_FILE_IDENT;
wenzelm
parents:
41952
diff
changeset
|
9 |
* Theory loader: source files are identified by content via SHA1 |
703ea96b13c6
files are identified via SHA1 digests -- discontinued ISABELLE_FILE_IDENT;
wenzelm
parents:
41952
diff
changeset
|
10 |
digests. Discontinued former path/modtime identification and optional |
703ea96b13c6
files are identified via SHA1 digests -- discontinued ISABELLE_FILE_IDENT;
wenzelm
parents:
41952
diff
changeset
|
11 |
ISABELLE_FILE_IDENT plugin scripts. |
703ea96b13c6
files are identified via SHA1 digests -- discontinued ISABELLE_FILE_IDENT;
wenzelm
parents:
41952
diff
changeset
|
12 |
|
41703
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
13 |
* Parallelization of nested Isar proofs is subject to |
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
14 |
Goal.parallel_proofs_threshold (default 100). See also isabelle |
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
15 |
usedir option -Q. |
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
16 |
|
41718
05514b09bb4b
discontinued support for Poly/ML 5.2, which was the last version without proper multithreading and TimeLimit implementation;
wenzelm
parents:
41703
diff
changeset
|
17 |
* Discontinued support for Poly/ML 5.2, which was the last version |
05514b09bb4b
discontinued support for Poly/ML 5.2, which was the last version without proper multithreading and TimeLimit implementation;
wenzelm
parents:
41703
diff
changeset
|
18 |
without proper multithreading and TimeLimit implementation. |
05514b09bb4b
discontinued support for Poly/ML 5.2, which was the last version without proper multithreading and TimeLimit implementation;
wenzelm
parents:
41703
diff
changeset
|
19 |
|
41734
d92cc39097e6
discontinued obsolete lib/scripts/polyml-platform;
wenzelm
parents:
41728
diff
changeset
|
20 |
* Discontinued old lib/scripts/polyml-platform, which has been |
d92cc39097e6
discontinued obsolete lib/scripts/polyml-platform;
wenzelm
parents:
41728
diff
changeset
|
21 |
obsolete since Isabelle2009-2. |
d92cc39097e6
discontinued obsolete lib/scripts/polyml-platform;
wenzelm
parents:
41728
diff
changeset
|
22 |
|
41886 | 23 |
* Theory loader: source files are exclusively located via the master |
24 |
directory of each theory node (where the .thy file itself resides). |
|
25 |
The global load path (such as src/HOL/Library) is has been |
|
26 |
discontinued. INCOMPATIBILITY. |
|
27 |
||
41950
134131d519c0
clarified ISABELLE_CSDP setting (formerly CSDP_EXE);
wenzelm
parents:
41944
diff
changeset
|
28 |
* Various optional external tools are referenced more robustly and |
41952
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
29 |
uniformly by explicit Isabelle settings as follows: |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
30 |
|
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
31 |
ISABELLE_CSDP (formerly CSDP_EXE) |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
32 |
ISABELLE_GHC (formerly EXEC_GHC or GHC_PATH) |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
33 |
ISABELLE_OCAML (formerly EXEC_OCAML) |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
34 |
ISABELLE_SWIPL (formerly EXEC_SWIPL) |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
35 |
ISABELLE_YAP (formerly EXEC_YAP) |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
36 |
|
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
37 |
Note that automated detection from the file-system or search path has |
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
38 |
been discontinued. INCOMPATIBILITY. |
41950
134131d519c0
clarified ISABELLE_CSDP setting (formerly CSDP_EXE);
wenzelm
parents:
41944
diff
changeset
|
39 |
|
42358
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
40 |
* Name space: proper configuration options "long_names", |
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
41 |
"short_names", "unique_names" instead of former unsynchronized |
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
42 |
references. Minor INCOMPATIBILITY, need to declare options in context |
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
43 |
like this: |
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
44 |
|
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
45 |
declare [[unique_names = false]] |
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
46 |
|
41703
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
47 |
|
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
48 |
*** HOL *** |
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
49 |
|
41792
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
50 |
* Nitpick: |
41877 | 51 |
- Added "need" and "total_consts" options. |
41993
bd6296de1432
reintroduced "show_skolems" option -- useful when too many Skolems are displayed
blanchet
parents:
41955
diff
changeset
|
52 |
- Reintroduced "show_skolems" option by popular demand. |
41792
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
53 |
- Renamed attribute: nitpick_def ~> nitpick_unfold. |
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
54 |
INCOMPATIBILITY. |
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
55 |
|
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
56 |
* Sledgehammer: |
41792
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
57 |
- sledgehammer available_provers ~> sledgehammer supported_provers |
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
58 |
INCOMPATIBILITY. |
42228 | 59 |
- Added "monomorphize", "monomorphize_limit", and "type_sys" options. |
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
60 |
|
41999
3c029ef9e0f2
added "simp:", "intro:", and "elim:" to "try" command
blanchet
parents:
41993
diff
changeset
|
61 |
* "try": |
3c029ef9e0f2
added "simp:", "intro:", and "elim:" to "try" command
blanchet
parents:
41993
diff
changeset
|
62 |
- Added "simp:", "intro:", and "elim:" options. |
3c029ef9e0f2
added "simp:", "intro:", and "elim:" to "try" command
blanchet
parents:
41993
diff
changeset
|
63 |
|
42160 | 64 |
* Quickcheck: |
65 |
- Added "eval" option to evaluate terms for the found counterexample |
|
66 |
(currently only supported by the default (exhaustive) tester) |
|
67 |
- Added post-processing of terms to obtain readable counterexamples |
|
68 |
(currently only supported by the default (exhaustive) tester) |
|
69 |
||
41846
b368a7aee46a
removed support for tail-recursion from function package (now implemented by partial_function)
krauss
parents:
41792
diff
changeset
|
70 |
* Function package: discontinued option "tailrec". |
b368a7aee46a
removed support for tail-recursion from function package (now implemented by partial_function)
krauss
parents:
41792
diff
changeset
|
71 |
INCOMPATIBILITY. Use partial_function instead. |
b368a7aee46a
removed support for tail-recursion from function package (now implemented by partial_function)
krauss
parents:
41792
diff
changeset
|
72 |
|
42149 | 73 |
* HOL-Probability: |
74 |
- Caratheodory's extension lemma is now proved for ring_of_sets. |
|
75 |
- Infinite products of probability measures are now available. |
|
76 |
- Use extended reals instead of positive extended reals. |
|
77 |
INCOMPATIBILITY. |
|
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
78 |
|
41685
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
79 |
*** Document preparation *** |
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
80 |
|
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
81 |
* New term style "isub" as ad-hoc conversion of variables x1, y23 into |
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
82 |
subscripted form x\<^isub>1, y\<^isub>2\<^isub>3. |
41651 | 83 |
|
84 |
||
41944
b97091ae583a
Path.print is the official way to show file-system paths to users -- note that Path.implode often indicates violation of the abstract datatype;
wenzelm
parents:
41886
diff
changeset
|
85 |
*** ML *** |
b97091ae583a
Path.print is the official way to show file-system paths to users -- note that Path.implode often indicates violation of the abstract datatype;
wenzelm
parents:
41886
diff
changeset
|
86 |
|
42360 | 87 |
* Structure Proof_Context follows standard naming scheme. Old |
88 |
ProofContext is still available for some time as legacy alias. |
|
89 |
||
42015
7b6e72a1b7dd
NEWS: structure Timing provides various operations for timing;
wenzelm
parents:
41999
diff
changeset
|
90 |
* Structure Timing provides various operations for timing; supersedes |
7b6e72a1b7dd
NEWS: structure Timing provides various operations for timing;
wenzelm
parents:
41999
diff
changeset
|
91 |
former start_timing/end_timing etc. |
7b6e72a1b7dd
NEWS: structure Timing provides various operations for timing;
wenzelm
parents:
41999
diff
changeset
|
92 |
|
41944
b97091ae583a
Path.print is the official way to show file-system paths to users -- note that Path.implode often indicates violation of the abstract datatype;
wenzelm
parents:
41886
diff
changeset
|
93 |
* Path.print is the official way to show file-system paths to users |
b97091ae583a
Path.print is the official way to show file-system paths to users -- note that Path.implode often indicates violation of the abstract datatype;
wenzelm
parents:
41886
diff
changeset
|
94 |
(including quotes etc.). |
b97091ae583a
Path.print is the official way to show file-system paths to users -- note that Path.implode often indicates violation of the abstract datatype;
wenzelm
parents:
41886
diff
changeset
|
95 |
|
42056
160a630b2c7e
enable inner syntax source positions by default (controlled via configuration option);
wenzelm
parents:
42015
diff
changeset
|
96 |
* Inner syntax: identifiers in parse trees of generic categories |
160a630b2c7e
enable inner syntax source positions by default (controlled via configuration option);
wenzelm
parents:
42015
diff
changeset
|
97 |
"logic", "aprop", "idt" etc. carry position information (disguised as |
160a630b2c7e
enable inner syntax source positions by default (controlled via configuration option);
wenzelm
parents:
42015
diff
changeset
|
98 |
type constraints). Occasional INCOMPATIBILITY with non-compliant |
42057
3eba96ff3d3e
more selective strip_positions in case patterns -- reactivate translations based on "case _ of _" in HOL and special patterns in HOLCF;
wenzelm
parents:
42056
diff
changeset
|
99 |
translations that choke on unexpected type constraints. Positions can |
3eba96ff3d3e
more selective strip_positions in case patterns -- reactivate translations based on "case _ of _" in HOL and special patterns in HOLCF;
wenzelm
parents:
42056
diff
changeset
|
100 |
be stripped in ML translations via Syntax.strip_positions / |
3eba96ff3d3e
more selective strip_positions in case patterns -- reactivate translations based on "case _ of _" in HOL and special patterns in HOLCF;
wenzelm
parents:
42056
diff
changeset
|
101 |
Syntax.strip_positions_ast, or via the syntax constant |
3eba96ff3d3e
more selective strip_positions in case patterns -- reactivate translations based on "case _ of _" in HOL and special patterns in HOLCF;
wenzelm
parents:
42056
diff
changeset
|
102 |
"_strip_positions" within parse trees. As last resort, positions can |
3eba96ff3d3e
more selective strip_positions in case patterns -- reactivate translations based on "case _ of _" in HOL and special patterns in HOLCF;
wenzelm
parents:
42056
diff
changeset
|
103 |
be disabled via the configuration option Syntax.positions, which is |
3eba96ff3d3e
more selective strip_positions in case patterns -- reactivate translations based on "case _ of _" in HOL and special patterns in HOLCF;
wenzelm
parents:
42056
diff
changeset
|
104 |
called "syntax_positions" in Isar attribute syntax. |
42056
160a630b2c7e
enable inner syntax source positions by default (controlled via configuration option);
wenzelm
parents:
42015
diff
changeset
|
105 |
|
42290
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
106 |
* Discontinued special status of various ML structures that contribute |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
107 |
to structure Syntax (Ast, Lexicon, Mixfix, Parser, Printer etc.): less |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
108 |
pervasive content, no inclusion in structure Syntax. INCOMPATIBILITY, |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
109 |
refer directly to Ast.Constant, Lexicon.is_identifier, |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
110 |
Syntax_Trans.mk_binder_tr etc. |
42224
578a51fae383
discontinued special treatment of structure Ast: no pervasive content, no inclusion in structure Syntax;
wenzelm
parents:
42180
diff
changeset
|
111 |
|
42247
12fe41a92cd5
typed_print_translation: discontinued show_sorts argument;
wenzelm
parents:
42239
diff
changeset
|
112 |
* Typed print translation: discontinued show_sorts argument, which is |
12fe41a92cd5
typed_print_translation: discontinued show_sorts argument;
wenzelm
parents:
42239
diff
changeset
|
113 |
already available via context of "advanced" translation. |
12fe41a92cd5
typed_print_translation: discontinued show_sorts argument;
wenzelm
parents:
42239
diff
changeset
|
114 |
|
42370 | 115 |
* Refined PARALLEL_GOALS tactical: degrades gracefully for schematic |
116 |
goal states; body tactic needs to address all subgoals uniformly. |
|
117 |
||
42403
38b29c9fc742
slightly more special eq_list/eq_set, with shortcut involving pointer_eq;
wenzelm
parents:
42370
diff
changeset
|
118 |
* Slightly more special eq_list/eq_set, with shortcut involving |
38b29c9fc742
slightly more special eq_list/eq_set, with shortcut involving pointer_eq;
wenzelm
parents:
42370
diff
changeset
|
119 |
pointer equality (assumes that eq relation is reflexive). |
38b29c9fc742
slightly more special eq_list/eq_set, with shortcut involving pointer_eq;
wenzelm
parents:
42370
diff
changeset
|
120 |
|
41944
b97091ae583a
Path.print is the official way to show file-system paths to users -- note that Path.implode often indicates violation of the abstract datatype;
wenzelm
parents:
41886
diff
changeset
|
121 |
|
41703
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
122 |
|
41512 | 123 |
New in Isabelle2011 (January 2011) |
124 |
---------------------------------- |
|
37383 | 125 |
|
37536
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
126 |
*** General *** |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
127 |
|
41573 | 128 |
* Experimental Prover IDE based on Isabelle/Scala and jEdit (see |
41612 | 129 |
src/Tools/jEdit). This also serves as IDE for Isabelle/ML, with |
130 |
useful tooltips and hyperlinks produced from its static analysis. The |
|
131 |
bundled component provides an executable Isabelle tool that can be run |
|
132 |
like this: |
|
133 |
||
134 |
Isabelle2011/bin/isabelle jedit |
|
41573 | 135 |
|
40948 | 136 |
* Significantly improved Isabelle/Isar implementation manual. |
137 |
||
41594 | 138 |
* System settings: ISABELLE_HOME_USER now includes ISABELLE_IDENTIFIER |
41595 | 139 |
(and thus refers to something like $HOME/.isabelle/Isabelle2011), |
41594 | 140 |
while the default heap location within that directory lacks that extra |
141 |
suffix. This isolates multiple Isabelle installations from each |
|
142 |
other, avoiding problems with old settings in new versions. |
|
143 |
INCOMPATIBILITY, need to copy/upgrade old user settings manually. |
|
144 |
||
40947 | 145 |
* Source files are always encoded as UTF-8, instead of old-fashioned |
146 |
ISO-Latin-1. INCOMPATIBILITY. Isabelle LaTeX documents might require |
|
40948 | 147 |
the following package declarations: |
40947 | 148 |
|
149 |
\usepackage[utf8]{inputenc} |
|
150 |
\usepackage{textcomp} |
|
151 |
||
41440 | 152 |
* Explicit treatment of UTF-8 sequences as Isabelle symbols, such that |
37536
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
153 |
a Unicode character is treated as a single symbol, not a sequence of |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
154 |
non-ASCII bytes as before. Since Isabelle/ML string literals may |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
155 |
contain symbols without further backslash escapes, Unicode can now be |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
156 |
used here as well. Recall that Symbol.explode in ML provides a |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
157 |
consistent view on symbols, while raw explode (or String.explode) |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
158 |
merely give a byte-oriented representation. |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
159 |
|
41594 | 160 |
* Theory loader: source files are primarily located via the master |
161 |
directory of each theory node (where the .thy file itself resides). |
|
162 |
The global load path is still partially available as legacy feature. |
|
163 |
Minor INCOMPATIBILITY due to subtle change in file lookup: use |
|
164 |
explicit paths, relatively to the theory. |
|
38135
2b9bfa0b44f1
theory loading: only the master source file is looked-up in the implicit load path;
wenzelm
parents:
38110
diff
changeset
|
165 |
|
37939
965537d86fcc
discontinued special treatment of ML files -- no longer complete extensions on demand;
wenzelm
parents:
37868
diff
changeset
|
166 |
* Special treatment of ML file names has been discontinued. |
965537d86fcc
discontinued special treatment of ML files -- no longer complete extensions on demand;
wenzelm
parents:
37868
diff
changeset
|
167 |
Historically, optional extensions .ML or .sml were added on demand -- |
965537d86fcc
discontinued special treatment of ML files -- no longer complete extensions on demand;
wenzelm
parents:
37868
diff
changeset
|
168 |
at the cost of clarity of file dependencies. Recall that Isabelle/ML |
965537d86fcc
discontinued special treatment of ML files -- no longer complete extensions on demand;
wenzelm
parents:
37868
diff
changeset
|
169 |
files exclusively use the .ML extension. Minor INCOMPATIBILTY. |
965537d86fcc
discontinued special treatment of ML files -- no longer complete extensions on demand;
wenzelm
parents:
37868
diff
changeset
|
170 |
|
38980
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
171 |
* Various options that affect pretty printing etc. are now properly |
38767
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
wenzelm
parents:
38708
diff
changeset
|
172 |
handled within the context via configuration options, instead of |
40879
ca132ef44944
configuration option "show_abbrevs" supersedes print mode "no_abbrevs", with inverted meaning;
wenzelm
parents:
40878
diff
changeset
|
173 |
unsynchronized references or print modes. There are both ML Config.T |
ca132ef44944
configuration option "show_abbrevs" supersedes print mode "no_abbrevs", with inverted meaning;
wenzelm
parents:
40878
diff
changeset
|
174 |
entities and Isar declaration attributes to access these. |
38767
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
wenzelm
parents:
38708
diff
changeset
|
175 |
|
39125
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
176 |
ML (Config.T) Isar (attribute) |
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
177 |
|
39128
93a7365fb4ee
turned eta_contract into proper configuration option;
wenzelm
parents:
39126
diff
changeset
|
178 |
eta_contract eta_contract |
39137
ccb53edd59f0
turned show_brackets into proper configuration option;
wenzelm
parents:
39134
diff
changeset
|
179 |
show_brackets show_brackets |
39134
917b4b6ba3d2
turned show_sorts/show_types into proper configuration options;
wenzelm
parents:
39128
diff
changeset
|
180 |
show_sorts show_sorts |
917b4b6ba3d2
turned show_sorts/show_types into proper configuration options;
wenzelm
parents:
39128
diff
changeset
|
181 |
show_types show_types |
39126
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
182 |
show_question_marks show_question_marks |
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
183 |
show_consts show_consts |
40879
ca132ef44944
configuration option "show_abbrevs" supersedes print mode "no_abbrevs", with inverted meaning;
wenzelm
parents:
40878
diff
changeset
|
184 |
show_abbrevs show_abbrevs |
39126
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
185 |
|
41379 | 186 |
Syntax.ast_trace syntax_ast_trace |
187 |
Syntax.ast_stat syntax_ast_stat |
|
39126
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
188 |
Syntax.ambiguity_level syntax_ambiguity_level |
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
189 |
|
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
190 |
Goal_Display.goals_limit goals_limit |
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
191 |
Goal_Display.show_main_goal show_main_goal |
ee117c5b3b75
configuration options Syntax.ambiguity_enabled (inverse of former Syntax.ambiguity_is_error), Syntax.ambiguity_level (with Isar attribute "syntax_ambiguity_level"), Syntax.ambiguity_limit;
wenzelm
parents:
39125
diff
changeset
|
192 |
|
41379 | 193 |
Method.rule_trace rule_trace |
194 |
||
39125
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
195 |
Thy_Output.display thy_output_display |
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
196 |
Thy_Output.quotes thy_output_quotes |
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
197 |
Thy_Output.indent thy_output_indent |
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
198 |
Thy_Output.source thy_output_source |
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
199 |
Thy_Output.break thy_output_break |
f45d332a90e3
pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents:
39105
diff
changeset
|
200 |
|
41440 | 201 |
Note that corresponding "..._default" references in ML may only be |
38767
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
wenzelm
parents:
38708
diff
changeset
|
202 |
changed globally at the ROOT session setup, but *not* within a theory. |
40879
ca132ef44944
configuration option "show_abbrevs" supersedes print mode "no_abbrevs", with inverted meaning;
wenzelm
parents:
40878
diff
changeset
|
203 |
The option "show_abbrevs" supersedes the former print mode |
ca132ef44944
configuration option "show_abbrevs" supersedes print mode "no_abbrevs", with inverted meaning;
wenzelm
parents:
40878
diff
changeset
|
204 |
"no_abbrevs" with inverted meaning. |
38767
d8da44a8dd25
proper context for various Thy_Output options, via official configuration options in ML and Isar;
wenzelm
parents:
38708
diff
changeset
|
205 |
|
40878
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
206 |
* More systematic naming of some configuration options. |
41294 | 207 |
INCOMPATIBILITY. |
40878
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
208 |
|
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
209 |
trace_simp ~> simp_trace |
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
210 |
debug_simp ~> simp_debug |
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
211 |
|
40291 | 212 |
* Support for real valued configuration options, using simplistic |
213 |
floating-point notation that coincides with the inner syntax for |
|
214 |
float_token. |
|
215 |
||
41594 | 216 |
* Support for real valued preferences (with approximative PGIP type): |
217 |
front-ends need to accept "pgint" values in float notation. |
|
218 |
INCOMPATIBILITY. |
|
41573 | 219 |
|
220 |
* The IsabelleText font now includes Cyrillic, Hebrew, Arabic from |
|
221 |
DejaVu Sans. |
|
222 |
||
41594 | 223 |
* Discontinued support for Poly/ML 5.0 and 5.1 versions. |
224 |
||
40948 | 225 |
|
226 |
*** Pure *** |
|
227 |
||
41249
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
228 |
* Command 'type_synonym' (with single argument) replaces somewhat |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
229 |
outdated 'types', which is still available as legacy feature for some |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
230 |
time. |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
231 |
|
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
232 |
* Command 'nonterminal' (with 'and' separated list of arguments) |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
233 |
replaces somewhat outdated 'nonterminals'. INCOMPATIBILITY. |
41229
d797baa3d57c
replaced command 'nonterminals' by slightly modernized version 'nonterminal';
wenzelm
parents:
41228
diff
changeset
|
234 |
|
40965
54b6c9e1c157
command 'notepad' replaces former 'example_proof';
wenzelm
parents:
40959
diff
changeset
|
235 |
* Command 'notepad' replaces former 'example_proof' for |
41020 | 236 |
experimentation in Isar without any result. INCOMPATIBILITY. |
40965
54b6c9e1c157
command 'notepad' replaces former 'example_proof';
wenzelm
parents:
40959
diff
changeset
|
237 |
|
41435 | 238 |
* Locale interpretation commands 'interpret' and 'sublocale' accept |
239 |
lists of equations to map definitions in a locale to appropriate |
|
240 |
entities in the context of the interpretation. The 'interpretation' |
|
241 |
command already provided this functionality. |
|
242 |
||
41594 | 243 |
* Diagnostic command 'print_dependencies' prints the locale instances |
244 |
that would be activated if the specified expression was interpreted in |
|
245 |
the current context. Variant "print_dependencies!" assumes a context |
|
246 |
without interpretations. |
|
38110 | 247 |
|
248 |
* Diagnostic command 'print_interps' prints interpretations in proofs |
|
249 |
in addition to interpretations in theories. |
|
250 |
||
38708
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
251 |
* Discontinued obsolete 'global' and 'local' commands to manipulate |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
252 |
the theory name space. Rare INCOMPATIBILITY. The ML functions |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
253 |
Sign.root_path and Sign.local_path may be applied directly where this |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
254 |
feature is still required for historical reasons. |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
255 |
|
40948 | 256 |
* Discontinued obsolete 'constdefs' command. INCOMPATIBILITY, use |
39215 | 257 |
'definition' instead. |
258 |
||
41574 | 259 |
* The "prems" fact, which refers to the accidental collection of |
260 |
foundational premises in the context, is now explicitly marked as |
|
41594 | 261 |
legacy feature and will be discontinued soon. Consider using "assms" |
262 |
of the head statement or reference facts by explicit names. |
|
41574 | 263 |
|
40801 | 264 |
* Document antiquotations @{class} and @{type} print classes and type |
265 |
constructors. |
|
266 |
||
267 |
* Document antiquotation @{file} checks file/directory entries within |
|
268 |
the local file system. |
|
39305
d4fa19eb0822
'class' and 'type' are now antiquoations by default
haftmann
parents:
39277
diff
changeset
|
269 |
|
38110 | 270 |
|
37387
3581483cca6c
qualified types "+" and nat; qualified constants Ball, Bex, Suc, curry; modernized some specifications
haftmann
parents:
37383
diff
changeset
|
271 |
*** HOL *** |
3581483cca6c
qualified types "+" and nat; qualified constants Ball, Bex, Suc, curry; modernized some specifications
haftmann
parents:
37383
diff
changeset
|
272 |
|
41594 | 273 |
* Coercive subtyping: functions can be declared as coercions and type |
274 |
inference will add them as necessary upon input of a term. Theory |
|
275 |
Complex_Main declares real :: nat => real and real :: int => real as |
|
276 |
coercions. A coercion function f is declared like this: |
|
40939
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
277 |
|
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
278 |
declare [[coercion f]] |
40866 | 279 |
|
41571 | 280 |
To lift coercions through type constructors (e.g. from nat => real to |
40866 | 281 |
nat list => real list), map functions can be declared, e.g. |
282 |
||
40939
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
283 |
declare [[coercion_map map]] |
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
284 |
|
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
285 |
Currently coercion inference is activated only in theories including |
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
286 |
real numbers, i.e. descendants of Complex_Main. This is controlled by |
41020 | 287 |
the configuration option "coercion_enabled", e.g. it can be enabled in |
40939
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
288 |
other theories like this: |
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
289 |
|
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
290 |
declare [[coercion_enabled]] |
40866 | 291 |
|
41571 | 292 |
* Command 'partial_function' provides basic support for recursive |
293 |
function definitions over complete partial orders. Concrete instances |
|
40183 | 294 |
are provided for i) the option type, ii) tail recursion on arbitrary |
41571 | 295 |
types, and iii) the heap monad of Imperative_HOL. See |
296 |
src/HOL/ex/Fundefs.thy and src/HOL/Imperative_HOL/ex/Linked_Lists.thy |
|
297 |
for examples. |
|
40183 | 298 |
|
41571 | 299 |
* Function package: f.psimps rules are no longer implicitly declared |
300 |
as [simp]. INCOMPATIBILITY. |
|
41398 | 301 |
|
302 |
* Datatype package: theorems generated for executable equality (class |
|
41571 | 303 |
"eq") carry proper names and are treated as default code equations. |
304 |
||
41594 | 305 |
* Inductive package: now offers command 'inductive_simps' to |
306 |
automatically derive instantiated and simplified equations for |
|
307 |
inductive predicates, similar to 'inductive_cases'. |
|
308 |
||
41571 | 309 |
* Command 'enriched_type' allows to register properties of the |
310 |
functorial structure of types. |
|
39771 | 311 |
|
39644 | 312 |
* Improved infrastructure for term evaluation using code generator |
313 |
techniques, in particular static evaluation conversions. |
|
314 |
||
41594 | 315 |
* Code generator: Scala (2.8 or higher) has been added to the target |
316 |
languages. |
|
317 |
||
41398 | 318 |
* Code generator: globbing constant expressions "*" and "Theory.*" |
319 |
have been replaced by the more idiomatic "_" and "Theory._". |
|
320 |
INCOMPATIBILITY. |
|
321 |
||
322 |
* Code generator: export_code without explicit file declaration prints |
|
323 |
to standard output. INCOMPATIBILITY. |
|
324 |
||
325 |
* Code generator: do not print function definitions for case |
|
326 |
combinators any longer. |
|
327 |
||
41594 | 328 |
* Code generator: simplification with rules determined with |
41571 | 329 |
src/Tools/Code/code_simp.ML and method "code_simp". |
330 |
||
41594 | 331 |
* Code generator for records: more idiomatic representation of record |
40948 | 332 |
types. Warning: records are not covered by ancient SML code |
333 |
generation any longer. INCOMPATIBILITY. In cases of need, a suitable |
|
334 |
rep_datatype declaration helps to succeed then: |
|
38537 | 335 |
|
336 |
record 'a foo = ... |
|
337 |
... |
|
338 |
rep_datatype foo_ext ... |
|
38535 | 339 |
|
41594 | 340 |
* Records: logical foundation type for records does not carry a |
341 |
'_type' suffix any longer (obsolete due to authentic syntax). |
|
342 |
INCOMPATIBILITY. |
|
343 |
||
41398 | 344 |
* Quickcheck now by default uses exhaustive testing instead of random |
41571 | 345 |
testing. Random testing can be invoked by "quickcheck [random]", |
346 |
exhaustive testing by "quickcheck [exhaustive]". |
|
41398 | 347 |
|
348 |
* Quickcheck instantiates polymorphic types with small finite |
|
349 |
datatypes by default. This enables a simple execution mechanism to |
|
350 |
handle quantifiers and function equality over the finite datatypes. |
|
351 |
||
41571 | 352 |
* Quickcheck random generator has been renamed from "code" to |
353 |
"random". INCOMPATIBILITY. |
|
41398 | 354 |
|
355 |
* Quickcheck now has a configurable time limit which is set to 30 |
|
356 |
seconds by default. This can be changed by adding [timeout = n] to the |
|
357 |
quickcheck command. The time limit for Auto Quickcheck is still set |
|
358 |
independently. |
|
38461 | 359 |
|
360 |
* Quickcheck in locales considers interpretations of that locale for |
|
361 |
counter example search. |
|
362 |
||
40059
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
363 |
* Sledgehammer: |
41571 | 364 |
- Added "smt" and "remote_smt" provers based on the "smt" proof |
365 |
method. See the Sledgehammer manual for details ("isabelle doc |
|
366 |
sledgehammer"). |
|
40059
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
367 |
- Renamed commands: |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
368 |
sledgehammer atp_info ~> sledgehammer running_provers |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
369 |
sledgehammer atp_kill ~> sledgehammer kill_provers |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
370 |
sledgehammer available_atps ~> sledgehammer available_provers |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
371 |
INCOMPATIBILITY. |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
372 |
- Renamed options: |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
373 |
sledgehammer [atps = ...] ~> sledgehammer [provers = ...] |
40062 | 374 |
sledgehammer [atp = ...] ~> sledgehammer [prover = ...] |
40341
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
375 |
sledgehammer [timeout = 77 s] ~> sledgehammer [timeout = 77] |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
376 |
(and "ms" and "min" are no longer supported) |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
377 |
INCOMPATIBILITY. |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
378 |
|
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
379 |
* Nitpick: |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
380 |
- Renamed options: |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
381 |
nitpick [timeout = 77 s] ~> nitpick [timeout = 77] |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
382 |
nitpick [tac_timeout = 777 ms] ~> nitpick [tac_timeout = 0.777] |
40059
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
383 |
INCOMPATIBILITY. |
40725 | 384 |
- Added support for partial quotient types. |
385 |
- Added local versions of the "Nitpick.register_xxx" functions. |
|
386 |
- Added "whack" option. |
|
387 |
- Allow registration of quotient types as codatatypes. |
|
388 |
- Improved "merge_type_vars" option to merge more types. |
|
389 |
- Removed unsound "fast_descrs" option. |
|
390 |
- Added custom symmetry breaking for datatypes, making it possible to reach |
|
391 |
higher cardinalities. |
|
392 |
- Prevent the expansion of too large definitions. |
|
39957
2f2d90cc31a2
document latest changes to Meson/Metis/Sledgehammer
blanchet
parents:
39910
diff
changeset
|
393 |
|
41571 | 394 |
* Proof methods "metis" and "meson" now have configuration options |
395 |
"meson_trace", "metis_trace", and "metis_verbose" that can be enabled |
|
396 |
to diagnose these tools. E.g. |
|
397 |
||
398 |
using [[metis_trace = true]] |
|
399 |
||
41398 | 400 |
* Auto Solve: Renamed "Auto Solve Direct". The tool is now available |
401 |
manually as command 'solve_direct'. |
|
402 |
||
41601 | 403 |
* The default SMT solver Z3 must be enabled explicitly (due to |
404 |
licensing issues) by setting the environment variable |
|
41603 | 405 |
Z3_NON_COMMERCIAL in etc/settings of the component, for example. For |
406 |
commercial applications, the SMT solver CVC3 is provided as fall-back; |
|
407 |
changing the SMT solver is done via the configuration option |
|
408 |
"smt_solver". |
|
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
409 |
|
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
410 |
* Remote SMT solvers need to be referred to by the "remote_" prefix, |
41571 | 411 |
i.e. "remote_cvc3" and "remote_z3". |
412 |
||
413 |
* Added basic SMT support for datatypes, records, and typedefs using |
|
414 |
the oracle mode (no proofs). Direct support of pairs has been dropped |
|
415 |
in exchange (pass theorems fst_conv snd_conv pair_collapse to the SMT |
|
416 |
support for a similar behavior). Minor INCOMPATIBILITY. |
|
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
417 |
|
40162
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
418 |
* Changed SMT configuration options: |
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
419 |
- Renamed: |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
420 |
z3_proofs ~> smt_oracle (with inverted meaning) |
40162
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
421 |
z3_trace_assms ~> smt_trace_used_facts |
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
422 |
INCOMPATIBILITY. |
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
423 |
- Added: |
40424
7550b2cba1cb
better modularization: moved SMT configuration options and diagnostics as well as SMT failure and exception into separate structures (both of which are loaded first and consequently are available to other SMT structures)
boehmes
parents:
40388
diff
changeset
|
424 |
smt_verbose |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
425 |
smt_random_seed |
40424
7550b2cba1cb
better modularization: moved SMT configuration options and diagnostics as well as SMT failure and exception into separate structures (both of which are loaded first and consequently are available to other SMT structures)
boehmes
parents:
40388
diff
changeset
|
426 |
smt_datatypes |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
427 |
smt_infer_triggers |
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
428 |
smt_monomorph_limit |
40162
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
429 |
cvc3_options |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
430 |
remote_cvc3_options |
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
431 |
remote_z3_options |
40162
7f58a9a843c2
joined setup of SMT solvers in one place; turned Z3-specific options into SMT options (renamed configuration options from z3_* to smt_*); more detailed SMT exception; improved SMT filter interface
boehmes
parents:
40128
diff
changeset
|
432 |
yices_options |
39957
2f2d90cc31a2
document latest changes to Meson/Metis/Sledgehammer
blanchet
parents:
39910
diff
changeset
|
433 |
|
40948 | 434 |
* Boogie output files (.b2i files) need to be declared in the theory |
435 |
header. |
|
40580
0592d3a39c08
require the b2i file ending in the boogie_open command (for consistency with the theory header)
boehmes
parents:
40424
diff
changeset
|
436 |
|
41594 | 437 |
* Simplification procedure "list_to_set_comprehension" rewrites list |
438 |
comprehensions applied to List.set to set comprehensions. Occasional |
|
439 |
INCOMPATIBILITY, may be deactivated like this: |
|
440 |
||
441 |
declare [[simproc del: list_to_set_comprehension]] |
|
442 |
||
41573 | 443 |
* Removed old version of primrec package. INCOMPATIBILITY. |
41398 | 444 |
|
445 |
* Removed simplifier congruence rule of "prod_case", as has for long |
|
446 |
been the case with "split". INCOMPATIBILITY. |
|
447 |
||
448 |
* String.literal is a type, but not a datatype. INCOMPATIBILITY. |
|
449 |
||
40388
cb9fd7dd641c
abolished obscure goal variant of [split_format] -- unused (cf. d1c14898fd04), unrelated to '(complete)' variant, and not at all canonical
krauss
parents:
40387
diff
changeset
|
450 |
* Removed [split_format ... and ... and ...] version of |
cb9fd7dd641c
abolished obscure goal variant of [split_format] -- unused (cf. d1c14898fd04), unrelated to '(complete)' variant, and not at all canonical
krauss
parents:
40387
diff
changeset
|
451 |
[split_format]. Potential INCOMPATIBILITY. |
cb9fd7dd641c
abolished obscure goal variant of [split_format] -- unused (cf. d1c14898fd04), unrelated to '(complete)' variant, and not at all canonical
krauss
parents:
40387
diff
changeset
|
452 |
|
41571 | 453 |
* Predicate "sorted" now defined inductively, with nice induction |
454 |
rules. INCOMPATIBILITY: former sorted.simps now named sorted_simps. |
|
41398 | 455 |
|
456 |
* Constant "contents" renamed to "the_elem", to free the generic name |
|
457 |
contents for other uses. INCOMPATIBILITY. |
|
458 |
||
459 |
* Renamed class eq and constant eq (for code generation) to class |
|
460 |
equal and constant equal, plus renaming of related facts and various |
|
461 |
tuning. INCOMPATIBILITY. |
|
462 |
||
463 |
* Dropped type classes mult_mono and mult_mono1. INCOMPATIBILITY. |
|
464 |
||
41571 | 465 |
* Removed output syntax "'a ~=> 'b" for "'a => 'b option". |
466 |
INCOMPATIBILITY. |
|
41398 | 467 |
|
468 |
* Renamed theory Fset to Cset, type Fset.fset to Cset.set, in order to |
|
469 |
avoid confusion with finite sets. INCOMPATIBILITY. |
|
470 |
||
471 |
* Abandoned locales equiv, congruent and congruent2 for equivalence |
|
472 |
relations. INCOMPATIBILITY: use equivI rather than equiv_intro (same |
|
473 |
for congruent(2)). |
|
474 |
||
475 |
* Some previously unqualified names have been qualified: |
|
476 |
||
477 |
types |
|
478 |
bool ~> HOL.bool |
|
479 |
nat ~> Nat.nat |
|
480 |
||
481 |
constants |
|
482 |
Trueprop ~> HOL.Trueprop |
|
483 |
True ~> HOL.True |
|
484 |
False ~> HOL.False |
|
485 |
op & ~> HOL.conj |
|
486 |
op | ~> HOL.disj |
|
487 |
op --> ~> HOL.implies |
|
488 |
op = ~> HOL.eq |
|
489 |
Not ~> HOL.Not |
|
490 |
The ~> HOL.The |
|
491 |
All ~> HOL.All |
|
492 |
Ex ~> HOL.Ex |
|
493 |
Ex1 ~> HOL.Ex1 |
|
494 |
Let ~> HOL.Let |
|
495 |
If ~> HOL.If |
|
496 |
Ball ~> Set.Ball |
|
497 |
Bex ~> Set.Bex |
|
498 |
Suc ~> Nat.Suc |
|
499 |
Pair ~> Product_Type.Pair |
|
500 |
fst ~> Product_Type.fst |
|
501 |
snd ~> Product_Type.snd |
|
502 |
curry ~> Product_Type.curry |
|
503 |
op : ~> Set.member |
|
504 |
Collect ~> Set.Collect |
|
505 |
||
506 |
INCOMPATIBILITY. |
|
507 |
||
508 |
* More canonical naming convention for some fundamental definitions: |
|
509 |
||
510 |
bot_bool_eq ~> bot_bool_def |
|
511 |
top_bool_eq ~> top_bool_def |
|
512 |
inf_bool_eq ~> inf_bool_def |
|
513 |
sup_bool_eq ~> sup_bool_def |
|
514 |
bot_fun_eq ~> bot_fun_def |
|
515 |
top_fun_eq ~> top_fun_def |
|
516 |
inf_fun_eq ~> inf_fun_def |
|
517 |
sup_fun_eq ~> sup_fun_def |
|
518 |
||
519 |
INCOMPATIBILITY. |
|
520 |
||
521 |
* More stylized fact names: |
|
522 |
||
523 |
expand_fun_eq ~> fun_eq_iff |
|
524 |
expand_set_eq ~> set_eq_iff |
|
525 |
set_ext ~> set_eqI |
|
526 |
nat_number ~> eval_nat_numeral |
|
527 |
||
528 |
INCOMPATIBILITY. |
|
529 |
||
41571 | 530 |
* Refactoring of code-generation specific operations in theory List: |
41398 | 531 |
|
532 |
constants |
|
533 |
null ~> List.null |
|
534 |
||
535 |
facts |
|
536 |
mem_iff ~> member_def |
|
537 |
null_empty ~> null_def |
|
538 |
||
539 |
INCOMPATIBILITY. Note that these were not supposed to be used |
|
540 |
regularly unless for striking reasons; their main purpose was code |
|
541 |
generation. |
|
542 |
||
543 |
Various operations from the Haskell prelude are used for generating |
|
544 |
Haskell code. |
|
545 |
||
41571 | 546 |
* Term "bij f" is now an abbreviation of "bij_betw f UNIV UNIV". Term |
547 |
"surj f" is now an abbreviation of "range f = UNIV". The theorems |
|
548 |
bij_def and surj_def are unchanged. INCOMPATIBILITY. |
|
41398 | 549 |
|
550 |
* Abolished some non-alphabetic type names: "prod" and "sum" replace |
|
551 |
"*" and "+" respectively. INCOMPATIBILITY. |
|
552 |
||
553 |
* Name "Plus" of disjoint sum operator "<+>" is now hidden. Write |
|
41571 | 554 |
"Sum_Type.Plus" instead. |
41398 | 555 |
|
556 |
* Constant "split" has been merged with constant "prod_case"; names of |
|
557 |
ML functions, facts etc. involving split have been retained so far, |
|
558 |
though. INCOMPATIBILITY. |
|
559 |
||
560 |
* Dropped old infix syntax "_ mem _" for List.member; use "_ : set _" |
|
561 |
instead. INCOMPATIBILITY. |
|
562 |
||
41571 | 563 |
* Removed lemma "Option.is_none_none" which duplicates "is_none_def". |
41398 | 564 |
INCOMPATIBILITY. |
565 |
||
41594 | 566 |
* Former theory Library/Enum is now part of the HOL-Main image. |
567 |
INCOMPATIBILITY: all constants of the Enum theory now have to be |
|
568 |
referred to by its qualified name. |
|
569 |
||
570 |
enum ~> Enum.enum |
|
571 |
nlists ~> Enum.nlists |
|
572 |
product ~> Enum.product |
|
573 |
||
574 |
* Theory Library/Monad_Syntax provides do-syntax for monad types. |
|
575 |
Syntax in Library/State_Monad has been changed to avoid ambiguities. |
|
576 |
INCOMPATIBILITY. |
|
577 |
||
578 |
* Theory Library/SetsAndFunctions has been split into |
|
579 |
Library/Function_Algebras and Library/Set_Algebras; canonical names |
|
580 |
for instance definitions for functions; various improvements. |
|
581 |
INCOMPATIBILITY. |
|
582 |
||
583 |
* Theory Library/Multiset provides stable quicksort implementation of |
|
584 |
sort_key. |
|
585 |
||
586 |
* Theory Library/Multiset: renamed empty_idemp ~> empty_neutral. |
|
587 |
INCOMPATIBILITY. |
|
588 |
||
589 |
* Session Multivariate_Analysis: introduced a type class for euclidean |
|
590 |
space. Most theorems are now stated in terms of euclidean spaces |
|
591 |
instead of finite cartesian products. |
|
592 |
||
593 |
types |
|
594 |
real ^ 'n ~> 'a::real_vector |
|
595 |
~> 'a::euclidean_space |
|
596 |
~> 'a::ordered_euclidean_space |
|
597 |
(depends on your needs) |
|
598 |
||
599 |
constants |
|
600 |
_ $ _ ~> _ $$ _ |
|
601 |
\<chi> x. _ ~> \<chi>\<chi> x. _ |
|
602 |
CARD('n) ~> DIM('a) |
|
603 |
||
604 |
Also note that the indices are now natural numbers and not from some |
|
605 |
finite type. Finite cartesian products of euclidean spaces, products |
|
606 |
of euclidean spaces the real and complex numbers are instantiated to |
|
607 |
be euclidean_spaces. INCOMPATIBILITY. |
|
608 |
||
609 |
* Session Probability: introduced pextreal as positive extended real |
|
610 |
numbers. Use pextreal as value for measures. Introduce the |
|
611 |
Radon-Nikodym derivative, product spaces and Fubini's theorem for |
|
612 |
arbitrary sigma finite measures. Introduces Lebesgue measure based on |
|
613 |
the integral in Multivariate Analysis. INCOMPATIBILITY. |
|
614 |
||
615 |
* Session Imperative_HOL: revamped, corrected dozens of inadequacies. |
|
616 |
INCOMPATIBILITY. |
|
617 |
||
618 |
* Session SPARK (with image HOL-SPARK) provides commands to load and |
|
619 |
prove verification conditions generated by the SPARK Ada program |
|
620 |
verifier. See also src/HOL/SPARK and src/HOL/SPARK/Examples. |
|
41567 | 621 |
|
40621 | 622 |
|
41433
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
623 |
*** HOL-Algebra *** |
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
624 |
|
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
625 |
* Theorems for additive ring operations (locale abelian_monoid and |
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
626 |
descendants) are generated by interpretation from their multiplicative |
41434
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
627 |
counterparts. Names (in particular theorem names) have the mandatory |
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
628 |
qualifier 'add'. Previous theorem names are redeclared for |
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
629 |
compatibility. |
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
630 |
|
41571 | 631 |
* Structure "int_ring" is now an abbreviation (previously a |
41434
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
632 |
definition). This fits more natural with advanced interpretations. |
41433
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
633 |
|
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
634 |
|
40621 | 635 |
*** HOLCF *** |
636 |
||
637 |
* The domain package now runs in definitional mode by default: The |
|
41571 | 638 |
former command 'new_domain' is now called 'domain'. To use the domain |
40621 | 639 |
package in its original axiomatic mode, use 'domain (unsafe)'. |
640 |
INCOMPATIBILITY. |
|
641 |
||
41571 | 642 |
* The new class "domain" is now the default sort. Class "predomain" |
643 |
is an unpointed version of "domain". Theories can be updated by |
|
644 |
replacing sort annotations as shown below. INCOMPATIBILITY. |
|
40621 | 645 |
|
646 |
'a::type ~> 'a::countable |
|
647 |
'a::cpo ~> 'a::predomain |
|
648 |
'a::pcpo ~> 'a::domain |
|
649 |
||
41571 | 650 |
* The old type class "rep" has been superseded by class "domain". |
40621 | 651 |
Accordingly, users of the definitional package must remove any |
41571 | 652 |
"default_sort rep" declarations. INCOMPATIBILITY. |
40621 | 653 |
|
41401 | 654 |
* The domain package (definitional mode) now supports unpointed |
655 |
predomain argument types, as long as they are marked 'lazy'. (Strict |
|
41571 | 656 |
arguments must be in class "domain".) For example, the following |
41401 | 657 |
domain definition now works: |
658 |
||
659 |
domain natlist = nil | cons (lazy "nat discr") (lazy "natlist") |
|
660 |
||
661 |
* Theory HOLCF/Library/HOL_Cpo provides cpo and predomain class |
|
41571 | 662 |
instances for types from main HOL: bool, nat, int, char, 'a + 'b, |
663 |
'a option, and 'a list. Additionally, it configures fixrec and the |
|
664 |
domain package to work with these types. For example: |
|
41401 | 665 |
|
666 |
fixrec isInl :: "('a + 'b) u -> tr" |
|
667 |
where "isInl$(up$(Inl x)) = TT" | "isInl$(up$(Inr y)) = FF" |
|
668 |
||
669 |
domain V = VFun (lazy "V -> V") | VCon (lazy "nat") (lazy "V list") |
|
670 |
||
41571 | 671 |
* The "(permissive)" option of fixrec has been replaced with a |
672 |
per-equation "(unchecked)" option. See |
|
673 |
src/HOL/HOLCF/Tutorial/Fixrec_ex.thy for examples. INCOMPATIBILITY. |
|
674 |
||
675 |
* The "bifinite" class no longer fixes a constant "approx"; the class |
|
676 |
now just asserts that such a function exists. INCOMPATIBILITY. |
|
677 |
||
678 |
* Former type "alg_defl" has been renamed to "defl". HOLCF no longer |
|
41287
029a6fc1bfb8
type 'defl' takes a type parameter again (cf. b525988432e9)
huffman
parents:
41286
diff
changeset
|
679 |
defines an embedding of type 'a defl into udom by default; instances |
41571 | 680 |
of "bifinite" and "domain" classes are available in |
681 |
src/HOL/HOLCF/Library/Defl_Bifinite.thy. |
|
682 |
||
683 |
* The syntax "REP('a)" has been replaced with "DEFL('a)". |
|
684 |
||
685 |
* The predicate "directed" has been removed. INCOMPATIBILITY. |
|
686 |
||
687 |
* The type class "finite_po" has been removed. INCOMPATIBILITY. |
|
688 |
||
689 |
* The function "cprod_map" has been renamed to "prod_map". |
|
41401 | 690 |
INCOMPATIBILITY. |
691 |
||
692 |
* The monadic bind operator on each powerdomain has new binder syntax |
|
41571 | 693 |
similar to sets, e.g. "\<Union>\<sharp>x\<in>xs. t" represents |
694 |
"upper_bind\<cdot>xs\<cdot>(\<Lambda> x. t)". |
|
41401 | 695 |
|
696 |
* The infix syntax for binary union on each powerdomain has changed |
|
41571 | 697 |
from e.g. "+\<sharp>" to "\<union>\<sharp>", for consistency with set |
698 |
syntax. INCOMPATIBILITY. |
|
699 |
||
700 |
* The constant "UU" has been renamed to "bottom". The syntax "UU" is |
|
41429
cf5f025bc3c7
renamed constant 'UU' to 'bottom', keeping 'UU' as alternative input syntax;
huffman
parents:
41414
diff
changeset
|
701 |
still supported as an input translation. |
cf5f025bc3c7
renamed constant 'UU' to 'bottom', keeping 'UU' as alternative input syntax;
huffman
parents:
41414
diff
changeset
|
702 |
|
40621 | 703 |
* Renamed some theorems (the original names are also still available). |
41571 | 704 |
|
40621 | 705 |
expand_fun_below ~> fun_below_iff |
706 |
below_fun_ext ~> fun_belowI |
|
707 |
expand_cfun_eq ~> cfun_eq_iff |
|
708 |
ext_cfun ~> cfun_eqI |
|
709 |
expand_cfun_below ~> cfun_below_iff |
|
710 |
below_cfun_ext ~> cfun_belowI |
|
711 |
cont2cont_Rep_CFun ~> cont2cont_APP |
|
712 |
||
713 |
* The Abs and Rep functions for various types have changed names. |
|
40948 | 714 |
Related theorem names have also changed to match. INCOMPATIBILITY. |
41571 | 715 |
|
40621 | 716 |
Rep_CFun ~> Rep_cfun |
717 |
Abs_CFun ~> Abs_cfun |
|
718 |
Rep_Sprod ~> Rep_sprod |
|
719 |
Abs_Sprod ~> Abs_sprod |
|
720 |
Rep_Ssum ~> Rep_ssum |
|
721 |
Abs_Ssum ~> Abs_ssum |
|
722 |
||
723 |
* Lemmas with names of the form *_defined_iff or *_strict_iff have |
|
41571 | 724 |
been renamed to *_bottom_iff. INCOMPATIBILITY. |
40621 | 725 |
|
726 |
* Various changes to bisimulation/coinduction with domain package: |
|
41571 | 727 |
|
728 |
- Definitions of "bisim" constants no longer mention definedness. |
|
729 |
- With mutual recursion, "bisim" predicate is now curried. |
|
40621 | 730 |
- With mutual recursion, each type gets a separate coind theorem. |
731 |
- Variable names in bisim_def and coinduct rules have changed. |
|
41571 | 732 |
|
40621 | 733 |
INCOMPATIBILITY. |
734 |
||
41571 | 735 |
* Case combinators generated by the domain package for type "foo" are |
736 |
now named "foo_case" instead of "foo_when". INCOMPATIBILITY. |
|
40621 | 737 |
|
40771 | 738 |
* Several theorems have been renamed to more accurately reflect the |
41571 | 739 |
names of constants and types involved. INCOMPATIBILITY. |
740 |
||
40771 | 741 |
thelub_const ~> lub_const |
742 |
lub_const ~> is_lub_const |
|
743 |
thelubI ~> lub_eqI |
|
744 |
is_lub_lub ~> is_lubD2 |
|
745 |
lubI ~> is_lub_lub |
|
746 |
unique_lub ~> is_lub_unique |
|
747 |
is_ub_lub ~> is_lub_rangeD1 |
|
748 |
lub_bin_chain ~> is_lub_bin_chain |
|
41030
ff7d177128ef
rename lub_fun -> is_lub_fun, thelub_fun -> lub_fun
huffman
parents:
40965
diff
changeset
|
749 |
lub_fun ~> is_lub_fun |
ff7d177128ef
rename lub_fun -> is_lub_fun, thelub_fun -> lub_fun
huffman
parents:
40965
diff
changeset
|
750 |
thelub_fun ~> lub_fun |
41031 | 751 |
thelub_cfun ~> lub_cfun |
40771 | 752 |
thelub_Pair ~> lub_Pair |
753 |
lub_cprod ~> is_lub_prod |
|
754 |
thelub_cprod ~> lub_prod |
|
755 |
minimal_cprod ~> minimal_prod |
|
756 |
inst_cprod_pcpo ~> inst_prod_pcpo |
|
41430
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
757 |
UU_I ~> bottomI |
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
758 |
compact_UU ~> compact_bottom |
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
759 |
deflation_UU ~> deflation_bottom |
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
760 |
finite_deflation_UU ~> finite_deflation_bottom |
40771 | 761 |
|
41571 | 762 |
* Many legacy theorem names have been discontinued. INCOMPATIBILITY. |
763 |
||
40621 | 764 |
sq_ord_less_eq_trans ~> below_eq_trans |
765 |
sq_ord_eq_less_trans ~> eq_below_trans |
|
766 |
refl_less ~> below_refl |
|
767 |
trans_less ~> below_trans |
|
768 |
antisym_less ~> below_antisym |
|
769 |
antisym_less_inverse ~> po_eq_conv [THEN iffD1] |
|
770 |
box_less ~> box_below |
|
771 |
rev_trans_less ~> rev_below_trans |
|
772 |
not_less2not_eq ~> not_below2not_eq |
|
773 |
less_UU_iff ~> below_UU_iff |
|
774 |
flat_less_iff ~> flat_below_iff |
|
775 |
adm_less ~> adm_below |
|
776 |
adm_not_less ~> adm_not_below |
|
777 |
adm_compact_not_less ~> adm_compact_not_below |
|
778 |
less_fun_def ~> below_fun_def |
|
779 |
expand_fun_less ~> fun_below_iff |
|
780 |
less_fun_ext ~> fun_belowI |
|
781 |
less_discr_def ~> below_discr_def |
|
782 |
discr_less_eq ~> discr_below_eq |
|
783 |
less_unit_def ~> below_unit_def |
|
784 |
less_cprod_def ~> below_prod_def |
|
785 |
prod_lessI ~> prod_belowI |
|
786 |
Pair_less_iff ~> Pair_below_iff |
|
787 |
fst_less_iff ~> fst_below_iff |
|
788 |
snd_less_iff ~> snd_below_iff |
|
789 |
expand_cfun_less ~> cfun_below_iff |
|
790 |
less_cfun_ext ~> cfun_belowI |
|
791 |
injection_less ~> injection_below |
|
792 |
less_up_def ~> below_up_def |
|
793 |
not_Iup_less ~> not_Iup_below |
|
794 |
Iup_less ~> Iup_below |
|
795 |
up_less ~> up_below |
|
796 |
Def_inject_less_eq ~> Def_below_Def |
|
797 |
Def_less_is_eq ~> Def_below_iff |
|
798 |
spair_less_iff ~> spair_below_iff |
|
799 |
less_sprod ~> below_sprod |
|
800 |
spair_less ~> spair_below |
|
801 |
sfst_less_iff ~> sfst_below_iff |
|
802 |
ssnd_less_iff ~> ssnd_below_iff |
|
803 |
fix_least_less ~> fix_least_below |
|
804 |
dist_less_one ~> dist_below_one |
|
805 |
less_ONE ~> below_ONE |
|
806 |
ONE_less_iff ~> ONE_below_iff |
|
807 |
less_sinlD ~> below_sinlD |
|
808 |
less_sinrD ~> below_sinrD |
|
809 |
||
810 |
||
40948 | 811 |
*** FOL and ZF *** |
38522 | 812 |
|
41310 | 813 |
* All constant names are now qualified internally and use proper |
814 |
identifiers, e.g. "IFOL.eq" instead of "op =". INCOMPATIBILITY. |
|
815 |
||
38522 | 816 |
|
37868
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
817 |
*** ML *** |
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
818 |
|
41594 | 819 |
* Antiquotation @{assert} inlines a function bool -> unit that raises |
820 |
Fail if the argument is false. Due to inlining the source position of |
|
821 |
failed assertions is included in the error output. |
|
822 |
||
823 |
* Discontinued antiquotation @{theory_ref}, which is obsolete since ML |
|
824 |
text is in practice always evaluated with a stable theory checkpoint. |
|
825 |
Minor INCOMPATIBILITY, use (Theory.check_thy @{theory}) instead. |
|
826 |
||
827 |
* Antiquotation @{theory A} refers to theory A from the ancestry of |
|
828 |
the current context, not any accidental theory loader state as before. |
|
829 |
Potential INCOMPATIBILITY, subtle change in semantics. |
|
41228
e1fce873b814
renamed structure MetaSimplifier to raw_Simplifer, to emphasize its meaning;
wenzelm
parents:
41079
diff
changeset
|
830 |
|
40956 | 831 |
* Syntax.pretty_priority (default 0) configures the required priority |
832 |
of pretty-printed output and thus affects insertion of parentheses. |
|
833 |
||
40959 | 834 |
* Syntax.default_root (default "any") configures the inner syntax |
835 |
category (nonterminal symbol) for parsing of terms. |
|
836 |
||
40722
441260986b63
make two copies (!) of Library.UnequalLengths coincide with ListPair.UnequalLengths;
wenzelm
parents:
40712
diff
changeset
|
837 |
* Former exception Library.UnequalLengths now coincides with |
441260986b63
make two copies (!) of Library.UnequalLengths coincide with ListPair.UnequalLengths;
wenzelm
parents:
40712
diff
changeset
|
838 |
ListPair.UnequalLengths. |
441260986b63
make two copies (!) of Library.UnequalLengths coincide with ListPair.UnequalLengths;
wenzelm
parents:
40712
diff
changeset
|
839 |
|
41594 | 840 |
* Renamed structure MetaSimplifier to Raw_Simplifier. Note that the |
841 |
main functionality is provided by structure Simplifier. |
|
842 |
||
40627
becf5d5187cc
renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents:
40624
diff
changeset
|
843 |
* Renamed raw "explode" function to "raw_explode" to emphasize its |
becf5d5187cc
renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents:
40624
diff
changeset
|
844 |
meaning. Note that internally to Isabelle, Symbol.explode is used in |
becf5d5187cc
renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents:
40624
diff
changeset
|
845 |
almost all situations. |
becf5d5187cc
renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents:
40624
diff
changeset
|
846 |
|
40318
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
847 |
* Discontinued obsolete function sys_error and exception SYS_ERROR. |
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
848 |
See implementation manual for further details on exceptions in |
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
849 |
Isabelle/ML. |
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
850 |
|
39616
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents:
39557
diff
changeset
|
851 |
* Renamed setmp_noncritical to Unsynchronized.setmp to emphasize its |
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents:
39557
diff
changeset
|
852 |
meaning. |
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents:
39557
diff
changeset
|
853 |
|
39557
fe5722fce758
renamed structure PureThy to Pure_Thy and moved most content to Global_Theory, to emphasize that this is global-only;
wenzelm
parents:
39513
diff
changeset
|
854 |
* Renamed structure PureThy to Pure_Thy and moved most of its |
fe5722fce758
renamed structure PureThy to Pure_Thy and moved most content to Global_Theory, to emphasize that this is global-only;
wenzelm
parents:
39513
diff
changeset
|
855 |
operations to structure Global_Theory, to emphasize that this is |
fe5722fce758
renamed structure PureThy to Pure_Thy and moved most content to Global_Theory, to emphasize that this is global-only;
wenzelm
parents:
39513
diff
changeset
|
856 |
rarely-used global-only stuff. |
fe5722fce758
renamed structure PureThy to Pure_Thy and moved most content to Global_Theory, to emphasize that this is global-only;
wenzelm
parents:
39513
diff
changeset
|
857 |
|
39513
fce2202892c4
discontinued Output.debug, which belongs to early PGIP experiments (b6788dbd2ef9) and causes just too many problems (like spamming the message channel if it is used by more than one module);
wenzelm
parents:
39308
diff
changeset
|
858 |
* Discontinued Output.debug. Minor INCOMPATIBILITY, use plain writeln |
fce2202892c4
discontinued Output.debug, which belongs to early PGIP experiments (b6788dbd2ef9) and causes just too many problems (like spamming the message channel if it is used by more than one module);
wenzelm
parents:
39308
diff
changeset
|
859 |
instead (or tracing for high-volume output). |
fce2202892c4
discontinued Output.debug, which belongs to early PGIP experiments (b6788dbd2ef9) and causes just too many problems (like spamming the message channel if it is used by more than one module);
wenzelm
parents:
39308
diff
changeset
|
860 |
|
38980
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
861 |
* Configuration option show_question_marks only affects regular pretty |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
862 |
printing of types and terms, not raw Term.string_of_vname. |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
863 |
|
39164
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
864 |
* ML_Context.thm and ML_Context.thms are no longer pervasive. Rare |
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
865 |
INCOMPATIBILITY, superseded by static antiquotations @{thm} and |
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
866 |
@{thms} for most purposes. |
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
867 |
|
41594 | 868 |
* ML structure Unsynchronized is never opened, not even in Isar |
38980
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
869 |
interaction mode as before. Old Unsynchronized.set etc. have been |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
870 |
discontinued -- use plain := instead. This should be *rare* anyway, |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
871 |
since modern tools always work via official context data, notably |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
872 |
configuration options. |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
873 |
|
39239 | 874 |
* Parallel and asynchronous execution requires special care concerning |
875 |
interrupts. Structure Exn provides some convenience functions that |
|
876 |
avoid working directly with raw Interrupt. User code must not absorb |
|
877 |
interrupts -- intermediate handling (for cleanup etc.) needs to be |
|
878 |
followed by re-raising of the original exception. Another common |
|
879 |
source of mistakes are "handle _" patterns, which make the meaning of |
|
880 |
the program subject to physical effects of the environment. |
|
881 |
||
37868
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
882 |
|
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
883 |
|
37144 | 884 |
New in Isabelle2009-2 (June 2010) |
885 |
--------------------------------- |
|
33993 | 886 |
|
35260 | 887 |
*** General *** |
888 |
||
35436 | 889 |
* Authentic syntax for *all* logical entities (type classes, type |
890 |
constructors, term constants): provides simple and robust |
|
891 |
correspondence between formal entities and concrete syntax. Within |
|
892 |
the parse tree / AST representations, "constants" are decorated by |
|
893 |
their category (class, type, const) and spelled out explicitly with |
|
894 |
their full internal name. |
|
895 |
||
896 |
Substantial INCOMPATIBILITY concerning low-level syntax declarations |
|
897 |
and translations (translation rules and translation functions in ML). |
|
898 |
Some hints on upgrading: |
|
35260 | 899 |
|
900 |
- Many existing uses of 'syntax' and 'translations' can be replaced |
|
35436 | 901 |
by more modern 'type_notation', 'notation' and 'abbreviation', |
902 |
which are independent of this issue. |
|
35260 | 903 |
|
904 |
- 'translations' require markup within the AST; the term syntax |
|
905 |
provides the following special forms: |
|
906 |
||
907 |
CONST c -- produces syntax version of constant c from context |
|
35261 | 908 |
XCONST c -- literally c, checked as constant from context |
909 |
c -- literally c, if declared by 'syntax' |
|
910 |
||
911 |
Plain identifiers are treated as AST variables -- occasionally the |
|
912 |
system indicates accidental variables via the error "rhs contains |
|
913 |
extra variables". |
|
35260 | 914 |
|
35436 | 915 |
Type classes and type constructors are marked according to their |
916 |
concrete syntax. Some old translations rules need to be written |
|
917 |
for the "type" category, using type constructor application |
|
918 |
instead of pseudo-term application of the default category |
|
919 |
"logic". |
|
920 |
||
35260 | 921 |
- 'parse_translation' etc. in ML may use the following |
922 |
antiquotations: |
|
923 |
||
35436 | 924 |
@{class_syntax c} -- type class c within parse tree / AST |
925 |
@{term_syntax c} -- type constructor c within parse tree / AST |
|
35260 | 926 |
@{const_syntax c} -- ML version of "CONST c" above |
927 |
@{syntax_const c} -- literally c (checked wrt. 'syntax' declarations) |
|
928 |
||
35436 | 929 |
- Literal types within 'typed_print_translations', i.e. those *not* |
930 |
represented as pseudo-terms are represented verbatim. Use @{class |
|
931 |
c} or @{type_name c} here instead of the above syntax |
|
932 |
antiquotations. |
|
933 |
||
35260 | 934 |
Note that old non-authentic syntax was based on unqualified base |
35436 | 935 |
names, so all of the above "constant" names would coincide. Recall |
936 |
that 'print_syntax' and ML_command "set Syntax.trace_ast" help to |
|
937 |
diagnose syntax problems. |
|
35260 | 938 |
|
35351
7425aece4ee3
allow general mixfix syntax for type constructors;
wenzelm
parents:
35306
diff
changeset
|
939 |
* Type constructors admit general mixfix syntax, not just infix. |
7425aece4ee3
allow general mixfix syntax for type constructors;
wenzelm
parents:
35306
diff
changeset
|
940 |
|
36508
03d2a2d0ee4a
allow concrete syntax for local entities within a proof body, either via regular mixfix annotations to 'fix' etc. or the separate 'write' command;
wenzelm
parents:
36461
diff
changeset
|
941 |
* Concrete syntax may be attached to local entities without a proof |
03d2a2d0ee4a
allow concrete syntax for local entities within a proof body, either via regular mixfix annotations to 'fix' etc. or the separate 'write' command;
wenzelm
parents:
36461
diff
changeset
|
942 |
body, too. This works via regular mixfix annotations for 'fix', |
03d2a2d0ee4a
allow concrete syntax for local entities within a proof body, either via regular mixfix annotations to 'fix' etc. or the separate 'write' command;
wenzelm
parents:
36461
diff
changeset
|
943 |
'def', 'obtain' etc. or via the explicit 'write' command, which is |
03d2a2d0ee4a
allow concrete syntax for local entities within a proof body, either via regular mixfix annotations to 'fix' etc. or the separate 'write' command;
wenzelm
parents:
36461
diff
changeset
|
944 |
similar to the 'notation' command in theory specifications. |
03d2a2d0ee4a
allow concrete syntax for local entities within a proof body, either via regular mixfix annotations to 'fix' etc. or the separate 'write' command;
wenzelm
parents:
36461
diff
changeset
|
945 |
|
37351 | 946 |
* Discontinued unnamed infix syntax (legacy feature for many years) -- |
947 |
need to specify constant name and syntax separately. Internal ML |
|
948 |
datatype constructors have been renamed from InfixName to Infix etc. |
|
949 |
Minor INCOMPATIBILITY. |
|
950 |
||
951 |
* Schematic theorem statements need to be explicitly markup as such, |
|
952 |
via commands 'schematic_lemma', 'schematic_theorem', |
|
953 |
'schematic_corollary'. Thus the relevance of the proof is made |
|
954 |
syntactically clear, which impacts performance in a parallel or |
|
955 |
asynchronous interactive environment. Minor INCOMPATIBILITY. |
|
956 |
||
35613 | 957 |
* Use of cumulative prems via "!" in some proof methods has been |
37351 | 958 |
discontinued (old legacy feature). |
35613 | 959 |
|
35979
12bb31230550
replaced references 'trace_simp' and 'debug_simp' by configuration options stored in the context
boehmes
parents:
35845
diff
changeset
|
960 |
* References 'trace_simp' and 'debug_simp' have been replaced by |
36857 | 961 |
configuration options stored in the context. Enabling tracing (the |
962 |
case of debugging is similar) in proofs works via |
|
963 |
||
964 |
using [[trace_simp = true]] |
|
965 |
||
966 |
Tracing is then active for all invocations of the simplifier in |
|
967 |
subsequent goal refinement steps. Tracing may also still be enabled or |
|
40780
1cabd6f4a718
recovered Isabelle2009-2 NEWS -- published part is read-only;
wenzelm
parents:
40771
diff
changeset
|
968 |
disabled via the ProofGeneral settings menu. |
35979
12bb31230550
replaced references 'trace_simp' and 'debug_simp' by configuration options stored in the context
boehmes
parents:
35845
diff
changeset
|
969 |
|
36177
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
970 |
* Separate commands 'hide_class', 'hide_type', 'hide_const', |
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
971 |
'hide_fact' replace the former 'hide' KIND command. Minor |
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
972 |
INCOMPATIBILITY. |
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
973 |
|
37298
1f3ca94ccb84
improved parallelism of proof term normalization;
wenzelm
parents:
37273
diff
changeset
|
974 |
* Improved parallelism of proof term normalization: usedir -p2 -q0 is |
1f3ca94ccb84
improved parallelism of proof term normalization;
wenzelm
parents:
37273
diff
changeset
|
975 |
more efficient than combinations with -q1 or -q2. |
1f3ca94ccb84
improved parallelism of proof term normalization;
wenzelm
parents:
37273
diff
changeset
|
976 |
|
35260 | 977 |
|
34170
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
978 |
*** Pure *** |
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
979 |
|
37351 | 980 |
* Proofterms record type-class reasoning explicitly, using the |
981 |
"unconstrain" operation internally. This eliminates all sort |
|
982 |
constraints from a theorem and proof, introducing explicit |
|
983 |
OFCLASS-premises. On the proof term level, this operation is |
|
984 |
automatically applied at theorem boundaries, such that closed proofs |
|
985 |
are always free of sort constraints. INCOMPATIBILITY for tools that |
|
986 |
inspect proof terms. |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
36096
diff
changeset
|
987 |
|
35765
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
988 |
* Local theory specifications may depend on extra type variables that |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
989 |
are not present in the result type -- arguments TYPE('a) :: 'a itself |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
990 |
are added internally. For example: |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
991 |
|
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
992 |
definition unitary :: bool where "unitary = (ALL (x::'a) y. x = y)" |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
993 |
|
37351 | 994 |
* Predicates of locales introduced by classes carry a mandatory |
995 |
"class" prefix. INCOMPATIBILITY. |
|
996 |
||
997 |
* Vacuous class specifications observe default sort. INCOMPATIBILITY. |
|
998 |
||
999 |
* Old 'axclass' command has been discontinued. INCOMPATIBILITY, use |
|
1000 |
'class' instead. |
|
1001 |
||
1002 |
* Command 'code_reflect' allows to incorporate generated ML code into |
|
1003 |
runtime environment; replaces immature code_datatype antiquotation. |
|
1004 |
INCOMPATIBILITY. |
|
1005 |
||
1006 |
* Code generator: simple concept for abstract datatypes obeying |
|
1007 |
invariants. |
|
1008 |
||
36857 | 1009 |
* Code generator: details of internal data cache have no impact on the |
1010 |
user space functionality any longer. |
|
1011 |
||
37351 | 1012 |
* Methods "unfold_locales" and "intro_locales" ignore non-locale |
1013 |
subgoals. This is more appropriate for interpretations with 'where'. |
|
36857 | 1014 |
INCOMPATIBILITY. |
34170
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
1015 |
|
36356
5ab0f8859f9f
command 'example_proof' opens an empty proof body;
wenzelm
parents:
36348
diff
changeset
|
1016 |
* Command 'example_proof' opens an empty proof body. This allows to |
5ab0f8859f9f
command 'example_proof' opens an empty proof body;
wenzelm
parents:
36348
diff
changeset
|
1017 |
experiment with Isar, without producing any persistent result. |
5ab0f8859f9f
command 'example_proof' opens an empty proof body;
wenzelm
parents:
36348
diff
changeset
|
1018 |
|
35413 | 1019 |
* Commands 'type_notation' and 'no_type_notation' declare type syntax |
1020 |
within a local theory context, with explicit checking of the |
|
1021 |
constructors involved (in contrast to the raw 'syntax' versions). |
|
1022 |
||
36178
0e5c133b48b6
keep localized 'types' as regular non-old-style version -- 'type_abbrev' as 'type' just causes too many problems, e.g. clash with "type" in translations or "type:" argument syntax;
wenzelm
parents:
36177
diff
changeset
|
1023 |
* Commands 'types' and 'typedecl' now work within a local theory |
0e5c133b48b6
keep localized 'types' as regular non-old-style version -- 'type_abbrev' as 'type' just causes too many problems, e.g. clash with "type" in translations or "type:" argument syntax;
wenzelm
parents:
36177
diff
changeset
|
1024 |
context -- without introducing dependencies on parameters or |
0e5c133b48b6
keep localized 'types' as regular non-old-style version -- 'type_abbrev' as 'type' just causes too many problems, e.g. clash with "type" in translations or "type:" argument syntax;
wenzelm
parents:
36177
diff
changeset
|
1025 |
assumptions, which is not possible in Isabelle/Pure. |
35681 | 1026 |
|
36857 | 1027 |
* Command 'defaultsort' has been renamed to 'default_sort', it works |
1028 |
within a local theory context. Minor INCOMPATIBILITY. |
|
36454
f2b5bcc61a8c
command 'defaultsort' is renamed to 'default_sort', it works within a local theory context;
wenzelm
parents:
36446
diff
changeset
|
1029 |
|
34170
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
1030 |
|
33993 | 1031 |
*** HOL *** |
1032 |
||
37351 | 1033 |
* Command 'typedef' now works within a local theory context -- without |
1034 |
introducing dependencies on parameters or assumptions, which is not |
|
1035 |
possible in Isabelle/Pure/HOL. Note that the logical environment may |
|
1036 |
contain multiple interpretations of local typedefs (with different |
|
1037 |
non-emptiness proofs), even in a global theory context. |
|
1038 |
||
1039 |
* New package for quotient types. Commands 'quotient_type' and |
|
1040 |
'quotient_definition' may be used for defining types and constants by |
|
1041 |
quotient constructions. An example is the type of integers created by |
|
1042 |
quotienting pairs of natural numbers: |
|
37380 | 1043 |
|
37351 | 1044 |
fun |
37380 | 1045 |
intrel :: "(nat * nat) => (nat * nat) => bool" |
37351 | 1046 |
where |
1047 |
"intrel (x, y) (u, v) = (x + v = u + y)" |
|
1048 |
||
37380 | 1049 |
quotient_type int = "nat * nat" / intrel |
37351 | 1050 |
by (auto simp add: equivp_def expand_fun_eq) |
37380 | 1051 |
|
37351 | 1052 |
quotient_definition |
1053 |
"0::int" is "(0::nat, 0::nat)" |
|
1054 |
||
1055 |
The method "lifting" can be used to lift of theorems from the |
|
1056 |
underlying "raw" type to the quotient type. The example |
|
1057 |
src/HOL/Quotient_Examples/FSet.thy includes such a quotient |
|
1058 |
construction and provides a reasoning infrastructure for finite sets. |
|
1059 |
||
1060 |
* Renamed Library/Quotient.thy to Library/Quotient_Type.thy to avoid |
|
1061 |
clash with new theory Quotient in Main HOL. |
|
1062 |
||
1063 |
* Moved the SMT binding into the main HOL session, eliminating |
|
1064 |
separate HOL-SMT session. |
|
1065 |
||
37020 | 1066 |
* List membership infix mem operation is only an input abbreviation. |
1067 |
INCOMPATIBILITY. |
|
1068 |
||
37144 | 1069 |
* Theory Library/Word.thy has been removed. Use library Word/Word.thy |
1070 |
for future developements; former Library/Word.thy is still present in |
|
1071 |
the AFP entry RSAPPS. |
|
36963
9a017146675f
dropped old Library/Word.thy and toy example ex/Adder.thy
haftmann
parents:
36953
diff
changeset
|
1072 |
|
36857 | 1073 |
* Theorem Int.int_induct renamed to Int.int_of_nat_induct and is no |
1074 |
longer shadowed. INCOMPATIBILITY. |
|
36808
cbeb3484fa07
theorem Presburger.int_induct has been renamed to Int.int_bidirectional_induct
haftmann
parents:
36714
diff
changeset
|
1075 |
|
36836
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1076 |
* Dropped theorem duplicate comp_arith; use semiring_norm instead. |
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1077 |
INCOMPATIBILITY. |
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1078 |
|
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1079 |
* Dropped theorem RealPow.real_sq_order; use power2_le_imp_le instead. |
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1080 |
INCOMPATIBILITY. |
36714 | 1081 |
|
36857 | 1082 |
* Dropped normalizing_semiring etc; use the facts in semiring classes |
1083 |
instead. INCOMPATIBILITY. |
|
1084 |
||
36979
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1085 |
* Dropped several real-specific versions of lemmas about floor and |
37351 | 1086 |
ceiling; use the generic lemmas from theory "Archimedean_Field" |
1087 |
instead. INCOMPATIBILITY. |
|
36979
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1088 |
|
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1089 |
floor_number_of_eq ~> floor_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1090 |
le_floor_eq_number_of ~> number_of_le_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1091 |
le_floor_eq_zero ~> zero_le_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1092 |
le_floor_eq_one ~> one_le_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1093 |
floor_less_eq_number_of ~> floor_less_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1094 |
floor_less_eq_zero ~> floor_less_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1095 |
floor_less_eq_one ~> floor_less_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1096 |
less_floor_eq_number_of ~> number_of_less_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1097 |
less_floor_eq_zero ~> zero_less_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1098 |
less_floor_eq_one ~> one_less_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1099 |
floor_le_eq_number_of ~> floor_le_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1100 |
floor_le_eq_zero ~> floor_le_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1101 |
floor_le_eq_one ~> floor_le_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1102 |
floor_subtract_number_of ~> floor_diff_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1103 |
floor_subtract_one ~> floor_diff_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1104 |
ceiling_number_of_eq ~> ceiling_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1105 |
ceiling_le_eq_number_of ~> ceiling_le_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1106 |
ceiling_le_zero_eq ~> ceiling_le_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1107 |
ceiling_le_eq_one ~> ceiling_le_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1108 |
less_ceiling_eq_number_of ~> number_of_less_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1109 |
less_ceiling_eq_zero ~> zero_less_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1110 |
less_ceiling_eq_one ~> one_less_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1111 |
ceiling_less_eq_number_of ~> ceiling_less_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1112 |
ceiling_less_eq_zero ~> ceiling_less_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1113 |
ceiling_less_eq_one ~> ceiling_less_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1114 |
le_ceiling_eq_number_of ~> number_of_le_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1115 |
le_ceiling_eq_zero ~> zero_le_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1116 |
le_ceiling_eq_one ~> one_le_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1117 |
ceiling_subtract_number_of ~> ceiling_diff_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1118 |
ceiling_subtract_one ~> ceiling_diff_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1119 |
|
37144 | 1120 |
* Theory "Finite_Set": various folding_XXX locales facilitate the |
36857 | 1121 |
application of the various fold combinators on finite sets. |
1122 |
||
1123 |
* Library theory "RBT" renamed to "RBT_Impl"; new library theory "RBT" |
|
1124 |
provides abstract red-black tree type which is backed by "RBT_Impl" as |
|
1125 |
implementation. INCOMPATIBILTY. |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
36096
diff
changeset
|
1126 |
|
36830 | 1127 |
* Theory Library/Coinductive_List has been removed -- superseded by |
35763
765f8adf10f9
removed obsolete HOL/Library/Coinductive_List.thy, superceded by thys/Coinductive/Coinductive_List.thy in AFP/f2f5727b77d0;
wenzelm
parents:
35745
diff
changeset
|
1128 |
AFP/thys/Coinductive. |
765f8adf10f9
removed obsolete HOL/Library/Coinductive_List.thy, superceded by thys/Coinductive/Coinductive_List.thy in AFP/f2f5727b77d0;
wenzelm
parents:
35745
diff
changeset
|
1129 |
|
36829 | 1130 |
* Theory PReal, including the type "preal" and related operations, has |
1131 |
been removed. INCOMPATIBILITY. |
|
1132 |
||
37380 | 1133 |
* Real: new development using Cauchy Sequences. |
1134 |
||
37351 | 1135 |
* Split off theory "Big_Operators" containing setsum, setprod, |
1136 |
Inf_fin, Sup_fin, Min, Max from theory Finite_Set. INCOMPATIBILITY. |
|
36857 | 1137 |
|
1138 |
* Theory "Rational" renamed to "Rat", for consistency with "Nat", |
|
1139 |
"Int" etc. INCOMPATIBILITY. |
|
1140 |
||
37351 | 1141 |
* Constant Rat.normalize needs to be qualified. INCOMPATIBILITY. |
37143 | 1142 |
|
36857 | 1143 |
* New set of rules "ac_simps" provides combined assoc / commute |
1144 |
rewrites for all interpretations of the appropriate generic locales. |
|
1145 |
||
1146 |
* Renamed theory "OrderedGroup" to "Groups" and split theory |
|
1147 |
"Ring_and_Field" into theories "Rings" and "Fields"; for more |
|
1148 |
appropriate and more consistent names suitable for name prefixes |
|
1149 |
within the HOL theories. INCOMPATIBILITY. |
|
35050
9f841f20dca6
renamed OrderedGroup to Groups; split theory Ring_and_Field into Rings Fields
haftmann
parents:
35042
diff
changeset
|
1150 |
|
35084 | 1151 |
* Some generic constants have been put to appropriate theories: |
36857 | 1152 |
- less_eq, less: Orderings |
1153 |
- zero, one, plus, minus, uminus, times, abs, sgn: Groups |
|
1154 |
- inverse, divide: Rings |
|
35084 | 1155 |
INCOMPATIBILITY. |
1156 |
||
36857 | 1157 |
* More consistent naming of type classes involving orderings (and |
1158 |
lattices): |
|
35027
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1159 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1160 |
lower_semilattice ~> semilattice_inf |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1161 |
upper_semilattice ~> semilattice_sup |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1162 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1163 |
dense_linear_order ~> dense_linorder |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1164 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1165 |
pordered_ab_group_add ~> ordered_ab_group_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1166 |
pordered_ab_group_add_abs ~> ordered_ab_group_add_abs |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1167 |
pordered_ab_semigroup_add ~> ordered_ab_semigroup_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1168 |
pordered_ab_semigroup_add_imp_le ~> ordered_ab_semigroup_add_imp_le |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1169 |
pordered_cancel_ab_semigroup_add ~> ordered_cancel_ab_semigroup_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1170 |
pordered_cancel_comm_semiring ~> ordered_cancel_comm_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1171 |
pordered_cancel_semiring ~> ordered_cancel_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1172 |
pordered_comm_monoid_add ~> ordered_comm_monoid_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1173 |
pordered_comm_ring ~> ordered_comm_ring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1174 |
pordered_comm_semiring ~> ordered_comm_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1175 |
pordered_ring ~> ordered_ring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1176 |
pordered_ring_abs ~> ordered_ring_abs |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1177 |
pordered_semiring ~> ordered_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1178 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1179 |
ordered_ab_group_add ~> linordered_ab_group_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1180 |
ordered_ab_semigroup_add ~> linordered_ab_semigroup_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1181 |
ordered_cancel_ab_semigroup_add ~> linordered_cancel_ab_semigroup_add |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1182 |
ordered_comm_semiring_strict ~> linordered_comm_semiring_strict |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1183 |
ordered_field ~> linordered_field |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1184 |
ordered_field_no_lb ~> linordered_field_no_lb |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1185 |
ordered_field_no_ub ~> linordered_field_no_ub |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1186 |
ordered_field_dense_linear_order ~> dense_linordered_field |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1187 |
ordered_idom ~> linordered_idom |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1188 |
ordered_ring ~> linordered_ring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1189 |
ordered_ring_le_cancel_factor ~> linordered_ring_le_cancel_factor |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1190 |
ordered_ring_less_cancel_factor ~> linordered_ring_less_cancel_factor |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1191 |
ordered_ring_strict ~> linordered_ring_strict |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1192 |
ordered_semidom ~> linordered_semidom |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1193 |
ordered_semiring ~> linordered_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1194 |
ordered_semiring_1 ~> linordered_semiring_1 |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1195 |
ordered_semiring_1_strict ~> linordered_semiring_1_strict |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1196 |
ordered_semiring_strict ~> linordered_semiring_strict |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1197 |
|
36857 | 1198 |
The following slightly odd type classes have been moved to a |
37351 | 1199 |
separate theory Library/Lattice_Algebras: |
35032
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1200 |
|
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1201 |
lordered_ab_group_add ~> lattice_ab_group_add |
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1202 |
lordered_ab_group_add_abs ~> lattice_ab_group_add_abs |
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1203 |
lordered_ab_group_add_meet ~> semilattice_inf_ab_group_add |
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1204 |
lordered_ab_group_add_join ~> semilattice_sup_ab_group_add |
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1205 |
lordered_ring ~> lattice_ring |
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1206 |
|
35027
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1207 |
INCOMPATIBILITY. |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1208 |
|
36416 | 1209 |
* Refined field classes: |
36857 | 1210 |
- classes division_ring_inverse_zero, field_inverse_zero, |
1211 |
linordered_field_inverse_zero include rule inverse 0 = 0 -- |
|
1212 |
subsumes former division_by_zero class; |
|
1213 |
- numerous lemmas have been ported from field to division_ring. |
|
1214 |
INCOMPATIBILITY. |
|
36416 | 1215 |
|
1216 |
* Refined algebra theorem collections: |
|
36857 | 1217 |
- dropped theorem group group_simps, use algebra_simps instead; |
1218 |
- dropped theorem group ring_simps, use field_simps instead; |
|
1219 |
- proper theorem collection field_simps subsumes former theorem |
|
1220 |
groups field_eq_simps and field_simps; |
|
1221 |
- dropped lemma eq_minus_self_iff which is a duplicate for |
|
1222 |
equal_neg_zero. |
|
1223 |
INCOMPATIBILITY. |
|
35009 | 1224 |
|
1225 |
* Theory Finite_Set and List: some lemmas have been generalized from |
|
34076
e3daf3c07381
Subgoal.FOCUS (and variants): resulting goal state is normalized as usual for resolution;
wenzelm
parents:
34062
diff
changeset
|
1226 |
sets to lattices: |
e3daf3c07381
Subgoal.FOCUS (and variants): resulting goal state is normalized as usual for resolution;
wenzelm
parents:
34062
diff
changeset
|
1227 |
|
34007
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1228 |
fun_left_comm_idem_inter ~> fun_left_comm_idem_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1229 |
fun_left_comm_idem_union ~> fun_left_comm_idem_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1230 |
inter_Inter_fold_inter ~> inf_Inf_fold_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1231 |
union_Union_fold_union ~> sup_Sup_fold_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1232 |
Inter_fold_inter ~> Inf_fold_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1233 |
Union_fold_union ~> Sup_fold_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1234 |
inter_INTER_fold_inter ~> inf_INFI_fold_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1235 |
union_UNION_fold_union ~> sup_SUPR_fold_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1236 |
INTER_fold_inter ~> INFI_fold_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1237 |
UNION_fold_union ~> SUPR_fold_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1238 |
|
37351 | 1239 |
* Theory "Complete_Lattice": lemmas top_def and bot_def have been |
36416 | 1240 |
replaced by the more convenient lemmas Inf_empty and Sup_empty. |
1241 |
Dropped lemmas Inf_insert_simp and Sup_insert_simp, which are subsumed |
|
1242 |
by Inf_insert and Sup_insert. Lemmas Inf_UNIV and Sup_UNIV replace |
|
1243 |
former Inf_Univ and Sup_Univ. Lemmas inf_top_right and sup_bot_right |
|
1244 |
subsume inf_top and sup_bot respectively. INCOMPATIBILITY. |
|
1245 |
||
36857 | 1246 |
* Reorganized theory Multiset: swapped notation of pointwise and |
1247 |
multiset order: |
|
37351 | 1248 |
|
36857 | 1249 |
- pointwise ordering is instance of class order with standard syntax |
1250 |
<= and <; |
|
1251 |
- multiset ordering has syntax <=# and <#; partial order properties |
|
1252 |
are provided by means of interpretation with prefix |
|
1253 |
multiset_order; |
|
1254 |
- less duplication, less historical organization of sections, |
|
1255 |
conversion from associations lists to multisets, rudimentary code |
|
1256 |
generation; |
|
1257 |
- use insert_DiffM2 [symmetric] instead of elem_imp_eq_diff_union, |
|
1258 |
if needed. |
|
37351 | 1259 |
|
36903 | 1260 |
Renamed: |
37351 | 1261 |
|
1262 |
multiset_eq_conv_count_eq ~> multiset_ext_iff |
|
1263 |
multi_count_ext ~> multiset_ext |
|
1264 |
diff_union_inverse2 ~> diff_union_cancelR |
|
1265 |
||
36857 | 1266 |
INCOMPATIBILITY. |
36416 | 1267 |
|
36903 | 1268 |
* Theory Permutation: replaced local "remove" by List.remove1. |
1269 |
||
36416 | 1270 |
* Code generation: ML and OCaml code is decorated with signatures. |
1271 |
||
35009 | 1272 |
* Theory List: added transpose. |
1273 |
||
35810 | 1274 |
* Library/Nat_Bijection.thy is a collection of bijective functions |
1275 |
between nat and other types, which supersedes the older libraries |
|
1276 |
Library/Nat_Int_Bij.thy and HOLCF/NatIso.thy. INCOMPATIBILITY. |
|
1277 |
||
1278 |
Constants: |
|
1279 |
Nat_Int_Bij.nat2_to_nat ~> prod_encode |
|
1280 |
Nat_Int_Bij.nat_to_nat2 ~> prod_decode |
|
1281 |
Nat_Int_Bij.int_to_nat_bij ~> int_encode |
|
1282 |
Nat_Int_Bij.nat_to_int_bij ~> int_decode |
|
1283 |
Countable.pair_encode ~> prod_encode |
|
1284 |
NatIso.prod2nat ~> prod_encode |
|
1285 |
NatIso.nat2prod ~> prod_decode |
|
1286 |
NatIso.sum2nat ~> sum_encode |
|
1287 |
NatIso.nat2sum ~> sum_decode |
|
1288 |
NatIso.list2nat ~> list_encode |
|
1289 |
NatIso.nat2list ~> list_decode |
|
1290 |
NatIso.set2nat ~> set_encode |
|
1291 |
NatIso.nat2set ~> set_decode |
|
1292 |
||
1293 |
Lemmas: |
|
1294 |
Nat_Int_Bij.bij_nat_to_int_bij ~> bij_int_decode |
|
1295 |
Nat_Int_Bij.nat2_to_nat_inj ~> inj_prod_encode |
|
1296 |
Nat_Int_Bij.nat2_to_nat_surj ~> surj_prod_encode |
|
1297 |
Nat_Int_Bij.nat_to_nat2_inj ~> inj_prod_decode |
|
1298 |
Nat_Int_Bij.nat_to_nat2_surj ~> surj_prod_decode |
|
1299 |
Nat_Int_Bij.i2n_n2i_id ~> int_encode_inverse |
|
1300 |
Nat_Int_Bij.n2i_i2n_id ~> int_decode_inverse |
|
1301 |
Nat_Int_Bij.surj_nat_to_int_bij ~> surj_int_encode |
|
1302 |
Nat_Int_Bij.surj_int_to_nat_bij ~> surj_int_decode |
|
1303 |
Nat_Int_Bij.inj_nat_to_int_bij ~> inj_int_encode |
|
1304 |
Nat_Int_Bij.inj_int_to_nat_bij ~> inj_int_decode |
|
1305 |
Nat_Int_Bij.bij_nat_to_int_bij ~> bij_int_encode |
|
1306 |
Nat_Int_Bij.bij_int_to_nat_bij ~> bij_int_decode |
|
1307 |
||
36929 | 1308 |
* Sledgehammer: |
1309 |
- Renamed ATP commands: |
|
1310 |
atp_info ~> sledgehammer running_atps |
|
1311 |
atp_kill ~> sledgehammer kill_atps |
|
1312 |
atp_messages ~> sledgehammer messages |
|
1313 |
atp_minimize ~> sledgehammer minimize |
|
1314 |
print_atps ~> sledgehammer available_atps |
|
1315 |
INCOMPATIBILITY. |
|
1316 |
- Added user's manual ("isabelle doc sledgehammer"). |
|
1317 |
- Added option syntax and "sledgehammer_params" to customize |
|
1318 |
Sledgehammer's behavior. See the manual for details. |
|
1319 |
- Modified the Isar proof reconstruction code so that it produces |
|
1320 |
direct proofs rather than proofs by contradiction. (This feature |
|
1321 |
is still experimental.) |
|
1322 |
- Made Isar proof reconstruction work for SPASS, remote ATPs, and in |
|
1323 |
full-typed mode. |
|
1324 |
- Added support for TPTP syntax for SPASS via the "spass_tptp" ATP. |
|
1325 |
||
36928 | 1326 |
* Nitpick: |
1327 |
- Added and implemented "binary_ints" and "bits" options. |
|
1328 |
- Added "std" option and implemented support for nonstandard models. |
|
1329 |
- Added and implemented "finitize" option to improve the precision |
|
1330 |
of infinite datatypes based on a monotonicity analysis. |
|
1331 |
- Added support for quotient types. |
|
1332 |
- Added support for "specification" and "ax_specification" |
|
1333 |
constructs. |
|
1334 |
- Added support for local definitions (for "function" and |
|
1335 |
"termination" proofs). |
|
1336 |
- Added support for term postprocessors. |
|
1337 |
- Optimized "Multiset.multiset" and "FinFun.finfun". |
|
1338 |
- Improved efficiency of "destroy_constrs" optimization. |
|
1339 |
- Fixed soundness bugs related to "destroy_constrs" optimization and |
|
1340 |
record getters. |
|
37272 | 1341 |
- Fixed soundness bug related to higher-order constructors. |
1342 |
- Fixed soundness bug when "full_descrs" is enabled. |
|
36928 | 1343 |
- Improved precision of set constructs. |
37260
dde817e6dfb1
added "atoms" option to Nitpick (request from Karlsruhe) + wrap Refute. functions to "nitpick_util.ML"
blanchet
parents:
37158
diff
changeset
|
1344 |
- Added "atoms" option. |
36928 | 1345 |
- Added cache to speed up repeated Kodkod invocations on the same |
1346 |
problems. |
|
1347 |
- Renamed "MiniSatJNI", "zChaffJNI", "BerkMinAlloy", and |
|
1348 |
"SAT4JLight" to "MiniSat_JNI", "zChaff_JNI", "BerkMin_Alloy", and |
|
1349 |
"SAT4J_Light". INCOMPATIBILITY. |
|
1350 |
- Removed "skolemize", "uncurry", "sym_break", "flatten_prop", |
|
1351 |
"sharing_depth", and "show_skolems" options. INCOMPATIBILITY. |
|
37264
8b931fb51cc6
removed "nitpick_intro" attribute -- Nitpick noew uses Spec_Rules instead
blanchet
parents:
37260
diff
changeset
|
1352 |
- Removed "nitpick_intro" attribute. INCOMPATIBILITY. |
36928 | 1353 |
|
37361
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1354 |
* Method "induct" now takes instantiations of the form t, where t is not |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1355 |
a variable, as a shorthand for "x == t", where x is a fresh variable. |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1356 |
If this is not intended, t has to be enclosed in parentheses. |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1357 |
By default, the equalities generated by definitional instantiations |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1358 |
are pre-simplified, which may cause parameters of inductive cases |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1359 |
to disappear, or may even delete some of the inductive cases. |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1360 |
Use "induct (no_simp)" instead of "induct" to restore the old |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1361 |
behaviour. The (no_simp) option is also understood by the "cases" |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1362 |
and "nominal_induct" methods, which now perform pre-simplification, too. |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1363 |
INCOMPATIBILITY. |
250f487b3034
Documented changes in induct, cases, and nominal_induct method.
berghofe
parents:
37352
diff
changeset
|
1364 |
|
33993 | 1365 |
|
36828 | 1366 |
*** HOLCF *** |
1367 |
||
1368 |
* Variable names in lemmas generated by the domain package have |
|
1369 |
changed; the naming scheme is now consistent with the HOL datatype |
|
1370 |
package. Some proof scripts may be affected, INCOMPATIBILITY. |
|
1371 |
||
1372 |
* The domain package no longer defines the function "foo_copy" for |
|
1373 |
recursive domain "foo". The reach lemma is now stated directly in |
|
1374 |
terms of "foo_take". Lemmas and proofs that mention "foo_copy" must |
|
1375 |
be reformulated in terms of "foo_take", INCOMPATIBILITY. |
|
1376 |
||
1377 |
* Most definedness lemmas generated by the domain package (previously |
|
1378 |
of the form "x ~= UU ==> foo$x ~= UU") now have an if-and-only-if form |
|
1379 |
like "foo$x = UU <-> x = UU", which works better as a simp rule. |
|
37351 | 1380 |
Proofs that used definedness lemmas as intro rules may break, |
36828 | 1381 |
potential INCOMPATIBILITY. |
1382 |
||
1383 |
* Induction and casedist rules generated by the domain package now |
|
1384 |
declare proper case_names (one called "bottom", and one named for each |
|
1385 |
constructor). INCOMPATIBILITY. |
|
1386 |
||
1387 |
* For mutually-recursive domains, separate "reach" and "take_lemma" |
|
1388 |
rules are generated for each domain, INCOMPATIBILITY. |
|
1389 |
||
1390 |
foo_bar.reach ~> foo.reach bar.reach |
|
1391 |
foo_bar.take_lemmas ~> foo.take_lemma bar.take_lemma |
|
1392 |
||
1393 |
* Some lemmas generated by the domain package have been renamed for |
|
1394 |
consistency with the datatype package, INCOMPATIBILITY. |
|
1395 |
||
1396 |
foo.ind ~> foo.induct |
|
1397 |
foo.finite_ind ~> foo.finite_induct |
|
1398 |
foo.coind ~> foo.coinduct |
|
1399 |
foo.casedist ~> foo.exhaust |
|
1400 |
foo.exhaust ~> foo.nchotomy |
|
1401 |
||
1402 |
* For consistency with other definition packages, the fixrec package |
|
1403 |
now generates qualified theorem names, INCOMPATIBILITY. |
|
1404 |
||
1405 |
foo_simps ~> foo.simps |
|
1406 |
foo_unfold ~> foo.unfold |
|
1407 |
foo_induct ~> foo.induct |
|
1408 |
||
37087 | 1409 |
* The "fixrec_simp" attribute has been removed. The "fixrec_simp" |
1410 |
method and internal fixrec proofs now use the default simpset instead. |
|
1411 |
INCOMPATIBILITY. |
|
1412 |
||
36828 | 1413 |
* The "contlub" predicate has been removed. Proof scripts should use |
1414 |
lemma contI2 in place of monocontlub2cont, INCOMPATIBILITY. |
|
1415 |
||
1416 |
* The "admw" predicate has been removed, INCOMPATIBILITY. |
|
1417 |
||
1418 |
* The constants cpair, cfst, and csnd have been removed in favor of |
|
1419 |
Pair, fst, and snd from Isabelle/HOL, INCOMPATIBILITY. |
|
1420 |
||
1421 |
||
33993 | 1422 |
*** ML *** |
1423 |
||
37351 | 1424 |
* Antiquotations for basic formal entities: |
1425 |
||
1426 |
@{class NAME} -- type class |
|
1427 |
@{class_syntax NAME} -- syntax representation of the above |
|
1428 |
||
1429 |
@{type_name NAME} -- logical type |
|
1430 |
@{type_abbrev NAME} -- type abbreviation |
|
1431 |
@{nonterminal NAME} -- type of concrete syntactic category |
|
1432 |
@{type_syntax NAME} -- syntax representation of any of the above |
|
1433 |
||
1434 |
@{const_name NAME} -- logical constant (INCOMPATIBILITY) |
|
1435 |
@{const_abbrev NAME} -- abbreviated constant |
|
1436 |
@{const_syntax NAME} -- syntax representation of any of the above |
|
1437 |
||
1438 |
* Antiquotation @{syntax_const NAME} ensures that NAME refers to a raw |
|
1439 |
syntax constant (cf. 'syntax' command). |
|
1440 |
||
1441 |
* Antiquotation @{make_string} inlines a function to print arbitrary |
|
1442 |
values similar to the ML toplevel. The result is compiler dependent |
|
1443 |
and may fall back on "?" in certain situations. |
|
1444 |
||
1445 |
* Diagnostic commands 'ML_val' and 'ML_command' may refer to |
|
1446 |
antiquotations @{Isar.state} and @{Isar.goal}. This replaces impure |
|
1447 |
Isar.state() and Isar.goal(), which belong to the old TTY loop and do |
|
1448 |
not work with the asynchronous Isar document model. |
|
1449 |
||
1450 |
* Configuration options now admit dynamic default values, depending on |
|
1451 |
the context or even global references. |
|
1452 |
||
1453 |
* SHA1.digest digests strings according to SHA-1 (see RFC 3174). It |
|
1454 |
uses an efficient external library if available (for Poly/ML). |
|
1455 |
||
37144 | 1456 |
* Renamed some important ML structures, while keeping the old names |
1457 |
for some time as aliases within the structure Legacy: |
|
1458 |
||
1459 |
OuterKeyword ~> Keyword |
|
1460 |
OuterLex ~> Token |
|
1461 |
OuterParse ~> Parse |
|
1462 |
OuterSyntax ~> Outer_Syntax |
|
37216
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
wenzelm
parents:
37158
diff
changeset
|
1463 |
PrintMode ~> Print_Mode |
37144 | 1464 |
SpecParse ~> Parse_Spec |
37216
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
wenzelm
parents:
37158
diff
changeset
|
1465 |
ThyInfo ~> Thy_Info |
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
wenzelm
parents:
37158
diff
changeset
|
1466 |
ThyLoad ~> Thy_Load |
3165bc303f66
modernized some structure names, keeping a few legacy aliases;
wenzelm
parents:
37158
diff
changeset
|
1467 |
ThyOutput ~> Thy_Output |
37145
01aa36932739
renamed structure TypeInfer to Type_Infer, keeping the old name as legacy alias for some time;
wenzelm
parents:
37144
diff
changeset
|
1468 |
TypeInfer ~> Type_Infer |
37144 | 1469 |
|
1470 |
Note that "open Legacy" simplifies porting of sources, but forgetting |
|
1471 |
to remove it again will complicate porting again in the future. |
|
1472 |
||
1473 |
* Most operations that refer to a global context are named |
|
1474 |
accordingly, e.g. Simplifier.global_context or |
|
1475 |
ProofContext.init_global. There are some situations where a global |
|
1476 |
context actually works, but under normal circumstances one needs to |
|
1477 |
pass the proper local context through the code! |
|
1478 |
||
1479 |
* Discontinued old TheoryDataFun with its copy/init operation -- data |
|
1480 |
needs to be pure. Functor Theory_Data_PP retains the traditional |
|
1481 |
Pretty.pp argument to merge, which is absent in the standard |
|
1482 |
Theory_Data version. |
|
36429
9d6b3be996d4
monotonic sort certification: sorts are no longer minimized at the kernel boundary, only when reading input from the end-user;
wenzelm
parents:
36416
diff
changeset
|
1483 |
|
37144 | 1484 |
* Sorts.certify_sort and derived "cert" operations for types and terms |
1485 |
no longer minimize sorts. Thus certification at the boundary of the |
|
1486 |
inference kernel becomes invariant under addition of class relations, |
|
1487 |
which is an important monotonicity principle. Sorts are now minimized |
|
1488 |
in the syntax layer only, at the boundary between the end-user and the |
|
1489 |
system. Subtle INCOMPATIBILITY, may have to use Sign.minimize_sort |
|
1490 |
explicitly in rare situations. |
|
1491 |
||
35021
c839a4c670c6
renamed old-style Drule.standard to Drule.export_without_context, to emphasize that this is in no way a standard operation;
wenzelm
parents:
35009
diff
changeset
|
1492 |
* Renamed old-style Drule.standard to Drule.export_without_context, to |
c839a4c670c6
renamed old-style Drule.standard to Drule.export_without_context, to emphasize that this is in no way a standard operation;
wenzelm
parents:
35009
diff
changeset
|
1493 |
emphasize that this is in no way a standard operation. |
c839a4c670c6
renamed old-style Drule.standard to Drule.export_without_context, to emphasize that this is in no way a standard operation;
wenzelm
parents:
35009
diff
changeset
|
1494 |
INCOMPATIBILITY. |
c839a4c670c6
renamed old-style Drule.standard to Drule.export_without_context, to emphasize that this is in no way a standard operation;
wenzelm
parents:
35009
diff
changeset
|
1495 |
|
34076
e3daf3c07381
Subgoal.FOCUS (and variants): resulting goal state is normalized as usual for resolution;
wenzelm
parents:
34062
diff
changeset
|
1496 |
* Subgoal.FOCUS (and variants): resulting goal state is normalized as |
e3daf3c07381
Subgoal.FOCUS (and variants): resulting goal state is normalized as usual for resolution;
wenzelm
parents:
34062
diff
changeset
|
1497 |
usual for resolution. Rare INCOMPATIBILITY. |
e3daf3c07381
Subgoal.FOCUS (and variants): resulting goal state is normalized as usual for resolution;
wenzelm
parents:
34062
diff
changeset
|
1498 |
|
35845
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents:
35810
diff
changeset
|
1499 |
* Renamed varify/unvarify operations to varify_global/unvarify_global |
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents:
35810
diff
changeset
|
1500 |
to emphasize that these only work in a global situation (which is |
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents:
35810
diff
changeset
|
1501 |
quite rare). |
e5980f0ad025
renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents:
35810
diff
changeset
|
1502 |
|
37144 | 1503 |
* Curried take and drop in library.ML; negative length is interpreted |
1504 |
as infinity (as in chop). Subtle INCOMPATIBILITY. |
|
36961 | 1505 |
|
37351 | 1506 |
* Proof terms: type substitutions on proof constants now use canonical |
1507 |
order of type variables. INCOMPATIBILITY for tools working with proof |
|
1508 |
terms. |
|
1509 |
||
1510 |
* Raw axioms/defs may no longer carry sort constraints, and raw defs |
|
1511 |
may no longer carry premises. User-level specifications are |
|
1512 |
transformed accordingly by Thm.add_axiom/add_def. |
|
1513 |
||
33993 | 1514 |
|
34238 | 1515 |
*** System *** |
1516 |
||
1517 |
* Discontinued special HOL_USEDIR_OPTIONS for the main HOL image; |
|
1518 |
ISABELLE_USEDIR_OPTIONS applies uniformly to all sessions. Note that |
|
1519 |
proof terms are enabled unconditionally in the new HOL-Proofs image. |
|
1520 |
||
34255
2dd2547acb41
discontinued old ISABELLE and ISATOOL environment settings;
wenzelm
parents:
34238
diff
changeset
|
1521 |
* Discontinued old ISABELLE and ISATOOL environment settings (legacy |
2dd2547acb41
discontinued old ISABELLE and ISATOOL environment settings;
wenzelm
parents:
34238
diff
changeset
|
1522 |
feature since Isabelle2009). Use ISABELLE_PROCESS and ISABELLE_TOOL, |
2dd2547acb41
discontinued old ISABELLE and ISATOOL environment settings;
wenzelm
parents:
34238
diff
changeset
|
1523 |
respectively. |
2dd2547acb41
discontinued old ISABELLE and ISATOOL environment settings;
wenzelm
parents:
34238
diff
changeset
|
1524 |
|
36201
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1525 |
* Old lib/scripts/polyml-platform is superseded by the |
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1526 |
ISABELLE_PLATFORM setting variable, which defaults to the 32 bit |
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1527 |
variant, even on a 64 bit machine. The following example setting |
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1528 |
prefers 64 bit if available: |
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1529 |
|
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1530 |
ML_PLATFORM="${ISABELLE_PLATFORM64:-$ISABELLE_PLATFORM}" |
07d4f74abd12
polyml-platform script is superseded by ISABELLE_PLATFORM;
wenzelm
parents:
36178
diff
changeset
|
1531 |
|
37218 | 1532 |
* The preliminary Isabelle/jEdit application demonstrates the emerging |
1533 |
Isabelle/Scala layer for advanced prover interaction and integration. |
|
1534 |
See src/Tools/jEdit or "isabelle jedit" provided by the properly built |
|
1535 |
component. |
|
1536 |
||
37375 | 1537 |
* "IsabelleText" is a Unicode font derived from Bitstream Vera Mono |
1538 |
and Bluesky TeX fonts. It provides the usual Isabelle symbols, |
|
1539 |
similar to the default assignment of the document preparation system |
|
1540 |
(cf. isabellesym.sty). The Isabelle/Scala class Isabelle_System |
|
1541 |
provides some operations for direct access to the font without asking |
|
1542 |
the user for manual installation. |
|
1543 |
||
34238 | 1544 |
|
33993 | 1545 |
|
33842 | 1546 |
New in Isabelle2009-1 (December 2009) |
1547 |
------------------------------------- |
|
30904 | 1548 |
|
31547 | 1549 |
*** General *** |
1550 |
||
1551 |
* Discontinued old form of "escaped symbols" such as \\<forall>. Only |
|
1552 |
one backslash should be used, even in ML sources. |
|
1553 |
||
1554 |
||
30951
a6e26a248f03
formal declaration of undefined parameters after class instantiation
haftmann
parents:
30949
diff
changeset
|
1555 |
*** Pure *** |
a6e26a248f03
formal declaration of undefined parameters after class instantiation
haftmann
parents:
30949
diff
changeset
|
1556 |
|
32846
29941e925c82
News entry: inheritance of mixins; print_interps.
ballarin
parents:
32775
diff
changeset
|
1557 |
* Locale interpretation propagates mixins along the locale hierarchy. |
29941e925c82
News entry: inheritance of mixins; print_interps.
ballarin
parents:
32775
diff
changeset
|
1558 |
The currently only available mixins are the equations used to map |
29941e925c82
News entry: inheritance of mixins; print_interps.
ballarin
parents:
32775
diff
changeset
|
1559 |
local definitions to terms of the target domain of an interpretation. |
29941e925c82
News entry: inheritance of mixins; print_interps.
ballarin
parents:
32775
diff
changeset
|
1560 |
|
33842 | 1561 |
* Reactivated diagnostic command 'print_interps'. Use "print_interps |
1562 |
loc" to print all interpretations of locale "loc" in the theory. |
|
1563 |
Interpretations in proofs are not shown. |
|
32846
29941e925c82
News entry: inheritance of mixins; print_interps.
ballarin
parents:
32775
diff
changeset
|
1564 |
|
32983 | 1565 |
* Thoroughly revised locales tutorial. New section on conditional |
1566 |
interpretation. |
|
1567 |
||
33843 | 1568 |
* On instantiation of classes, remaining undefined class parameters |
1569 |
are formally declared. INCOMPATIBILITY. |
|
1570 |
||
30951
a6e26a248f03
formal declaration of undefined parameters after class instantiation
haftmann
parents:
30949
diff
changeset
|
1571 |
|
33842 | 1572 |
*** Document preparation *** |
1573 |
||
1574 |
* New generalized style concept for printing terms: @{foo (style) ...} |
|
1575 |
instead of @{foo_style style ...} (old form is still retained for |
|
1576 |
backward compatibility). Styles can be also applied for |
|
1577 |
antiquotations prop, term_type and typeof. |
|
32891 | 1578 |
|
1579 |
||
30930 | 1580 |
*** HOL *** |
1581 |
||
33842 | 1582 |
* New proof method "smt" for a combination of first-order logic with |
1583 |
equality, linear and nonlinear (natural/integer/real) arithmetic, and |
|
1584 |
fixed-size bitvectors; there is also basic support for higher-order |
|
1585 |
features (esp. lambda abstractions). It is an incomplete decision |
|
1586 |
procedure based on external SMT solvers using the oracle mechanism; |
|
1587 |
for the SMT solver Z3, this method is proof-producing. Certificates |
|
1588 |
are provided to avoid calling the external solvers solely for |
|
1589 |
re-checking proofs. Due to a remote SMT service there is no need for |
|
1590 |
installing SMT solvers locally. See src/HOL/SMT. |
|
1591 |
||
1592 |
* New commands to load and prove verification conditions generated by |
|
1593 |
the Boogie program verifier or derived systems (e.g. the Verifying C |
|
1594 |
Compiler (VCC) or Spec#). See src/HOL/Boogie. |
|
1595 |
||
1596 |
* New counterexample generator tool 'nitpick' based on the Kodkod |
|
1597 |
relational model finder. See src/HOL/Tools/Nitpick and |
|
1598 |
src/HOL/Nitpick_Examples. |
|
1599 |
||
33860 | 1600 |
* New commands 'code_pred' and 'values' to invoke the predicate |
1601 |
compiler and to enumerate values of inductive predicates. |
|
1602 |
||
1603 |
* A tabled implementation of the reflexive transitive closure. |
|
1604 |
||
1605 |
* New implementation of quickcheck uses generic code generator; |
|
1606 |
default generators are provided for all suitable HOL types, records |
|
1607 |
and datatypes. Old quickcheck can be re-activated importing theory |
|
1608 |
Library/SML_Quickcheck. |
|
1609 |
||
33843 | 1610 |
* New testing tool Mirabelle for automated proof tools. Applies |
1611 |
several tools and tactics like sledgehammer, metis, or quickcheck, to |
|
1612 |
every proof step in a theory. To be used in batch mode via the |
|
1613 |
"mirabelle" utility. |
|
1614 |
||
1615 |
* New proof method "sos" (sum of squares) for nonlinear real |
|
1616 |
arithmetic (originally due to John Harison). It requires theory |
|
1617 |
Library/Sum_Of_Squares. It is not a complete decision procedure but |
|
1618 |
works well in practice on quantifier-free real arithmetic with +, -, |
|
1619 |
*, ^, =, <= and <, i.e. boolean combinations of equalities and |
|
1620 |
inequalities between polynomials. It makes use of external |
|
1621 |
semidefinite programming solvers. Method "sos" generates a |
|
1622 |
certificate that can be pasted into the proof thus avoiding the need |
|
1623 |
to call an external tool every time the proof is checked. See |
|
1624 |
src/HOL/Library/Sum_Of_Squares. |
|
1625 |
||
1626 |
* New method "linarith" invokes existing linear arithmetic decision |
|
1627 |
procedure only. |
|
1628 |
||
1629 |
* New command 'atp_minimal' reduces result produced by Sledgehammer. |
|
1630 |
||
1631 |
* New Sledgehammer option "Full Types" in Proof General settings menu. |
|
1632 |
Causes full type information to be output to the ATPs. This slows |
|
1633 |
ATPs down considerably but eliminates a source of unsound "proofs" |
|
1634 |
that fail later. |
|
1635 |
||
1636 |
* New method "metisFT": A version of metis that uses full type |
|
1637 |
information in order to avoid failures of proof reconstruction. |
|
1638 |
||
1639 |
* New evaluator "approximate" approximates an real valued term using |
|
1640 |
the same method as the approximation method. |
|
1641 |
||
1642 |
* Method "approximate" now supports arithmetic expressions as |
|
1643 |
boundaries of intervals and implements interval splitting and Taylor |
|
1644 |
series expansion. |
|
1645 |
||
1646 |
* ML antiquotation @{code_datatype} inserts definition of a datatype |
|
1647 |
generated by the code generator; e.g. see src/HOL/Predicate.thy. |
|
1648 |
||
33860 | 1649 |
* New theory SupInf of the supremum and infimum operators for sets of |
1650 |
reals. |
|
1651 |
||
1652 |
* New theory Probability, which contains a development of measure |
|
1653 |
theory, eventually leading to Lebesgue integration and probability. |
|
1654 |
||
1655 |
* Extended Multivariate Analysis to include derivation and Brouwer's |
|
1656 |
fixpoint theorem. |
|
33843 | 1657 |
|
33842 | 1658 |
* Reorganization of number theory, INCOMPATIBILITY: |
33873 | 1659 |
- new number theory development for nat and int, in theories Divides |
1660 |
and GCD as well as in new session Number_Theory |
|
1661 |
- some constants and facts now suffixed with _nat and _int |
|
1662 |
accordingly |
|
1663 |
- former session NumberTheory now named Old_Number_Theory, including |
|
1664 |
theories Legacy_GCD and Primes (prefer Number_Theory if possible) |
|
33842 | 1665 |
- moved theory Pocklington from src/HOL/Library to |
1666 |
src/HOL/Old_Number_Theory |
|
32479 | 1667 |
|
33873 | 1668 |
* Theory GCD includes functions Gcd/GCD and Lcm/LCM for the gcd and |
1669 |
lcm of finite and infinite sets. It is shown that they form a complete |
|
32600 | 1670 |
lattice. |
1671 |
||
1672 |
* Class semiring_div requires superclass no_zero_divisors and proof of |
|
1673 |
div_mult_mult1; theorems div_mult_mult1, div_mult_mult2, |
|
1674 |
div_mult_mult1_if, div_mult_mult1 and div_mult_mult2 have been |
|
1675 |
generalized to class semiring_div, subsuming former theorems |
|
1676 |
zdiv_zmult_zmult1, zdiv_zmult_zmult1_if, zdiv_zmult_zmult1 and |
|
1677 |
zdiv_zmult_zmult2. div_mult_mult1 is now [simp] by default. |
|
1678 |
INCOMPATIBILITY. |
|
1679 |
||
32588
5e06a1634e55
Inter and Union are mere abbreviations for Inf and Sup; tuned
haftmann
parents:
32485
diff
changeset
|
1680 |
* Refinements to lattice classes and sets: |
32064 | 1681 |
- less default intro/elim rules in locale variant, more default |
1682 |
intro/elim rules in class variant: more uniformity |
|
33842 | 1683 |
- lemma ge_sup_conv renamed to le_sup_iff, in accordance with |
1684 |
le_inf_iff |
|
1685 |
- dropped lemma alias inf_ACI for inf_aci (same for sup_ACI and |
|
1686 |
sup_aci) |
|
32064 | 1687 |
- renamed ACI to inf_sup_aci |
32600 | 1688 |
- new class "boolean_algebra" |
33842 | 1689 |
- class "complete_lattice" moved to separate theory |
33860 | 1690 |
"Complete_Lattice"; corresponding constants (and abbreviations) |
33842 | 1691 |
renamed and with authentic syntax: |
33860 | 1692 |
Set.Inf ~> Complete_Lattice.Inf |
1693 |
Set.Sup ~> Complete_Lattice.Sup |
|
1694 |
Set.INFI ~> Complete_Lattice.INFI |
|
1695 |
Set.SUPR ~> Complete_Lattice.SUPR |
|
1696 |
Set.Inter ~> Complete_Lattice.Inter |
|
1697 |
Set.Union ~> Complete_Lattice.Union |
|
1698 |
Set.INTER ~> Complete_Lattice.INTER |
|
1699 |
Set.UNION ~> Complete_Lattice.UNION |
|
32600 | 1700 |
- authentic syntax for |
1701 |
Set.Pow |
|
1702 |
Set.image |
|
32588
5e06a1634e55
Inter and Union are mere abbreviations for Inf and Sup; tuned
haftmann
parents:
32485
diff
changeset
|
1703 |
- mere abbreviations: |
5e06a1634e55
Inter and Union are mere abbreviations for Inf and Sup; tuned
haftmann
parents:
32485
diff
changeset
|
1704 |
Set.empty (for bot) |
5e06a1634e55
Inter and Union are mere abbreviations for Inf and Sup; tuned
haftmann
parents:
32485
diff
changeset
|
1705 |
Set.UNIV (for top) |
33860 | 1706 |
Set.inter (for inf, formerly Set.Int) |
1707 |
Set.union (for sup, formerly Set.Un) |
|
32588
5e06a1634e55
Inter and Union are mere abbreviations for Inf and Sup; tuned
haftmann
parents:
32485
diff
changeset
|
1708 |
Complete_Lattice.Inter (for Inf) |
5e06a1634e55
Inter and Union are mere abbreviations for Inf and Sup; tuned
haftmann
parents:
32485
diff
changeset
|
1709 |
Complete_Lattice.Union (for Sup) |
32606
b5c3a8a75772
INTER and UNION are mere abbreviations for INFI and SUPR
haftmann
parents:
32600
diff
changeset
|
1710 |
Complete_Lattice.INTER (for INFI) |
b5c3a8a75772
INTER and UNION are mere abbreviations for INFI and SUPR
haftmann
parents:
32600
diff
changeset
|
1711 |
Complete_Lattice.UNION (for SUPR) |
32600 | 1712 |
- object-logic definitions as far as appropriate |
32217 | 1713 |
|
32691 | 1714 |
INCOMPATIBILITY. Care is required when theorems Int_subset_iff or |
33842 | 1715 |
Un_subset_iff are explicitly deleted as default simp rules; then also |
1716 |
their lattice counterparts le_inf_iff and le_sup_iff have to be |
|
32691 | 1717 |
deleted to achieve the desired effect. |
32064 | 1718 |
|
33842 | 1719 |
* Rules inf_absorb1, inf_absorb2, sup_absorb1, sup_absorb2 are no simp |
1720 |
rules by default any longer; the same applies to min_max.inf_absorb1 |
|
1721 |
etc. INCOMPATIBILITY. |
|
1722 |
||
1723 |
* Rules sup_Int_eq and sup_Un_eq are no longer declared as |
|
1724 |
pred_set_conv by default. INCOMPATIBILITY. |
|
1725 |
||
1726 |
* Power operations on relations and functions are now one dedicated |
|
32706 | 1727 |
constant "compow" with infix syntax "^^". Power operation on |
31547 | 1728 |
multiplicative monoids retains syntax "^" and is now defined generic |
1729 |
in class power. INCOMPATIBILITY. |
|
1730 |
||
33842 | 1731 |
* Relation composition "R O S" now has a more standard argument order: |
1732 |
"R O S = {(x, z). EX y. (x, y) : R & (y, z) : S}". INCOMPATIBILITY, |
|
1733 |
rewrite propositions with "S O R" --> "R O S". Proofs may occasionally |
|
1734 |
break, since the O_assoc rule was not rewritten like this. Fix using |
|
1735 |
O_assoc[symmetric]. The same applies to the curried version "R OO S". |
|
32427 | 1736 |
|
33057 | 1737 |
* Function "Inv" is renamed to "inv_into" and function "inv" is now an |
33842 | 1738 |
abbreviation for "inv_into UNIV". Lemmas are renamed accordingly. |
32988 | 1739 |
INCOMPATIBILITY. |
1740 |
||
33860 | 1741 |
* Most rules produced by inductive and datatype package have mandatory |
1742 |
prefixes. INCOMPATIBILITY. |
|
31790 | 1743 |
|
33842 | 1744 |
* Changed "DERIV_intros" to a dynamic fact, which can be augmented by |
1745 |
the attribute of the same name. Each of the theorems in the list |
|
1746 |
DERIV_intros assumes composition with an additional function and |
|
1747 |
matches a variable to the derivative, which has to be solved by the |
|
1748 |
Simplifier. Hence (auto intro!: DERIV_intros) computes the derivative |
|
33873 | 1749 |
of most elementary terms. Former Maclauren.DERIV_tac and |
1750 |
Maclauren.deriv_tac should be replaced by (auto intro!: DERIV_intros). |
|
1751 |
INCOMPATIBILITY. |
|
33860 | 1752 |
|
1753 |
* Code generator attributes follow the usual underscore convention: |
|
1754 |
code_unfold replaces code unfold |
|
1755 |
code_post replaces code post |
|
1756 |
etc. |
|
1757 |
INCOMPATIBILITY. |
|
31900 | 1758 |
|
33471 | 1759 |
* Renamed methods: |
1760 |
sizechange -> size_change |
|
1761 |
induct_scheme -> induction_schema |
|
33860 | 1762 |
INCOMPATIBILITY. |
33673 | 1763 |
|
33843 | 1764 |
* Discontinued abbreviation "arbitrary" of constant "undefined". |
1765 |
INCOMPATIBILITY, use "undefined" directly. |
|
1766 |
||
33860 | 1767 |
* Renamed theorems: |
1768 |
Suc_eq_add_numeral_1 -> Suc_eq_plus1 |
|
1769 |
Suc_eq_add_numeral_1_left -> Suc_eq_plus1_left |
|
1770 |
Suc_plus1 -> Suc_eq_plus1 |
|
1771 |
*anti_sym -> *antisym* |
|
1772 |
vector_less_eq_def -> vector_le_def |
|
1773 |
INCOMPATIBILITY. |
|
1774 |
||
1775 |
* Added theorem List.map_map as [simp]. Removed List.map_compose. |
|
1776 |
INCOMPATIBILITY. |
|
1777 |
||
1778 |
* Removed predicate "M hassize n" (<--> card M = n & finite M). |
|
1779 |
INCOMPATIBILITY. |
|
1780 |
||
31812 | 1781 |
|
33825 | 1782 |
*** HOLCF *** |
1783 |
||
33842 | 1784 |
* Theory Representable defines a class "rep" of domains that are |
1785 |
representable (via an ep-pair) in the universal domain type "udom". |
|
33825 | 1786 |
Instances are provided for all type constructors defined in HOLCF. |
1787 |
||
1788 |
* The 'new_domain' command is a purely definitional version of the |
|
1789 |
domain package, for representable domains. Syntax is identical to the |
|
1790 |
old domain package. The 'new_domain' package also supports indirect |
|
1791 |
recursion using previously-defined type constructors. See |
|
33842 | 1792 |
src/HOLCF/ex/New_Domain.thy for examples. |
1793 |
||
1794 |
* Method "fixrec_simp" unfolds one step of a fixrec-defined constant |
|
33825 | 1795 |
on the left-hand side of an equation, and then performs |
1796 |
simplification. Rewriting is done using rules declared with the |
|
33842 | 1797 |
"fixrec_simp" attribute. The "fixrec_simp" method is intended as a |
1798 |
replacement for "fixpat"; see src/HOLCF/ex/Fixrec_ex.thy for examples. |
|
33825 | 1799 |
|
1800 |
* The pattern-match compiler in 'fixrec' can now handle constructors |
|
1801 |
with HOL function types. Pattern-match combinators for the Pair |
|
1802 |
constructor are pre-configured. |
|
1803 |
||
1804 |
* The 'fixrec' package now produces better fixed-point induction rules |
|
1805 |
for mutually-recursive definitions: Induction rules have conclusions |
|
1806 |
of the form "P foo bar" instead of "P <foo, bar>". |
|
1807 |
||
1808 |
* The constant "sq_le" (with infix syntax "<<" or "\<sqsubseteq>") has |
|
1809 |
been renamed to "below". The name "below" now replaces "less" in many |
|
33842 | 1810 |
theorem names. (Legacy theorem names using "less" are still supported |
1811 |
as well.) |
|
33825 | 1812 |
|
1813 |
* The 'fixrec' package now supports "bottom patterns". Bottom |
|
1814 |
patterns can be used to generate strictness rules, or to make |
|
1815 |
functions more strict (much like the bang-patterns supported by the |
|
33873 | 1816 |
Glasgow Haskell Compiler). See src/HOLCF/ex/Fixrec_ex.thy for |
1817 |
examples. |
|
33825 | 1818 |
|
1819 |
||
31304 | 1820 |
*** ML *** |
1821 |
||
33843 | 1822 |
* Support for Poly/ML 5.3.0, with improved reporting of compiler |
1823 |
errors and run-time exceptions, including detailed source positions. |
|
1824 |
||
1825 |
* Structure Name_Space (formerly NameSpace) now manages uniquely |
|
1826 |
identified entries, with some additional information such as source |
|
1827 |
position, logical grouping etc. |
|
1828 |
||
33524
a08e6c1cbc04
updated functor Theory_Data, Proof_Data, Generic_Data;
wenzelm
parents:
33472
diff
changeset
|
1829 |
* Theory and context data is now introduced by the simplified and |
a08e6c1cbc04
updated functor Theory_Data, Proof_Data, Generic_Data;
wenzelm
parents:
33472
diff
changeset
|
1830 |
modernized functors Theory_Data, Proof_Data, Generic_Data. Data needs |
a08e6c1cbc04
updated functor Theory_Data, Proof_Data, Generic_Data;
wenzelm
parents:
33472
diff
changeset
|
1831 |
to be pure, but the old TheoryDataFun for mutable data (with explicit |
a08e6c1cbc04
updated functor Theory_Data, Proof_Data, Generic_Data;
wenzelm
parents:
33472
diff
changeset
|
1832 |
copy operation) is still available for some time. |
a08e6c1cbc04
updated functor Theory_Data, Proof_Data, Generic_Data;
wenzelm
parents:
33472
diff
changeset
|
1833 |
|
32742 | 1834 |
* Structure Synchronized (cf. src/Pure/Concurrent/synchronized.ML) |
1835 |
provides a high-level programming interface to synchronized state |
|
1836 |
variables with atomic update. This works via pure function |
|
1837 |
application within a critical section -- its runtime should be as |
|
1838 |
short as possible; beware of deadlocks if critical code is nested, |
|
1839 |
either directly or indirectly via other synchronized variables! |
|
1840 |
||
1841 |
* Structure Unsynchronized (cf. src/Pure/ML-Systems/unsynchronized.ML) |
|
1842 |
wraps raw ML references, explicitly indicating their non-thread-safe |
|
1843 |
behaviour. The Isar toplevel keeps this structure open, to |
|
1844 |
accommodate Proof General as well as quick and dirty interactive |
|
1845 |
experiments with references. |
|
1846 |
||
32365 | 1847 |
* PARALLEL_CHOICE and PARALLEL_GOALS provide basic support for |
1848 |
parallel tactical reasoning. |
|
1849 |
||
32427 | 1850 |
* Tacticals Subgoal.FOCUS, Subgoal.FOCUS_PREMS, Subgoal.FOCUS_PARAMS |
1851 |
are similar to SUBPROOF, but are slightly more flexible: only the |
|
1852 |
specified parts of the subgoal are imported into the context, and the |
|
1853 |
body tactic may introduce new subgoals and schematic variables. |
|
1854 |
||
1855 |
* Old tactical METAHYPS, which does not observe the proof context, has |
|
1856 |
been renamed to Old_Goals.METAHYPS and awaits deletion. Use SUBPROOF |
|
1857 |
or Subgoal.FOCUS etc. |
|
32216 | 1858 |
|
31971
8c1b845ed105
renamed functor TableFun to Table, and GraphFun to Graph;
wenzelm
parents:
31901
diff
changeset
|
1859 |
* Renamed functor TableFun to Table, and GraphFun to Graph. (Since |
8c1b845ed105
renamed functor TableFun to Table, and GraphFun to Graph;
wenzelm
parents:
31901
diff
changeset
|
1860 |
functors have their own ML name space there is no point to mark them |
8c1b845ed105
renamed functor TableFun to Table, and GraphFun to Graph;
wenzelm
parents:
31901
diff
changeset
|
1861 |
separately.) Minor INCOMPATIBILITY. |
8c1b845ed105
renamed functor TableFun to Table, and GraphFun to Graph;
wenzelm
parents:
31901
diff
changeset
|
1862 |
|
31901 | 1863 |
* Renamed NamedThmsFun to Named_Thms. INCOMPATIBILITY. |
1864 |
||
33842 | 1865 |
* Renamed several structures FooBar to Foo_Bar. Occasional, |
1866 |
INCOMPATIBILITY. |
|
1867 |
||
33843 | 1868 |
* Operations of structure Skip_Proof no longer require quick_and_dirty |
1869 |
mode, which avoids critical setmp. |
|
1870 |
||
31306
a74ee84288a0
eliminated old Attrib.add_attributes (and Attrib.syntax);
wenzelm
parents:
31304
diff
changeset
|
1871 |
* Eliminated old Attrib.add_attributes, Method.add_methods and related |
33842 | 1872 |
combinators for "args". INCOMPATIBILITY, need to use simplified |
31306
a74ee84288a0
eliminated old Attrib.add_attributes (and Attrib.syntax);
wenzelm
parents:
31304
diff
changeset
|
1873 |
Attrib/Method.setup introduced in Isabelle2009. |
31304 | 1874 |
|
32151
2f65c45c2e7e
Proper context for simpset_of, claset_of, clasimpset_of.
wenzelm
parents:
32136
diff
changeset
|
1875 |
* Proper context for simpset_of, claset_of, clasimpset_of. May fall |
2f65c45c2e7e
Proper context for simpset_of, claset_of, clasimpset_of.
wenzelm
parents:
32136
diff
changeset
|
1876 |
back on global_simpset_of, global_claset_of, global_clasimpset_of as |
2f65c45c2e7e
Proper context for simpset_of, claset_of, clasimpset_of.
wenzelm
parents:
32136
diff
changeset
|
1877 |
last resort. INCOMPATIBILITY. |
2f65c45c2e7e
Proper context for simpset_of, claset_of, clasimpset_of.
wenzelm
parents:
32136
diff
changeset
|
1878 |
|
32092
6a5995438266
Display.pretty_thm now requires a proper context;
wenzelm
parents:
32079
diff
changeset
|
1879 |
* Display.pretty_thm now requires a proper context (cf. former |
6a5995438266
Display.pretty_thm now requires a proper context;
wenzelm
parents:
32079
diff
changeset
|
1880 |
ProofContext.pretty_thm). May fall back on Display.pretty_thm_global |
6a5995438266
Display.pretty_thm now requires a proper context;
wenzelm
parents:
32079
diff
changeset
|
1881 |
or even Display.pretty_thm_without_context as last resort. |
6a5995438266
Display.pretty_thm now requires a proper context;
wenzelm
parents:
32079
diff
changeset
|
1882 |
INCOMPATIBILITY. |
6a5995438266
Display.pretty_thm now requires a proper context;
wenzelm
parents:
32079
diff
changeset
|
1883 |
|
32433 | 1884 |
* Discontinued Display.pretty_ctyp/cterm etc. INCOMPATIBILITY, use |
1885 |
Syntax.pretty_typ/term directly, preferably with proper context |
|
1886 |
instead of global theory. |
|
1887 |
||
31304 | 1888 |
|
31308 | 1889 |
*** System *** |
1890 |
||
33842 | 1891 |
* Further fine tuning of parallel proof checking, scales up to 8 cores |
1892 |
(max. speedup factor 5.0). See also Goal.parallel_proofs in ML and |
|
1893 |
usedir option -q. |
|
1894 |
||
32326 | 1895 |
* Support for additional "Isabelle components" via etc/components, see |
1896 |
also the system manual. |
|
1897 |
||
1898 |
* The isabelle makeall tool now operates on all components with |
|
1899 |
IsaMakefile, not just hardwired "logics". |
|
1900 |
||
33842 | 1901 |
* Removed "compress" option from isabelle-process and isabelle usedir; |
1902 |
this is always enabled. |
|
33818 | 1903 |
|
31308 | 1904 |
* Discontinued support for Poly/ML 4.x versions. |
1905 |
||
33842 | 1906 |
* Isabelle tool "wwwfind" provides web interface for 'find_theorems' |
1907 |
on a given logic image. This requires the lighttpd webserver and is |
|
1908 |
currently supported on Linux only. |
|
32061
11f8ee55662d
parallel_proofs: more fine-grained control with optional parallel checking of nested Isar proofs;
wenzelm
parents:
31997
diff
changeset
|
1909 |
|
31308 | 1910 |
|
31304 | 1911 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1912 |
New in Isabelle2009 (April 2009) |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1913 |
-------------------------------- |
27104
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
1914 |
|
27599 | 1915 |
*** General *** |
1916 |
||
28504
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1917 |
* Simplified main Isabelle executables, with less surprises on |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1918 |
case-insensitive file-systems (such as Mac OS). |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1919 |
|
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1920 |
- The main Isabelle tool wrapper is now called "isabelle" instead of |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1921 |
"isatool." |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1922 |
|
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1923 |
- The former "isabelle" alias for "isabelle-process" has been |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1924 |
removed (should rarely occur to regular users). |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1925 |
|
28915
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1926 |
- The former "isabelle-interface" and its alias "Isabelle" have been |
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1927 |
removed (interfaces are now regular Isabelle tools). |
28504
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1928 |
|
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1929 |
Within scripts and make files, the Isabelle environment variables |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1930 |
ISABELLE_TOOL and ISABELLE_PROCESS replace old ISATOOL and ISABELLE, |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1931 |
respectively. (The latter are still available as legacy feature.) |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1932 |
|
28915
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1933 |
The old isabelle-interface wrapper could react in confusing ways if |
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1934 |
the interface was uninstalled or changed otherwise. Individual |
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1935 |
interface tool configuration is now more explicit, see also the |
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1936 |
Isabelle system manual. In particular, Proof General is now available |
0642cbb60c98
removed obsolete isabelle-interface executable and ISABELLE_INTERFACE setting;
wenzelm
parents:
28914
diff
changeset
|
1937 |
via "isabelle emacs". |
28504
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1938 |
|
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1939 |
INCOMPATIBILITY, need to adapt derivative scripts. Users may need to |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1940 |
purge installed copies of Isabelle executables and re-run "isabelle |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1941 |
install -p ...", or use symlinks. |
7ad7d7d6df47
simplified main Isabelle executables: removed Isabelle and isabelle (replaced by isabelle-process), renamed isatool to isabelle;
wenzelm
parents:
28475
diff
changeset
|
1942 |
|
28914
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1943 |
* The default for ISABELLE_HOME_USER is now ~/.isabelle instead of the |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1944 |
old ~/isabelle, which was slightly non-standard and apt to cause |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1945 |
surprises on case-insensitive file-systems (such as Mac OS). |
28914
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1946 |
|
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1947 |
INCOMPATIBILITY, need to move existing ~/isabelle/etc, |
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1948 |
~/isabelle/heaps, ~/isabelle/browser_info to the new place. Special |
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1949 |
care is required when using older releases of Isabelle. Note that |
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1950 |
ISABELLE_HOME_USER can be changed in Isabelle/etc/settings of any |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1951 |
Isabelle distribution, in order to use the new ~/.isabelle uniformly. |
28914
f993cbffc42a
default for ISABELLE_HOME_USER is now ~/.isabelle instead of ~/isabelle;
wenzelm
parents:
28856
diff
changeset
|
1952 |
|
29161
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
1953 |
* Proofs of fully specified statements are run in parallel on |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1954 |
multi-core systems. A speedup factor of 2.5 to 3.2 can be expected on |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1955 |
a regular 4-core machine, if the initial heap space is made reasonably |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1956 |
large (cf. Poly/ML option -H). (Requires Poly/ML 5.2.1 or later.) |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1957 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1958 |
* The main reference manuals ("isar-ref", "implementation", and |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1959 |
"system") have been updated and extended. Formally checked references |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1960 |
as hyperlinks are now available uniformly. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1961 |
|
30163
faf95eb3f375
* New prover for coherent logic (see src/Tools/coherent.ML).
wenzelm
parents:
30106
diff
changeset
|
1962 |
|
27599 | 1963 |
*** Pure *** |
1964 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1965 |
* Complete re-implementation of locales. INCOMPATIBILITY in several |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1966 |
respects. The most important changes are listed below. See the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1967 |
Tutorial on Locales ("locales" manual) for details. |
29253 | 1968 |
|
1969 |
- In locale expressions, instantiation replaces renaming. Parameters |
|
1970 |
must be declared in a for clause. To aid compatibility with previous |
|
1971 |
parameter inheritance, in locale declarations, parameters that are not |
|
1972 |
'touched' (instantiation position "_" or omitted) are implicitly added |
|
1973 |
with their syntax at the beginning of the for clause. |
|
1974 |
||
1975 |
- Syntax from abbreviations and definitions in locales is available in |
|
1976 |
locale expressions and context elements. The latter is particularly |
|
1977 |
useful in locale declarations. |
|
1978 |
||
1979 |
- More flexible mechanisms to qualify names generated by locale |
|
1980 |
expressions. Qualifiers (prefixes) may be specified in locale |
|
30728
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1981 |
expressions, and can be marked as mandatory (syntax: "name!:") or |
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1982 |
optional (syntax "name?:"). The default depends for plain "name:" |
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1983 |
depends on the situation where a locale expression is used: in |
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1984 |
commands 'locale' and 'sublocale' prefixes are optional, in |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1985 |
'interpretation' and 'interpret' prefixes are mandatory. The old |
30728
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1986 |
implicit qualifiers derived from the parameter names of a locale are |
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1987 |
no longer generated. |
30106 | 1988 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1989 |
- Command "sublocale l < e" replaces "interpretation l < e". The |
30106 | 1990 |
instantiation clause in "interpretation" and "interpret" (square |
1991 |
brackets) is no longer available. Use locale expressions. |
|
29253 | 1992 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1993 |
- When converting proof scripts, mandatory qualifiers in |
30728
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
1994 |
'interpretation' and 'interpret' should be retained by default, even |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1995 |
if this is an INCOMPATIBILITY compared to former behavior. In the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1996 |
worst case, use the "name?:" form for non-mandatory ones. Qualifiers |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1997 |
in locale expressions range over a single locale instance only. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1998 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
1999 |
- Dropped locale element "includes". This is a major INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2000 |
In existing theorem specifications replace the includes element by the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2001 |
respective context elements of the included locale, omitting those |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2002 |
that are already present in the theorem specification. Multiple |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2003 |
assume elements of a locale should be replaced by a single one |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2004 |
involving the locale predicate. In the proof body, declarations (most |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2005 |
notably theorems) may be regained by interpreting the respective |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2006 |
locales in the proof context as required (command "interpret"). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2007 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2008 |
If using "includes" in replacement of a target solely because the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2009 |
parameter types in the theorem are not as general as in the target, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2010 |
consider declaring a new locale with additional type constraints on |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2011 |
the parameters (context element "constrains"). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2012 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2013 |
- Discontinued "locale (open)". INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2014 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2015 |
- Locale interpretation commands no longer attempt to simplify goal. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2016 |
INCOMPATIBILITY: in rare situations the generated goal differs. Use |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2017 |
methods intro_locales and unfold_locales to clarify. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2018 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2019 |
- Locale interpretation commands no longer accept interpretation |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2020 |
attributes. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2021 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2022 |
* Class declaration: so-called "base sort" must not be given in import |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2023 |
list any longer, but is inferred from the specification. Particularly |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2024 |
in HOL, write |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2025 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2026 |
class foo = ... |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2027 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2028 |
instead of |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2029 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2030 |
class foo = type + ... |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2031 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2032 |
* Class target: global versions of theorems stemming do not carry a |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2033 |
parameter prefix any longer. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2034 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2035 |
* Class 'instance' command no longer accepts attached definitions. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2036 |
INCOMPATIBILITY, use proper 'instantiation' target instead. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2037 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2038 |
* Recovered hiding of consts, which was accidentally broken in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2039 |
Isabelle2007. Potential INCOMPATIBILITY, ``hide const c'' really |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2040 |
makes c inaccessible; consider using ``hide (open) const c'' instead. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2041 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2042 |
* Slightly more coherent Pure syntax, with updated documentation in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2043 |
isar-ref manual. Removed locales meta_term_syntax and |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2044 |
meta_conjunction_syntax: TERM and &&& (formerly &&) are now permanent, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2045 |
INCOMPATIBILITY in rare situations. Note that &&& should not be used |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2046 |
directly in regular applications. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2047 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2048 |
* There is a new syntactic category "float_const" for signed decimal |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2049 |
fractions (e.g. 123.45 or -123.45). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2050 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2051 |
* Removed exotic 'token_translation' command. INCOMPATIBILITY, use ML |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2052 |
interface with 'setup' command instead. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2053 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2054 |
* Command 'local_setup' is similar to 'setup', but operates on a local |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2055 |
theory context. |
27104
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2056 |
|
28114 | 2057 |
* The 'axiomatization' command now only works within a global theory |
2058 |
context. INCOMPATIBILITY. |
|
2059 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2060 |
* Goal-directed proof now enforces strict proof irrelevance wrt. sort |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2061 |
hypotheses. Sorts required in the course of reasoning need to be |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2062 |
covered by the constraints in the initial statement, completed by the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2063 |
type instance information of the background theory. Non-trivial sort |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2064 |
hypotheses, which rarely occur in practice, may be specified via |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2065 |
vacuous propositions of the form SORT_CONSTRAINT('a::c). For example: |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2066 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2067 |
lemma assumes "SORT_CONSTRAINT('a::empty)" shows False ... |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2068 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2069 |
The result contains an implicit sort hypotheses as before -- |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2070 |
SORT_CONSTRAINT premises are eliminated as part of the canonical rule |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2071 |
normalization. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2072 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2073 |
* Generalized Isar history, with support for linear undo, direct state |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2074 |
addressing etc. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2075 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2076 |
* Changed defaults for unify configuration options: |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2077 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2078 |
unify_trace_bound = 50 (formerly 25) |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2079 |
unify_search_bound = 60 (formerly 30) |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2080 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2081 |
* Different bookkeeping for code equations (INCOMPATIBILITY): |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2082 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2083 |
a) On theory merge, the last set of code equations for a particular |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2084 |
constant is taken (in accordance with the policy applied by other |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2085 |
parts of the code generator framework). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2086 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2087 |
b) Code equations stemming from explicit declarations (e.g. code |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2088 |
attribute) gain priority over default code equations stemming |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2089 |
from definition, primrec, fun etc. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2090 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2091 |
* Keyword 'code_exception' now named 'code_abort'. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2092 |
|
30965 | 2093 |
* Unified theorem tables for both code generators. Thus [code |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2094 |
func] has disappeared and only [code] remains. INCOMPATIBILITY. |
30577 | 2095 |
|
2096 |
* Command 'find_consts' searches for constants based on type and name |
|
2097 |
patterns, e.g. |
|
29883 | 2098 |
|
2099 |
find_consts "_ => bool" |
|
2100 |
||
30106 | 2101 |
By default, matching is against subtypes, but it may be restricted to |
30728
f0aeca99b5d9
interpretation/interpret: prefixes are mandatory by default;
wenzelm
parents:
30706
diff
changeset
|
2102 |
the whole type. Searching by name is possible. Multiple queries are |
30106 | 2103 |
conjunctive and queries may be negated by prefixing them with a |
2104 |
hyphen: |
|
29883 | 2105 |
|
2106 |
find_consts strict: "_ => bool" name: "Int" -"int => int" |
|
29861
3c348f5873f3
updated NEWS etc with "solves" criterion and auto_solves
kleing
parents:
29823
diff
changeset
|
2107 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2108 |
* New 'find_theorems' criterion "solves" matches theorems that |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2109 |
directly solve the current goal (modulo higher-order unification). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2110 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2111 |
* Auto solve feature for main theorem statements: whenever a new goal |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2112 |
is stated, "find_theorems solves" is called; any theorems that could |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2113 |
solve the lemma directly are listed as part of the goal state. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2114 |
Cf. associated options in Proof General Isabelle settings menu, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2115 |
enabled by default, with reasonable timeout for pathological cases of |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2116 |
higher-order unification. |
30415
9501af91c4a3
Instead of giving up entirely, arith now ignores all inequalities when there are too many.
webertj
parents:
30399
diff
changeset
|
2117 |
|
27104
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2118 |
|
27381 | 2119 |
*** Document preparation *** |
2120 |
||
2121 |
* Antiquotation @{lemma} now imitates a regular terminal proof, |
|
27392 | 2122 |
demanding keyword 'by' and supporting the full method expression |
27519
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2123 |
syntax just like the Isar command 'by'. |
27381 | 2124 |
|
2125 |
||
27104
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2126 |
*** HOL *** |
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2127 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2128 |
* Integrated main parts of former image HOL-Complex with HOL. Entry |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2129 |
points Main and Complex_Main remain as before. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2130 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2131 |
* Logic image HOL-Plain provides a minimal HOL with the most important |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2132 |
tools available (inductive, datatype, primrec, ...). This facilitates |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2133 |
experimentation and tool development. Note that user applications |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2134 |
(and library theories) should never refer to anything below theory |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2135 |
Main, as before. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2136 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2137 |
* Logic image HOL-Main stops at theory Main, and thus facilitates |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2138 |
experimentation due to shorter build times. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2139 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2140 |
* Logic image HOL-NSA contains theories of nonstandard analysis which |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2141 |
were previously part of former HOL-Complex. Entry point Hyperreal |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2142 |
remains valid, but theories formerly using Complex_Main should now use |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2143 |
new entry point Hypercomplex. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2144 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2145 |
* Generic ATP manager for Sledgehammer, based on ML threads instead of |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2146 |
Posix processes. Avoids potentially expensive forking of the ML |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2147 |
process. New thread-based implementation also works on non-Unix |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2148 |
platforms (Cygwin). Provers are no longer hardwired, but defined |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2149 |
within the theory via plain ML wrapper functions. Basic Sledgehammer |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2150 |
commands are covered in the isar-ref manual. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2151 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2152 |
* Wrapper scripts for remote SystemOnTPTP service allows to use |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2153 |
sledgehammer without local ATP installation (Vampire etc.). Other |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2154 |
provers may be included via suitable ML wrappers, see also |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2155 |
src/HOL/ATP_Linkup.thy. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2156 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2157 |
* ATP selection (E/Vampire/Spass) is now via Proof General's settings |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2158 |
menu. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2159 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2160 |
* The metis method no longer fails because the theorem is too trivial |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2161 |
(contains the empty clause). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2162 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2163 |
* The metis method now fails in the usual manner, rather than raising |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2164 |
an exception, if it determines that it cannot prove the theorem. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2165 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2166 |
* Method "coherent" implements a prover for coherent logic (see also |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2167 |
src/Tools/coherent.ML). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2168 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2169 |
* Constants "undefined" and "default" replace "arbitrary". Usually |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2170 |
"undefined" is the right choice to replace "arbitrary", though |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2171 |
logically there is no difference. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2172 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2173 |
* Command "value" now integrates different evaluation mechanisms. The |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2174 |
result of the first successful evaluation mechanism is printed. In |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2175 |
square brackets a particular named evaluation mechanisms may be |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2176 |
specified (currently, [SML], [code] or [nbe]). See further |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2177 |
src/HOL/ex/Eval_Examples.thy. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2178 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2179 |
* Normalization by evaluation now allows non-leftlinear equations. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2180 |
Declare with attribute [code nbe]. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2181 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2182 |
* Methods "case_tac" and "induct_tac" now refer to the very same rules |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2183 |
as the structured Isar versions "cases" and "induct", cf. the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2184 |
corresponding "cases" and "induct" attributes. Mutual induction rules |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2185 |
are now presented as a list of individual projections |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2186 |
(e.g. foo_bar.inducts for types foo and bar); the old format with |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2187 |
explicit HOL conjunction is no longer supported. INCOMPATIBILITY, in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2188 |
rare situations a different rule is selected --- notably nested tuple |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2189 |
elimination instead of former prod.exhaust: use explicit (case_tac t |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2190 |
rule: prod.exhaust) here. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2191 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2192 |
* Attributes "cases", "induct", "coinduct" support "del" option. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2193 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2194 |
* Removed fact "case_split_thm", which duplicates "case_split". |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2195 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2196 |
* The option datatype has been moved to a new theory Option. Renamed |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2197 |
option_map to Option.map, and o2s to Option.set, INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2198 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2199 |
* New predicate "strict_mono" classifies strict functions on partial |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2200 |
orders. With strict functions on linear orders, reasoning about |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2201 |
(in)equalities is facilitated by theorems "strict_mono_eq", |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2202 |
"strict_mono_less_eq" and "strict_mono_less". |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2203 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2204 |
* Some set operations are now proper qualified constants with |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2205 |
authentic syntax. INCOMPATIBILITY: |
30304
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2206 |
|
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2207 |
op Int ~> Set.Int |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2208 |
op Un ~> Set.Un |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2209 |
INTER ~> Set.INTER |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2210 |
UNION ~> Set.UNION |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2211 |
Inter ~> Set.Inter |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2212 |
Union ~> Set.Union |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2213 |
{} ~> Set.empty |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2214 |
UNIV ~> Set.UNIV |
d8e4cd2ac2a1
set operations Int, Un, INTER, UNION, Inter, Union, empty, UNIV are now proper qualified constants with authentic syntax
haftmann
parents:
30085
diff
changeset
|
2215 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2216 |
* Class complete_lattice with operations Inf, Sup, INFI, SUPR now in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2217 |
theory Set. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2218 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2219 |
* Auxiliary class "itself" has disappeared -- classes without any |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2220 |
parameter are treated as expected by the 'class' command. |
29797 | 2221 |
|
29823
0ab754d13ccd
session Reflecion renamed to Decision_Procs, moved Dense_Linear_Order there
haftmann
parents:
29810
diff
changeset
|
2222 |
* Leibnitz's Series for Pi and the arcus tangens and logarithm series. |
0ab754d13ccd
session Reflecion renamed to Decision_Procs, moved Dense_Linear_Order there
haftmann
parents:
29810
diff
changeset
|
2223 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2224 |
* Common decision procedures (Cooper, MIR, Ferrack, Approximation, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2225 |
Dense_Linear_Order) are now in directory HOL/Decision_Procs. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2226 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2227 |
* Theory src/HOL/Decision_Procs/Approximation provides the new proof |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2228 |
method "approximation". It proves formulas on real values by using |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2229 |
interval arithmetic. In the formulas are also the transcendental |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2230 |
functions sin, cos, tan, atan, ln, exp and the constant pi are |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2231 |
allowed. For examples see |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2232 |
src/HOL/Descision_Procs/ex/Approximation_Ex.thy. |
29823
0ab754d13ccd
session Reflecion renamed to Decision_Procs, moved Dense_Linear_Order there
haftmann
parents:
29810
diff
changeset
|
2233 |
|
0ab754d13ccd
session Reflecion renamed to Decision_Procs, moved Dense_Linear_Order there
haftmann
parents:
29810
diff
changeset
|
2234 |
* Theory "Reflection" now resides in HOL/Library. |
29650 | 2235 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2236 |
* Entry point to Word library now simply named "Word". |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2237 |
INCOMPATIBILITY. |
29628 | 2238 |
|
29197
6d4cb27ed19c
adapted HOL source structure to distribution layout
haftmann
parents:
29182
diff
changeset
|
2239 |
* Made source layout more coherent with logical distribution |
6d4cb27ed19c
adapted HOL source structure to distribution layout
haftmann
parents:
29182
diff
changeset
|
2240 |
structure: |
28952
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2241 |
|
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2242 |
src/HOL/Library/RType.thy ~> src/HOL/Typerep.thy |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2243 |
src/HOL/Library/Code_Message.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2244 |
src/HOL/Library/GCD.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2245 |
src/HOL/Library/Order_Relation.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2246 |
src/HOL/Library/Parity.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2247 |
src/HOL/Library/Univ_Poly.thy ~> src/HOL/ |
30176
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2248 |
src/HOL/Real/ContNotDenum.thy ~> src/HOL/Library/ |
28952
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2249 |
src/HOL/Real/Lubs.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2250 |
src/HOL/Real/PReal.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2251 |
src/HOL/Real/Rational.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2252 |
src/HOL/Real/RComplete.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2253 |
src/HOL/Real/RealDef.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2254 |
src/HOL/Real/RealPow.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2255 |
src/HOL/Real/Real.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2256 |
src/HOL/Complex/Complex_Main.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2257 |
src/HOL/Complex/Complex.thy ~> src/HOL/ |
30176
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2258 |
src/HOL/Complex/FrechetDeriv.thy ~> src/HOL/Library/ |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2259 |
src/HOL/Complex/Fundamental_Theorem_Algebra.thy ~> src/HOL/Library/ |
28952
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2260 |
src/HOL/Hyperreal/Deriv.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2261 |
src/HOL/Hyperreal/Fact.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2262 |
src/HOL/Hyperreal/Integration.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2263 |
src/HOL/Hyperreal/Lim.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2264 |
src/HOL/Hyperreal/Ln.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2265 |
src/HOL/Hyperreal/Log.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2266 |
src/HOL/Hyperreal/MacLaurin.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2267 |
src/HOL/Hyperreal/NthRoot.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2268 |
src/HOL/Hyperreal/Series.thy ~> src/HOL/ |
29197
6d4cb27ed19c
adapted HOL source structure to distribution layout
haftmann
parents:
29182
diff
changeset
|
2269 |
src/HOL/Hyperreal/SEQ.thy ~> src/HOL/ |
28952
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2270 |
src/HOL/Hyperreal/Taylor.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2271 |
src/HOL/Hyperreal/Transcendental.thy ~> src/HOL/ |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2272 |
src/HOL/Real/Float ~> src/HOL/Library/ |
29197
6d4cb27ed19c
adapted HOL source structure to distribution layout
haftmann
parents:
29182
diff
changeset
|
2273 |
src/HOL/Real/HahnBanach ~> src/HOL/HahnBanach |
6d4cb27ed19c
adapted HOL source structure to distribution layout
haftmann
parents:
29182
diff
changeset
|
2274 |
src/HOL/Real/RealVector.thy ~> src/HOL/ |
28952
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2275 |
|
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2276 |
src/HOL/arith_data.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2277 |
src/HOL/hologic.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2278 |
src/HOL/simpdata.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2279 |
src/HOL/int_arith1.ML ~> src/HOL/Tools/int_arith.ML |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2280 |
src/HOL/int_factor_simprocs.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2281 |
src/HOL/nat_simprocs.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2282 |
src/HOL/Real/float_arith.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2283 |
src/HOL/Real/float_syntax.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2284 |
src/HOL/Real/rat_arith.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2285 |
src/HOL/Real/real_arith.ML ~> src/HOL/Tools |
15a4b2cf8c34
made repository layout more coherent with logical distribution structure; stripped some $Id$s
haftmann
parents:
28915
diff
changeset
|
2286 |
|
29398 | 2287 |
src/HOL/Library/Array.thy ~> src/HOL/Imperative_HOL |
2288 |
src/HOL/Library/Heap_Monad.thy ~> src/HOL/Imperative_HOL |
|
2289 |
src/HOL/Library/Heap.thy ~> src/HOL/Imperative_HOL |
|
2290 |
src/HOL/Library/Imperative_HOL.thy ~> src/HOL/Imperative_HOL |
|
2291 |
src/HOL/Library/Ref.thy ~> src/HOL/Imperative_HOL |
|
2292 |
src/HOL/Library/Relational.thy ~> src/HOL/Imperative_HOL |
|
2293 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2294 |
* If methods "eval" and "evaluation" encounter a structured proof |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2295 |
state with !!/==>, only the conclusion is evaluated to True (if |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2296 |
possible), avoiding strange error messages. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2297 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2298 |
* Method "sizechange" automates termination proofs using (a |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2299 |
modification of) the size-change principle. Requires SAT solver. See |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2300 |
src/HOL/ex/Termination.thy for examples. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2301 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2302 |
* Simplifier: simproc for let expressions now unfolds if bound |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2303 |
variable occurs at most once in let expression body. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2304 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2305 |
* Method "arith": Linear arithmetic now ignores all inequalities when |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2306 |
fast_arith_neq_limit is exceeded, instead of giving up entirely. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2307 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2308 |
* New attribute "arith" for facts that should always be used |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2309 |
automatically by arithmetic. It is intended to be used locally in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2310 |
proofs, e.g. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2311 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2312 |
assumes [arith]: "x > 0" |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2313 |
|
30706 | 2314 |
Global usage is discouraged because of possible performance impact. |
2315 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2316 |
* New classes "top" and "bot" with corresponding operations "top" and |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2317 |
"bot" in theory Orderings; instantiation of class "complete_lattice" |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2318 |
requires instantiation of classes "top" and "bot". INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2319 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2320 |
* Changed definition lemma "less_fun_def" in order to provide an |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2321 |
instance for preorders on functions; use lemma "less_le" instead. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2322 |
INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2323 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2324 |
* Theory Orderings: class "wellorder" moved here, with explicit |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2325 |
induction rule "less_induct" as assumption. For instantiation of |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2326 |
"wellorder" by means of predicate "wf", use rule wf_wellorderI. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2327 |
INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2328 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2329 |
* Theory Orderings: added class "preorder" as superclass of "order". |
27793 | 2330 |
INCOMPATIBILITY: Instantiation proofs for order, linorder |
2331 |
etc. slightly changed. Some theorems named order_class.* now named |
|
2332 |
preorder_class.*. |
|
2333 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2334 |
* Theory Relation: renamed "refl" to "refl_on", "reflexive" to "refl, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2335 |
"diag" to "Id_on". |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2336 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2337 |
* Theory Finite_Set: added a new fold combinator of type |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2338 |
|
28855 | 2339 |
('a => 'b => 'b) => 'b => 'a set => 'b |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2340 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2341 |
Occasionally this is more convenient than the old fold combinator |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2342 |
which is now defined in terms of the new one and renamed to |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2343 |
fold_image. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2344 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2345 |
* Theories Ring_and_Field and OrderedGroup: The lemmas "group_simps" |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2346 |
and "ring_simps" have been replaced by "algebra_simps" (which can be |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2347 |
extended with further lemmas!). At the moment both still exist but |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2348 |
the former will disappear at some point. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2349 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2350 |
* Theory Power: Lemma power_Suc is now declared as a simp rule in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2351 |
class recpower. Type-specific simp rules for various recpower types |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2352 |
have been removed. INCOMPATIBILITY, rename old lemmas as follows: |
30273
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2353 |
|
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2354 |
rat_power_0 -> power_0 |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2355 |
rat_power_Suc -> power_Suc |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2356 |
realpow_0 -> power_0 |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2357 |
realpow_Suc -> power_Suc |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2358 |
complexpow_0 -> power_0 |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2359 |
complexpow_Suc -> power_Suc |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2360 |
power_poly_0 -> power_0 |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2361 |
power_poly_Suc -> power_Suc |
ecd6f0ca62ea
declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents:
30250
diff
changeset
|
2362 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2363 |
* Theories Ring_and_Field and Divides: Definition of "op dvd" has been |
27793 | 2364 |
moved to separate class dvd in Ring_and_Field; a couple of lemmas on |
2365 |
dvd has been generalized to class comm_semiring_1. Likewise a bunch |
|
2366 |
of lemmas from Divides has been generalized from nat to class |
|
2367 |
semiring_div. INCOMPATIBILITY. This involves the following theorem |
|
2368 |
renames resulting from duplicate elimination: |
|
27651
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2369 |
|
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2370 |
dvd_def_mod ~> dvd_eq_mod_eq_0 |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2371 |
zero_dvd_iff ~> dvd_0_left_iff |
28559 | 2372 |
dvd_0 ~> dvd_0_right |
27651
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2373 |
DIVISION_BY_ZERO_DIV ~> div_by_0 |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2374 |
DIVISION_BY_ZERO_MOD ~> mod_by_0 |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2375 |
mult_div ~> div_mult_self2_is_id |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2376 |
mult_mod ~> mod_mult_self2_is_0 |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2377 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2378 |
* Theory IntDiv: removed many lemmas that are instances of class-based |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2379 |
generalizations (from Divides and Ring_and_Field). INCOMPATIBILITY, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2380 |
rename old lemmas as follows: |
30044 | 2381 |
|
2382 |
dvd_diff -> nat_dvd_diff |
|
2383 |
dvd_zminus_iff -> dvd_minus_iff |
|
30224 | 2384 |
mod_add1_eq -> mod_add_eq |
2385 |
mod_mult1_eq -> mod_mult_right_eq |
|
2386 |
mod_mult1_eq' -> mod_mult_left_eq |
|
2387 |
mod_mult_distrib_mod -> mod_mult_eq |
|
30044 | 2388 |
nat_mod_add_left_eq -> mod_add_left_eq |
2389 |
nat_mod_add_right_eq -> mod_add_right_eq |
|
2390 |
nat_mod_div_trivial -> mod_div_trivial |
|
2391 |
nat_mod_mod_trivial -> mod_mod_trivial |
|
2392 |
zdiv_zadd_self1 -> div_add_self1 |
|
2393 |
zdiv_zadd_self2 -> div_add_self2 |
|
30181 | 2394 |
zdiv_zmult_self1 -> div_mult_self2_is_id |
30044 | 2395 |
zdiv_zmult_self2 -> div_mult_self1_is_id |
2396 |
zdvd_triv_left -> dvd_triv_left |
|
2397 |
zdvd_triv_right -> dvd_triv_right |
|
2398 |
zdvd_zmult_cancel_disj -> dvd_mult_cancel_left |
|
30085 | 2399 |
zmod_eq0_zdvd_iff -> dvd_eq_mod_eq_0[symmetric] |
30044 | 2400 |
zmod_zadd_left_eq -> mod_add_left_eq |
2401 |
zmod_zadd_right_eq -> mod_add_right_eq |
|
2402 |
zmod_zadd_self1 -> mod_add_self1 |
|
2403 |
zmod_zadd_self2 -> mod_add_self2 |
|
30224 | 2404 |
zmod_zadd1_eq -> mod_add_eq |
30044 | 2405 |
zmod_zdiff1_eq -> mod_diff_eq |
2406 |
zmod_zdvd_zmod -> mod_mod_cancel |
|
2407 |
zmod_zmod_cancel -> mod_mod_cancel |
|
2408 |
zmod_zmult_self1 -> mod_mult_self2_is_0 |
|
2409 |
zmod_zmult_self2 -> mod_mult_self1_is_0 |
|
2410 |
zmod_1 -> mod_by_1 |
|
2411 |
zdiv_1 -> div_by_1 |
|
2412 |
zdvd_abs1 -> abs_dvd_iff |
|
2413 |
zdvd_abs2 -> dvd_abs_iff |
|
2414 |
zdvd_refl -> dvd_refl |
|
2415 |
zdvd_trans -> dvd_trans |
|
2416 |
zdvd_zadd -> dvd_add |
|
2417 |
zdvd_zdiff -> dvd_diff |
|
2418 |
zdvd_zminus_iff -> dvd_minus_iff |
|
2419 |
zdvd_zminus2_iff -> minus_dvd_iff |
|
2420 |
zdvd_zmultD -> dvd_mult_right |
|
2421 |
zdvd_zmultD2 -> dvd_mult_left |
|
2422 |
zdvd_zmult_mono -> mult_dvd_mono |
|
2423 |
zdvd_0_right -> dvd_0_right |
|
2424 |
zdvd_0_left -> dvd_0_left_iff |
|
2425 |
zdvd_1_left -> one_dvd |
|
2426 |
zminus_dvd_iff -> minus_dvd_iff |
|
2427 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2428 |
* Theory Rational: 'Fract k 0' now equals '0'. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2429 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2430 |
* The real numbers offer decimal input syntax: 12.34 is translated |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2431 |
into 1234/10^2. This translation is not reversed upon output. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2432 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2433 |
* Theory Library/Polynomial defines an abstract type 'a poly of |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2434 |
univariate polynomials with coefficients of type 'a. In addition to |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2435 |
the standard ring operations, it also supports div and mod. Code |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2436 |
generation is also supported, using list-style constructors. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2437 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2438 |
* Theory Library/Inner_Product defines a class of real_inner for real |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2439 |
inner product spaces, with an overloaded operation inner :: 'a => 'a |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2440 |
=> real. Class real_inner is a subclass of real_normed_vector from |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2441 |
theory RealVector. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2442 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2443 |
* Theory Library/Product_Vector provides instances for the product |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2444 |
type 'a * 'b of several classes from RealVector and Inner_Product. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2445 |
Definitions of addition, subtraction, scalar multiplication, norms, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2446 |
and inner products are included. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2447 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2448 |
* Theory Library/Bit defines the field "bit" of integers modulo 2. In |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2449 |
addition to the field operations, numerals and case syntax are also |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2450 |
supported. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2451 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2452 |
* Theory Library/Diagonalize provides constructive version of Cantor's |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2453 |
first diagonalization argument. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2454 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2455 |
* Theory Library/GCD: Curried operations gcd, lcm (for nat) and zgcd, |
27599 | 2456 |
zlcm (for int); carried together from various gcd/lcm developements in |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2457 |
the HOL Distribution. Constants zgcd and zlcm replace former igcd and |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2458 |
ilcm; corresponding theorems renamed accordingly. INCOMPATIBILITY, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2459 |
may recover tupled syntax as follows: |
27556 | 2460 |
|
2461 |
hide (open) const gcd |
|
2462 |
abbreviation gcd where |
|
2463 |
"gcd == (%(a, b). GCD.gcd a b)" |
|
2464 |
notation (output) |
|
2465 |
GCD.gcd ("gcd '(_, _')") |
|
2466 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2467 |
The same works for lcm, zgcd, zlcm. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2468 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2469 |
* Theory Library/Nat_Infinity: added addition, numeral syntax and more |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2470 |
instantiations for algebraic structures. Removed some duplicate |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2471 |
theorems. Changes in simp rules. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2472 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2473 |
* ML antiquotation @{code} takes a constant as argument and generates |
27651
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2474 |
corresponding code in background and inserts name of the corresponding |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2475 |
resulting ML value/function/datatype constructor binding in place. |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2476 |
All occurrences of @{code} with a single ML block are generated |
16a26996c30e
moved op dvd to theory Ring_and_Field; generalized a couple of lemmas
haftmann
parents:
27599
diff
changeset
|
2477 |
simultaneously. Provides a generic and safe interface for |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2478 |
instrumentalizing code generation. See |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2479 |
src/HOL/Decision_Procs/Ferrack.thy for a more ambitious application. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2480 |
In future you ought to refrain from ad-hoc compiling generated SML |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2481 |
code on the ML toplevel. Note that (for technical reasons) @{code} |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2482 |
cannot refer to constants for which user-defined serializations are |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2483 |
set. Refer to the corresponding ML counterpart directly in that |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2484 |
cases. |
27122 | 2485 |
|
2486 |
* Command 'rep_datatype': instead of theorem names the command now |
|
2487 |
takes a list of terms denoting the constructors of the type to be |
|
2488 |
represented as datatype. The characteristic theorems have to be |
|
2489 |
proven. INCOMPATIBILITY. Also observe that the following theorems |
|
2490 |
have disappeared in favour of existing ones: |
|
2491 |
||
27104
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2492 |
unit_induct ~> unit.induct |
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2493 |
prod_induct ~> prod.induct |
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2494 |
sum_induct ~> sum.induct |
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2495 |
Suc_Suc_eq ~> nat.inject |
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2496 |
Suc_not_Zero Zero_not_Suc ~> nat.distinct |
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2497 |
|
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2498 |
|
27696 | 2499 |
*** HOL-Algebra *** |
2500 |
||
27713
95b36bfe7fc4
New locales for orders and lattices where the equivalence relation is not restricted to equality.
ballarin
parents:
27704
diff
changeset
|
2501 |
* New locales for orders and lattices where the equivalence relation |
30106 | 2502 |
is not restricted to equality. INCOMPATIBILITY: all order and lattice |
2503 |
locales use a record structure with field eq for the equivalence. |
|
27713
95b36bfe7fc4
New locales for orders and lattices where the equivalence relation is not restricted to equality.
ballarin
parents:
27704
diff
changeset
|
2504 |
|
95b36bfe7fc4
New locales for orders and lattices where the equivalence relation is not restricted to equality.
ballarin
parents:
27704
diff
changeset
|
2505 |
* New theory of factorial domains. |
95b36bfe7fc4
New locales for orders and lattices where the equivalence relation is not restricted to equality.
ballarin
parents:
27704
diff
changeset
|
2506 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2507 |
* Units_l_inv and Units_r_inv are now simp rules by default. |
27696 | 2508 |
INCOMPATIBILITY. Simplifier proof that require deletion of l_inv |
2509 |
and/or r_inv will now also require deletion of these lemmas. |
|
2510 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2511 |
* Renamed the following theorems, INCOMPATIBILITY: |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2512 |
|
27696 | 2513 |
UpperD ~> Upper_memD |
2514 |
LowerD ~> Lower_memD |
|
2515 |
least_carrier ~> least_closed |
|
2516 |
greatest_carrier ~> greatest_closed |
|
2517 |
greatest_Lower_above ~> greatest_Lower_below |
|
27717
21bbd410ba04
Generalised polynomial lemmas from cring to ring.
ballarin
parents:
27713
diff
changeset
|
2518 |
one_zero ~> carrier_one_zero |
21bbd410ba04
Generalised polynomial lemmas from cring to ring.
ballarin
parents:
27713
diff
changeset
|
2519 |
one_not_zero ~> carrier_one_not_zero (collision with assumption) |
27696 | 2520 |
|
27793 | 2521 |
|
30849 | 2522 |
*** HOL-Nominal *** |
2523 |
||
30855 | 2524 |
* Nominal datatypes can now contain type-variables. |
2525 |
||
2526 |
* Commands 'nominal_inductive' and 'equivariance' work with local |
|
2527 |
theory targets. |
|
2528 |
||
2529 |
* Nominal primrec can now works with local theory targets and its |
|
2530 |
specification syntax now conforms to the general format as seen in |
|
2531 |
'inductive' etc. |
|
2532 |
||
2533 |
* Method "perm_simp" honours the standard simplifier attributes |
|
2534 |
(no_asm), (no_asm_use) etc. |
|
2535 |
||
2536 |
* The new predicate #* is defined like freshness, except that on the |
|
2537 |
left hand side can be a set or list of atoms. |
|
2538 |
||
2539 |
* Experimental command 'nominal_inductive2' derives strong induction |
|
2540 |
principles for inductive definitions. In contrast to |
|
2541 |
'nominal_inductive', which can only deal with a fixed number of |
|
2542 |
binders, it can deal with arbitrary expressions standing for sets of |
|
2543 |
atoms to be avoided. The only inductive definition we have at the |
|
2544 |
moment that needs this generalisation is the typing rule for Lets in |
|
2545 |
the algorithm W: |
|
2546 |
||
2547 |
Gamma |- t1 : T1 (x,close Gamma T1)::Gamma |- t2 : T2 x#Gamma |
|
2548 |
----------------------------------------------------------------- |
|
2549 |
Gamma |- Let x be t1 in t2 : T2 |
|
2550 |
||
2551 |
In this rule one wants to avoid all the binders that are introduced by |
|
2552 |
"close Gamma T1". We are looking for other examples where this |
|
2553 |
feature might be useful. Please let us know. |
|
30849 | 2554 |
|
2555 |
||
30176
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2556 |
*** HOLCF *** |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2557 |
|
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2558 |
* Reimplemented the simplification procedure for proving continuity |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2559 |
subgoals. The new simproc is extensible; users can declare additional |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2560 |
continuity introduction rules with the attribute [cont2cont]. |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2561 |
|
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2562 |
* The continuity simproc now uses a different introduction rule for |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2563 |
solving continuity subgoals on terms with lambda abstractions. In |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2564 |
some rare cases the new simproc may fail to solve subgoals that the |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2565 |
old one could solve, and "simp add: cont2cont_LAM" may be necessary. |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2566 |
Potential INCOMPATIBILITY. |
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2567 |
|
30847 | 2568 |
* Command 'fixrec': specification syntax now conforms to the general |
30855 | 2569 |
format as seen in 'inductive' etc. See src/HOLCF/ex/Fixrec_ex.thy for |
2570 |
examples. INCOMPATIBILITY. |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2571 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2572 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2573 |
*** ZF *** |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2574 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2575 |
* Proof of Zorn's Lemma for partial orders. |
30176
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2576 |
|
78610979b3c6
add news for HOLCF; fixed some typos and inaccuracies
huffman
parents:
30163
diff
changeset
|
2577 |
|
27246
df85326af57c
* Rules and tactics that read instantiations now demand a proper context;
wenzelm
parents:
27200
diff
changeset
|
2578 |
*** ML *** |
28088
723735f2d73a
* Name bindings in higher specification mechanisms;
wenzelm
parents:
28085
diff
changeset
|
2579 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2580 |
* Multithreading for Poly/ML 5.1/5.2 is no longer supported, only for |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2581 |
Poly/ML 5.2.1 or later. Important note: the TimeLimit facility |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2582 |
depends on multithreading, so timouts will not work before Poly/ML |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2583 |
5.2.1! |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2584 |
|
29161
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
2585 |
* High-level support for concurrent ML programming, see |
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
2586 |
src/Pure/Cuncurrent. The data-oriented model of "future values" is |
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
2587 |
particularly convenient to organize independent functional |
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
2588 |
computations. The concept of "synchronized variables" provides a |
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
2589 |
higher-order interface for components with shared state, avoiding the |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2590 |
delicate details of mutexes and condition variables. (Requires |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2591 |
Poly/ML 5.2.1 or later.) |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2592 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2593 |
* ML bindings produced via Isar commands are stored within the Isar |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2594 |
context (theory or proof). Consequently, commands like 'use' and 'ML' |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2595 |
become thread-safe and work with undo as expected (concerning |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2596 |
top-level bindings, not side-effects on global references). |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2597 |
INCOMPATIBILITY, need to provide proper Isar context when invoking the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2598 |
compiler at runtime; really global bindings need to be given outside a |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2599 |
theory. (Requires Poly/ML 5.2 or later.) |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2600 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2601 |
* Command 'ML_prf' is analogous to 'ML' but works within a proof |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2602 |
context. Top-level ML bindings are stored within the proof context in |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2603 |
a purely sequential fashion, disregarding the nested proof structure. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2604 |
ML bindings introduced by 'ML_prf' are discarded at the end of the |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2605 |
proof. (Requires Poly/ML 5.2 or later.) |
29161
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
2606 |
|
30530 | 2607 |
* Simplified ML attribute and method setup, cf. functions Attrib.setup |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2608 |
and Method.setup, as well as Isar commands 'attribute_setup' and |
30547 | 2609 |
'method_setup'. INCOMPATIBILITY for 'method_setup', need to simplify |
2610 |
existing code accordingly, or use plain 'setup' together with old |
|
2611 |
Method.add_method. |
|
30530 | 2612 |
|
28294 | 2613 |
* Simplified ML oracle interface Thm.add_oracle promotes 'a -> cterm |
2614 |
to 'a -> thm, while results are always tagged with an authentic oracle |
|
2615 |
name. The Isar command 'oracle' is now polymorphic, no argument type |
|
2616 |
is specified. INCOMPATIBILITY, need to simplify existing oracle code |
|
2617 |
accordingly. Note that extra performance may be gained by producing |
|
2618 |
the cterm carefully, avoiding slow Thm.cterm_of. |
|
2619 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2620 |
* Simplified interface for defining document antiquotations via |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2621 |
ThyOutput.antiquotation, ThyOutput.output, and optionally |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2622 |
ThyOutput.maybe_pretty_source. INCOMPATIBILITY, need to simplify user |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2623 |
antiquotations accordingly, see src/Pure/Thy/thy_output.ML for common |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2624 |
examples. |
28099
fb16a07d6580
* Generic Toplevel.add_hook interface allows to analyze the result of
wenzelm
parents:
28089
diff
changeset
|
2625 |
|
30395
f3103bd2b167
* More systematic treatment of long names, abstract name bindings, and name space operations.
wenzelm
parents:
30326
diff
changeset
|
2626 |
* More systematic treatment of long names, abstract name bindings, and |
f3103bd2b167
* More systematic treatment of long names, abstract name bindings, and name space operations.
wenzelm
parents:
30326
diff
changeset
|
2627 |
name space operations. Basic operations on qualified names have been |
30399 | 2628 |
move from structure NameSpace to Long_Name, e.g. Long_Name.base_name, |
30395
f3103bd2b167
* More systematic treatment of long names, abstract name bindings, and name space operations.
wenzelm
parents:
30326
diff
changeset
|
2629 |
Long_Name.append. Old type bstring has been mostly replaced by |
f3103bd2b167
* More systematic treatment of long names, abstract name bindings, and name space operations.
wenzelm
parents:
30326
diff
changeset
|
2630 |
abstract type binding (see structure Binding), which supports precise |
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2631 |
qualification by packages and local theory targets, as well as proper |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2632 |
tracking of source positions. INCOMPATIBILITY, need to wrap old |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2633 |
bstring values into Binding.name, or better pass through abstract |
30399 | 2634 |
bindings everywhere. See further src/Pure/General/long_name.ML, |
30395
f3103bd2b167
* More systematic treatment of long names, abstract name bindings, and name space operations.
wenzelm
parents:
30326
diff
changeset
|
2635 |
src/Pure/General/binding.ML and src/Pure/General/name_space.ML |
f3103bd2b167
* More systematic treatment of long names, abstract name bindings, and name space operations.
wenzelm
parents:
30326
diff
changeset
|
2636 |
|
28089
66ae1926482a
* Result facts now refer to the *full* internal name;
wenzelm
parents:
28088
diff
changeset
|
2637 |
* Result facts (from PureThy.note_thms, ProofContext.note_thms, |
66ae1926482a
* Result facts now refer to the *full* internal name;
wenzelm
parents:
28088
diff
changeset
|
2638 |
LocalTheory.note etc.) now refer to the *full* internal name, not the |
66ae1926482a
* Result facts now refer to the *full* internal name;
wenzelm
parents:
28088
diff
changeset
|
2639 |
bstring as before. INCOMPATIBILITY, not detected by ML type-checking! |
66ae1926482a
* Result facts now refer to the *full* internal name;
wenzelm
parents:
28088
diff
changeset
|
2640 |
|
27287 | 2641 |
* Disposed old type and term read functions (Sign.read_def_typ, |
2642 |
Sign.read_typ, Sign.read_def_terms, Sign.read_term, |
|
2643 |
Thm.read_def_cterms, Thm.read_cterm etc.). INCOMPATIBILITY, should |
|
2644 |
use regular Syntax.read_typ, Syntax.read_term, Syntax.read_typ_global, |
|
27269 | 2645 |
Syntax.read_term_global etc.; see also OldGoals.read_term as last |
2646 |
resort for legacy applications. |
|
2647 |
||
30609
983e8b6e4e69
Disposed old declarations, tactics, tactic combinators that refer to the simpset or claset of an implicit theory;
wenzelm
parents:
30577
diff
changeset
|
2648 |
* Disposed old declarations, tactics, tactic combinators that refer to |
983e8b6e4e69
Disposed old declarations, tactics, tactic combinators that refer to the simpset or claset of an implicit theory;
wenzelm
parents:
30577
diff
changeset
|
2649 |
the simpset or claset of an implicit theory (such as Addsimps, |
983e8b6e4e69
Disposed old declarations, tactics, tactic combinators that refer to the simpset or claset of an implicit theory;
wenzelm
parents:
30577
diff
changeset
|
2650 |
Simp_tac, SIMPSET). INCOMPATIBILITY, should use @{simpset} etc. in |
983e8b6e4e69
Disposed old declarations, tactics, tactic combinators that refer to the simpset or claset of an implicit theory;
wenzelm
parents:
30577
diff
changeset
|
2651 |
embedded ML text, or local_simpset_of with a proper context passed as |
983e8b6e4e69
Disposed old declarations, tactics, tactic combinators that refer to the simpset or claset of an implicit theory;
wenzelm
parents:
30577
diff
changeset
|
2652 |
explicit runtime argument. |
983e8b6e4e69
Disposed old declarations, tactics, tactic combinators that refer to the simpset or claset of an implicit theory;
wenzelm
parents:
30577
diff
changeset
|
2653 |
|
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2654 |
* Rules and tactics that read instantiations (read_instantiate, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2655 |
res_inst_tac, thin_tac, subgoal_tac etc.) now demand a proper proof |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2656 |
context, which is required for parsing and type-checking. Moreover, |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2657 |
the variables are specified as plain indexnames, not string encodings |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2658 |
thereof. INCOMPATIBILITY. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2659 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2660 |
* Generic Toplevel.add_hook interface allows to analyze the result of |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2661 |
transactions. E.g. see src/Pure/ProofGeneral/proof_general_pgip.ML |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2662 |
for theorem dependency output of transactions resulting in a new |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2663 |
theory state. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2664 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2665 |
* ML antiquotations: block-structured compilation context indicated by |
27391 | 2666 |
\<lbrace> ... \<rbrace>; additional antiquotation forms: |
2667 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2668 |
@{binding name} - basic name binding |
27519
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2669 |
@{let ?pat = term} - term abbreviation (HO matching) |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2670 |
@{note name = fact} - fact abbreviation |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2671 |
@{thm fact} - singleton fact (with attributes) |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2672 |
@{thms fact} - general fact (with attributes) |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2673 |
@{lemma prop by method} - singleton goal |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2674 |
@{lemma prop by meth1 meth2} - singleton goal |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2675 |
@{lemma prop1 ... propN by method} - general goal |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2676 |
@{lemma prop1 ... propN by meth1 meth2} - general goal |
59b54d80d2ae
slightly improved @{lemma} (both for latex and ML);
wenzelm
parents:
27485
diff
changeset
|
2677 |
@{lemma (open) ...} - open derivation |
27380 | 2678 |
|
27246
df85326af57c
* Rules and tactics that read instantiations now demand a proper context;
wenzelm
parents:
27200
diff
changeset
|
2679 |
|
27979 | 2680 |
*** System *** |
2681 |
||
28248 | 2682 |
* The Isabelle "emacs" tool provides a specific interface to invoke |
2683 |
Proof General / Emacs, with more explicit failure if that is not |
|
2684 |
installed (the old isabelle-interface script silently falls back on |
|
2685 |
isabelle-process). The PROOFGENERAL_HOME setting determines the |
|
2686 |
installation location of the Proof General distribution. |
|
2687 |
||
27979 | 2688 |
* Isabelle/lib/classes/Pure.jar provides basic support to integrate |
2689 |
the Isabelle process into a JVM/Scala application. See |
|
2690 |
Isabelle/lib/jedit/plugin for a minimal example. (The obsolete Java |
|
2691 |
process wrapper has been discontinued.) |
|
2692 |
||
30845
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2693 |
* Added homegrown Isabelle font with unicode layout, see lib/fonts. |
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2694 |
|
9a887484de53
misc cleanup and rearrangements for Isabelle2009 release;
wenzelm
parents:
30741
diff
changeset
|
2695 |
* Various status messages (with exact source position information) are |
27979 | 2696 |
emitted, if proper markup print mode is enabled. This allows |
2697 |
user-interface components to provide detailed feedback on internal |
|
2698 |
prover operations. |
|
2699 |
||
2700 |
||
27143 | 2701 |
|
27008 | 2702 |
New in Isabelle2008 (June 2008) |
2703 |
------------------------------- |
|
25464
0ca80ce89001
moved new NEWS from Isabelle2007 to this Isabelle version'';
wenzelm
parents:
25459
diff
changeset
|
2704 |
|
25522 | 2705 |
*** General *** |
2706 |
||
27061 | 2707 |
* The Isabelle/Isar Reference Manual (isar-ref) has been reorganized |
2708 |
and updated, with formally checked references as hyperlinks. |
|
2709 |
||
25994 | 2710 |
* Theory loader: use_thy (and similar operations) no longer set the |
2711 |
implicit ML context, which was occasionally hard to predict and in |
|
2712 |
conflict with concurrency. INCOMPATIBILITY, use ML within Isar which |
|
2713 |
provides a proper context already. |
|
2714 |
||
26323
73efc70edeef
theory loader: discontinued *attached* ML scripts;
wenzelm
parents:
26315
diff
changeset
|
2715 |
* Theory loader: old-style ML proof scripts being *attached* to a thy |
73efc70edeef
theory loader: discontinued *attached* ML scripts;
wenzelm
parents:
26315
diff
changeset
|
2716 |
file are no longer supported. INCOMPATIBILITY, regular 'uses' and |
73efc70edeef
theory loader: discontinued *attached* ML scripts;
wenzelm
parents:
26315
diff
changeset
|
2717 |
'use' within a theory file will do the job. |
73efc70edeef
theory loader: discontinued *attached* ML scripts;
wenzelm
parents:
26315
diff
changeset
|
2718 |
|
26650 | 2719 |
* Name space merge now observes canonical order, i.e. the second space |
2720 |
is inserted into the first one, while existing entries in the first |
|
26659 | 2721 |
space take precedence. INCOMPATIBILITY in rare situations, may try to |
26650 | 2722 |
swap theory imports. |
2723 |
||
27067 | 2724 |
* Syntax: symbol \<chi> is now considered a letter. Potential |
2725 |
INCOMPATIBILITY in identifier syntax etc. |
|
2726 |
||
2727 |
* Outer syntax: string tokens no longer admit escaped white space, |
|
2728 |
which was an accidental (undocumented) feature. INCOMPATIBILITY, use |
|
2729 |
white space without escapes. |
|
2730 |
||
2731 |
* Outer syntax: string tokens may contain arbitrary character codes |
|
2732 |
specified via 3 decimal digits (as in SML). E.g. "foo\095bar" for |
|
2733 |
"foo_bar". |
|
2734 |
||
25522 | 2735 |
|
25502 | 2736 |
*** Pure *** |
2737 |
||
26718 | 2738 |
* Context-dependent token translations. Default setup reverts locally |
2739 |
fixed variables, and adds hilite markup for undeclared frees. |
|
2740 |
||
26681 | 2741 |
* Unused theorems can be found using the new command 'unused_thms'. |
2742 |
There are three ways of invoking it: |
|
2743 |
||
2744 |
(1) unused_thms |
|
2745 |
Only finds unused theorems in the current theory. |
|
2746 |
||
2747 |
(2) unused_thms thy_1 ... thy_n - |
|
2748 |
Finds unused theorems in the current theory and all of its ancestors, |
|
2749 |
excluding the theories thy_1 ... thy_n and all of their ancestors. |
|
2750 |
||
2751 |
(3) unused_thms thy_1 ... thy_n - thy'_1 ... thy'_m |
|
2752 |
Finds unused theorems in the theories thy'_1 ... thy'_m and all of |
|
2753 |
their ancestors, excluding the theories thy_1 ... thy_n and all of |
|
2754 |
their ancestors. |
|
2755 |
||
26718 | 2756 |
In order to increase the readability of the list produced by |
2757 |
unused_thms, theorems that have been created by a particular instance |
|
26874 | 2758 |
of a theory command such as 'inductive' or 'function' are considered |
2759 |
to belong to the same "group", meaning that if at least one theorem in |
|
26718 | 2760 |
this group is used, the other theorems in the same group are no longer |
2761 |
reported as unused. Moreover, if all theorems in the group are |
|
2762 |
unused, only one theorem in the group is displayed. |
|
2763 |
||
2764 |
Note that proof objects have to be switched on in order for |
|
2765 |
unused_thms to work properly (i.e. !proofs must be >= 1, which is |
|
26874 | 2766 |
usually the case when using Proof General with the default settings). |
26681 | 2767 |
|
26650 | 2768 |
* Authentic naming of facts disallows ad-hoc overwriting of previous |
2769 |
theorems within the same name space. INCOMPATIBILITY, need to remove |
|
2770 |
duplicate fact bindings, or even accidental fact duplications. Note |
|
2771 |
that tools may maintain dynamically scoped facts systematically, using |
|
2772 |
PureThy.add_thms_dynamic. |
|
2773 |
||
26660 | 2774 |
* Command 'hide' now allows to hide from "fact" name space as well. |
2775 |
||
26496
49ae9456eba9
purely functional setup of claset/simpset/clasimpset;
wenzelm
parents:
26495
diff
changeset
|
2776 |
* Eliminated destructive theorem database, simpset, claset, and |
49ae9456eba9
purely functional setup of claset/simpset/clasimpset;
wenzelm
parents:
26495
diff
changeset
|
2777 |
clasimpset. Potential INCOMPATIBILITY, really need to observe linear |
49ae9456eba9
purely functional setup of claset/simpset/clasimpset;
wenzelm
parents:
26495
diff
changeset
|
2778 |
update of theories within ML code. |
26479 | 2779 |
|
26955
ebbaa935eae0
* Eliminated theory ProtoPure and CPure, leaving just one Pure theory.
wenzelm
parents:
26925
diff
changeset
|
2780 |
* Eliminated theory ProtoPure and CPure, leaving just one Pure theory. |
ebbaa935eae0
* Eliminated theory ProtoPure and CPure, leaving just one Pure theory.
wenzelm
parents:
26925
diff
changeset
|
2781 |
INCOMPATIBILITY, object-logics depending on former Pure require |
ebbaa935eae0
* Eliminated theory ProtoPure and CPure, leaving just one Pure theory.
wenzelm
parents:
26925
diff
changeset
|
2782 |
additional setup PureThy.old_appl_syntax_setup; object-logics |
ebbaa935eae0
* Eliminated theory ProtoPure and CPure, leaving just one Pure theory.
wenzelm
parents:
26925
diff
changeset
|
2783 |
depending on former CPure need to refer to Pure. |
26650 | 2784 |
|
26495 | 2785 |
* Commands 'use' and 'ML' are now purely functional, operating on |
26479 | 2786 |
theory/local_theory. Removed former 'ML_setup' (on theory), use 'ML' |
2787 |
instead. Added 'ML_val' as mere diagnostic replacement for 'ML'. |
|
2788 |
INCOMPATIBILITY. |
|
2789 |
||
26874 | 2790 |
* Command 'setup': discontinued implicit version with ML reference. |
26434 | 2791 |
|
25970
9053fd546501
* Default settings: PROOFGENERAL_OPTIONS no longer impose xemacs here;
wenzelm
parents:
25961
diff
changeset
|
2792 |
* Instantiation target allows for simultaneous specification of class |
9053fd546501
* Default settings: PROOFGENERAL_OPTIONS no longer impose xemacs here;
wenzelm
parents:
25961
diff
changeset
|
2793 |
instance operations together with an instantiation proof. |
9053fd546501
* Default settings: PROOFGENERAL_OPTIONS no longer impose xemacs here;
wenzelm
parents:
25961
diff
changeset
|
2794 |
Type-checking phase allows to refer to class operations uniformly. |
27067 | 2795 |
See src/HOL/Complex/Complex.thy for an Isar example and |
2796 |
src/HOL/Library/Eval.thy for an ML example. |
|
25502 | 2797 |
|
26201
d3363a854708
indexing literal facts: exclude background context;
wenzelm
parents:
26197
diff
changeset
|
2798 |
* Indexing of literal facts: be more serious about including only |
d3363a854708
indexing literal facts: exclude background context;
wenzelm
parents:
26197
diff
changeset
|
2799 |
facts from the visible specification/proof context, but not the |
d3363a854708
indexing literal facts: exclude background context;
wenzelm
parents:
26197
diff
changeset
|
2800 |
background context (locale etc.). Affects `prop` notation and method |
d3363a854708
indexing literal facts: exclude background context;
wenzelm
parents:
26197
diff
changeset
|
2801 |
"fact". INCOMPATIBILITY: need to name facts explicitly in rare |
d3363a854708
indexing literal facts: exclude background context;
wenzelm
parents:
26197
diff
changeset
|
2802 |
situations. |
d3363a854708
indexing literal facts: exclude background context;
wenzelm
parents:
26197
diff
changeset
|
2803 |
|
26925
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2804 |
* Method "cases", "induct", "coinduct": removed obsolete/undocumented |
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2805 |
"(open)" option, which used to expose internal bound variables to the |
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2806 |
proof text. |
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2807 |
|
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2808 |
* Isar statements: removed obsolete case "rule_context". |
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2809 |
INCOMPATIBILITY, better use explicit fixes/assumes. |
ce964f0df281
* Method "cases", "induct", "coinduct": removed obsolete "(open)" option;
wenzelm
parents:
26920
diff
changeset
|
2810 |
|
26874 | 2811 |
* Locale proofs: default proof step now includes 'unfold_locales'; |
2812 |
hence 'proof' without argument may be used to unfold locale |
|
2813 |
predicates. |
|
26765 | 2814 |
|
2815 |
||
26762 | 2816 |
*** Document preparation *** |
2817 |
||
26914 | 2818 |
* Simplified pdfsetup.sty: color/hyperref is used unconditionally for |
2819 |
both pdf and dvi (hyperlinks usually work in xdvi as well); removed |
|
2820 |
obsolete thumbpdf setup (contemporary PDF viewers do this on the |
|
2821 |
spot); renamed link color from "darkblue" to "linkcolor" (default |
|
26920 | 2822 |
value unchanged, can be redefined via \definecolor); no longer sets |
2823 |
"a4paper" option (unnecessary or even intrusive). |
|
26914 | 2824 |
|
27008 | 2825 |
* Antiquotation @{lemma A method} proves proposition A by the given |
2826 |
method (either a method name or a method name plus (optional) method |
|
2827 |
arguments in parentheses) and prints A just like @{prop A}. |
|
26762 | 2828 |
|
2829 |
||
25464
0ca80ce89001
moved new NEWS from Isabelle2007 to this Isabelle version'';
wenzelm
parents:
25459
diff
changeset
|
2830 |
*** HOL *** |
0ca80ce89001
moved new NEWS from Isabelle2007 to this Isabelle version'';
wenzelm
parents:
25459
diff
changeset
|
2831 |
|
27067 | 2832 |
* New primrec package. Specification syntax conforms in style to |
2833 |
definition/function/.... No separate induction rule is provided. The |
|
2834 |
"primrec" command distinguishes old-style and new-style specifications |
|
2835 |
by syntax. The former primrec package is now named OldPrimrecPackage. |
|
2836 |
When adjusting theories, beware: constants stemming from new-style |
|
2837 |
primrec specifications have authentic syntax. |
|
2838 |
||
2839 |
* Metis prover is now an order of magnitude faster, and also works |
|
2840 |
with multithreading. |
|
2841 |
||
2842 |
* Metis: the maximum number of clauses that can be produced from a |
|
2843 |
theorem is now given by the attribute max_clauses. Theorems that |
|
2844 |
exceed this number are ignored, with a warning printed. |
|
2845 |
||
2846 |
* Sledgehammer no longer produces structured proofs by default. To |
|
2847 |
enable, declare [[sledgehammer_full = true]]. Attributes |
|
2848 |
reconstruction_modulus, reconstruction_sorts renamed |
|
2849 |
sledgehammer_modulus, sledgehammer_sorts. INCOMPATIBILITY. |
|
2850 |
||
27104
791607529f6d
rep_datatype command now takes list of constructors as input arguments
haftmann
parents:
27067
diff
changeset
|
2851 |
* Method "induct_scheme" derives user-specified induction rules |
27067 | 2852 |
from well-founded induction and completeness of patterns. This factors |
2853 |
out some operations that are done internally by the function package |
|
2854 |
and makes them available separately. See |
|
2855 |
src/HOL/ex/Induction_Scheme.thy for examples. |
|
2856 |
||
2857 |
* More flexible generation of measure functions for termination |
|
2858 |
proofs: Measure functions can be declared by proving a rule of the |
|
2859 |
form "is_measure f" and giving it the [measure_function] attribute. |
|
2860 |
The "is_measure" predicate is logically meaningless (always true), and |
|
2861 |
just guides the heuristic. To find suitable measure functions, the |
|
2862 |
termination prover sets up the goal "is_measure ?f" of the appropriate |
|
2863 |
type and generates all solutions by prolog-style backwards proof using |
|
2864 |
the declared rules. |
|
2865 |
||
2866 |
This setup also deals with rules like |
|
2867 |
||
2868 |
"is_measure f ==> is_measure (list_size f)" |
|
2869 |
||
2870 |
which accommodates nested datatypes that recurse through lists. |
|
2871 |
Similar rules are predeclared for products and option types. |
|
2872 |
||
26964
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2873 |
* Turned the type of sets "'a set" into an abbreviation for "'a => bool" |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2874 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2875 |
INCOMPATIBILITIES: |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2876 |
|
27008 | 2877 |
- Definitions of overloaded constants on sets have to be replaced by |
2878 |
definitions on => and bool. |
|
26964
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2879 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2880 |
- Some definitions of overloaded operators on sets can now be proved |
27008 | 2881 |
using the definitions of the operators on => and bool. Therefore, |
2882 |
the following theorems have been renamed: |
|
26964
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2883 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2884 |
subset_def -> subset_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2885 |
psubset_def -> psubset_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2886 |
set_diff_def -> set_diff_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2887 |
Compl_def -> Compl_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2888 |
Sup_set_def -> Sup_set_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2889 |
Inf_set_def -> Inf_set_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2890 |
sup_set_def -> sup_set_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2891 |
inf_set_def -> inf_set_eq |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2892 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2893 |
- Due to the incompleteness of the HO unification algorithm, some |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2894 |
rules such as subst may require manual instantiation, if some of |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2895 |
the unknowns in the rule is a set. |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2896 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2897 |
- Higher order unification and forward proofs: |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2898 |
The proof pattern |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2899 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2900 |
have "P (S::'a set)" <...> |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2901 |
then have "EX S. P S" .. |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2902 |
|
27008 | 2903 |
no longer works (due to the incompleteness of the HO unification |
2904 |
algorithm) and must be replaced by the pattern |
|
26964
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2905 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2906 |
have "EX S. P S" |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2907 |
proof |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2908 |
show "P S" <...> |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2909 |
qed |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2910 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2911 |
- Calculational reasoning with subst (or similar rules): |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2912 |
The proof pattern |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2913 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2914 |
have "P (S::'a set)" <...> |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2915 |
also have "S = T" <...> |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2916 |
finally have "P T" . |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2917 |
|
27008 | 2918 |
no longer works (for similar reasons as the previous example) and |
2919 |
must be replaced by something like |
|
26964
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2920 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2921 |
have "P (S::'a set)" <...> |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2922 |
moreover have "S = T" <...> |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2923 |
ultimately have "P T" by simp |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2924 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2925 |
- Tactics or packages written in ML code: |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2926 |
Code performing pattern matching on types via |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2927 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2928 |
Type ("set", [T]) => ... |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2929 |
|
27008 | 2930 |
must be rewritten. Moreover, functions like strip_type or |
2931 |
binder_types no longer return the right value when applied to a |
|
2932 |
type of the form |
|
26964
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2933 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2934 |
T1 => ... => Tn => U => bool |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2935 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2936 |
rather than |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2937 |
|
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2938 |
T1 => ... => Tn => U set |
df1f238a05f7
Added entry explaining incompatibilities introduced by replacing sets by predicates.
berghofe
parents:
26955
diff
changeset
|
2939 |
|
26874 | 2940 |
* Merged theories Wellfounded_Recursion, Accessible_Part and |
27067 | 2941 |
Wellfounded_Relations to theory Wellfounded. |
26748
4d51ddd6aa5c
Merged theories about wellfoundedness into one: Wellfounded.thy
krauss
parents:
26724
diff
changeset
|
2942 |
|
26513 | 2943 |
* Explicit class "eq" for executable equality. INCOMPATIBILITY. |
2944 |
||
26874 | 2945 |
* Class finite no longer treats UNIV as class parameter. Use class |
2946 |
enum from theory Library/Enum instead to achieve a similar effect. |
|
26445 | 2947 |
INCOMPATIBILITY. |
2948 |
||
26874 | 2949 |
* Theory List: rule list_induct2 now has explicitly named cases "Nil" |
2950 |
and "Cons". INCOMPATIBILITY. |
|
2951 |
||
26422
d5883907c514
HOL (and FOL): renamed variables in rules imp_elim and swap;
wenzelm
parents:
26401
diff
changeset
|
2952 |
* HOL (and FOL): renamed variables in rules imp_elim and swap. |
d5883907c514
HOL (and FOL): renamed variables in rules imp_elim and swap;
wenzelm
parents:
26401
diff
changeset
|
2953 |
Potential INCOMPATIBILITY. |
d5883907c514
HOL (and FOL): renamed variables in rules imp_elim and swap;
wenzelm
parents:
26401
diff
changeset
|
2954 |
|
26874 | 2955 |
* Theory Product_Type: duplicated lemmas split_Pair_apply and |
2956 |
injective_fst_snd removed, use split_eta and prod_eqI instead. |
|
2957 |
Renamed upd_fst to apfst and upd_snd to apsnd. INCOMPATIBILITY. |
|
26355 | 2958 |
|
26335
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2959 |
* Theory Nat: removed redundant lemmas that merely duplicate lemmas of |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2960 |
the same name in theory Orderings: |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2961 |
|
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2962 |
less_trans |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2963 |
less_linear |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2964 |
le_imp_less_or_eq |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2965 |
le_less_trans |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2966 |
less_le_trans |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2967 |
less_not_sym |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2968 |
less_asym |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2969 |
|
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2970 |
Renamed less_imp_le to less_imp_le_nat, and less_irrefl to |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2971 |
less_irrefl_nat. Potential INCOMPATIBILITY due to more general types |
961bbcc9d85b
removed redundant Nat.less_not_sym, Nat.less_asym;
wenzelm
parents:
26333
diff
changeset
|
2972 |
and different variable names. |
26315
cb3badaa192e
removed redundant less_trans, less_linear, le_imp_less_or_eq, le_less_trans, less_le_trans (cf. Orderings.thy);
wenzelm
parents:
26231
diff
changeset
|
2973 |
|
26231 | 2974 |
* Library/Option_ord.thy: Canonical order on option type. |
2975 |
||
27008 | 2976 |
* Library/RBT.thy: Red-black trees, an efficient implementation of |
2977 |
finite maps. |
|
26197 | 2978 |
|
26231 | 2979 |
* Library/Countable.thy: Type class for countable types. |
2980 |
||
26180
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2981 |
* Theory Int: The representation of numerals has changed. The infix |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2982 |
operator BIT and the bit datatype with constructors B0 and B1 have |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2983 |
disappeared. INCOMPATIBILITY, use "Int.Bit0 x" and "Int.Bit1 y" in |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2984 |
place of "x BIT bit.B0" and "y BIT bit.B1", respectively. Theorems |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2985 |
involving BIT, B0, or B1 have been renamed with "Bit0" or "Bit1" |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2986 |
accordingly. |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2987 |
|
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2988 |
* Theory Nat: definition of <= and < on natural numbers no longer |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2989 |
depend on well-founded relations. INCOMPATIBILITY. Definitions |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2990 |
le_def and less_def have disappeared. Consider lemmas not_less |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2991 |
[symmetric, where ?'a = nat] and less_eq [symmetric] instead. |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2992 |
|
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2993 |
* Theory Finite_Set: locales ACf, ACe, ACIf, ACIfSL and ACIfSLlin |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2994 |
(whose purpose mainly is for various fold_set functionals) have been |
26874 | 2995 |
abandoned in favor of the existing algebraic classes |
26180
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2996 |
ab_semigroup_mult, comm_monoid_mult, ab_semigroup_idem_mult, |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
2997 |
lower_semilattice (resp. upper_semilattice) and linorder. |
26139 | 2998 |
INCOMPATIBILITY. |
26041
c2e15e65165f
locales ACf, ACIf, ACIfSL and ACIfSLlin have been abandoned in favour of the existing algebraic classes ab_semigroup_mult, ab_semigroup_idem_mult, lower_semilattice (resp. uper_semilattice) and linorder
haftmann
parents:
26013
diff
changeset
|
2999 |
|
26180
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3000 |
* Theory Transitive_Closure: induct and cases rules now declare proper |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3001 |
case_names ("base" and "step"). INCOMPATIBILITY. |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3002 |
|
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3003 |
* Theorem Inductive.lfp_ordinal_induct generalized to complete |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3004 |
lattices. The form set-specific version is available as |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3005 |
Inductive.lfp_ordinal_induct_set. |
26013
8764a1f1253b
Theorem Inductive.lfp_ordinal_induct generalized to complete lattices
haftmann
parents:
26006
diff
changeset
|
3006 |
|
26874 | 3007 |
* Renamed theorems "power.simps" to "power_int.simps". |
27067 | 3008 |
INCOMPATIBILITY. |
25961 | 3009 |
|
26180
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3010 |
* Class semiring_div provides basic abstract properties of semirings |
25942 | 3011 |
with division and modulo operations. Subsumes former class dvd_mod. |
3012 |
||
26180
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3013 |
* Merged theories IntDef, Numeral and IntArith into unified theory |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3014 |
Int. INCOMPATIBILITY. |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3015 |
|
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3016 |
* Theory Library/Code_Index: type "index" now represents natural |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3017 |
numbers rather than integers. INCOMPATIBILITY. |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3018 |
|
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3019 |
* New class "uminus" with operation "uminus" (split of from class |
cc85eaab20f6
Transitive_Closure: induct and cases rules now declare proper case_names;
wenzelm
parents:
26139
diff
changeset
|
3020 |
"minus" which now only has operation "minus", binary). |
25919
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
haftmann
parents:
25900
diff
changeset
|
3021 |
INCOMPATIBILITY. |
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
haftmann
parents:
25900
diff
changeset
|
3022 |
|
25522 | 3023 |
* Constants "card", "internal_split", "option_map" now with authentic |
25919
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
haftmann
parents:
25900
diff
changeset
|
3024 |
syntax. INCOMPATIBILITY. |
25522 | 3025 |
|
3026 |
* Definitions subset_def, psubset_def, set_diff_def, Compl_def, |
|
3027 |
le_bool_def, less_bool_def, le_fun_def, less_fun_def, inf_bool_def, |
|
3028 |
sup_bool_def, Inf_bool_def, Sup_bool_def, inf_fun_def, sup_fun_def, |
|
3029 |
Inf_fun_def, Sup_fun_def, inf_set_def, sup_set_def, Inf_set_def, |
|
3030 |
Sup_set_def, le_def, less_def, option_map_def now with object |
|
25919
8b1c0d434824
joined theories IntDef, Numeral, IntArith to theory Int
haftmann
parents:
25900
diff
changeset
|
3031 |
equality. INCOMPATIBILITY. |
25464
0ca80ce89001
moved new NEWS from Isabelle2007 to this Isabelle version'';
wenzelm
parents:
25459
diff
changeset
|
3032 |
|
25705 | 3033 |
* Records. Removed K_record, and replaced it by pure lambda term |
25726
9728f319ffc6
* Metis prover an order of magnitude faster, works with multithreading.
wenzelm
parents:
25712
diff
changeset
|
3034 |
%x. c. The simplifier setup is now more robust against eta expansion. |
25705 | 3035 |
INCOMPATIBILITY: in cases explicitly referring to K_record. |
25464
0ca80ce89001
moved new NEWS from Isabelle2007 to this Isabelle version'';
wenzelm
parents:
25459
diff
changeset
|
3036 |
|
27067 | 3037 |
* Library/Multiset: {#a, b, c#} abbreviates {#a#} + {#b#} + {#c#}. |
3038 |
||
3039 |
* Library/ListVector: new theory of arithmetic vector operations. |
|
3040 |
||
3041 |
* Library/Order_Relation: new theory of various orderings as sets of |
|
3042 |
pairs. Defines preorders, partial orders, linear orders and |
|
3043 |
well-orders on sets and on types. |
|
26877 | 3044 |
|
25726
9728f319ffc6
* Metis prover an order of magnitude faster, works with multithreading.
wenzelm
parents:
25712
diff
changeset
|
3045 |
|
26197 | 3046 |
*** ZF *** |
3047 |
||
26874 | 3048 |
* Renamed some theories to allow to loading both ZF and HOL in the |
3049 |
same session: |
|
3050 |
||
3051 |
Datatype -> Datatype_ZF |
|
3052 |
Inductive -> Inductive_ZF |
|
3053 |
Int -> Int_ZF |
|
3054 |
IntDiv -> IntDiv_ZF |
|
3055 |
Nat -> Nat_ZF |
|
3056 |
List -> List_ZF |
|
3057 |
Main -> Main_ZF |
|
3058 |
||
3059 |
INCOMPATIBILITY: ZF theories that import individual theories below |
|
3060 |
Main might need to be adapted. Regular theory Main is still |
|
3061 |
available, as trivial extension of Main_ZF. |
|
26197 | 3062 |
|
3063 |
||
25737
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3064 |
*** ML *** |
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3065 |
|
27067 | 3066 |
* ML within Isar: antiquotation @{const name} or @{const |
3067 |
name(typargs)} produces statically-checked Const term. |
|
3068 |
||
26401
e7a94081dce7
Functor NamedThmsFun: data is available to the user as dynamic fact;
wenzelm
parents:
26387
diff
changeset
|
3069 |
* Functor NamedThmsFun: data is available to the user as dynamic fact |
26724
ff6ff3a9010e
NamedThmsFun: removed obsolete print command -- facts are accesible via dynamic name;
wenzelm
parents:
26718
diff
changeset
|
3070 |
(of the same name). Removed obsolete print command. |
26401
e7a94081dce7
Functor NamedThmsFun: data is available to the user as dynamic fact;
wenzelm
parents:
26387
diff
changeset
|
3071 |
|
27067 | 3072 |
* Removed obsolete "use_legacy_bindings" function. |
26188 | 3073 |
|
25737
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3074 |
* The ``print mode'' is now a thread-local value derived from a global |
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3075 |
template (the former print_mode reference), thus access becomes |
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3076 |
non-critical. The global print_mode reference is for session |
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3077 |
management only; user-code should use print_mode_value, |
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3078 |
print_mode_active, PrintMode.setmp etc. INCOMPATIBILITY. |
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3079 |
|
26874 | 3080 |
* Functions system/system_out provide a robust way to invoke external |
29161
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
3081 |
shell commands, with propagation of interrupts (requires Poly/ML |
9903e84a9c9c
* Proofs of are run in parallel on multi-core systems;
wenzelm
parents:
29145
diff
changeset
|
3082 |
5.2.1). Do not use OS.Process.system etc. from the basis library! |
26222
edf6473ac9e9
* system/system_out provides a robust way to invoke external shell
wenzelm
parents:
26218
diff
changeset
|
3083 |
|
25737
84c92fc48e36
``print mode'' is now a thread-local value derived from a global template;
wenzelm
parents:
25726
diff
changeset
|
3084 |
|
25626
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3085 |
*** System *** |
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3086 |
|
25971 | 3087 |
* Default settings: PROOFGENERAL_OPTIONS no longer impose xemacs --- |
3088 |
in accordance with Proof General 3.7, which prefers GNU emacs. |
|
25970
9053fd546501
* Default settings: PROOFGENERAL_OPTIONS no longer impose xemacs here;
wenzelm
parents:
25961
diff
changeset
|
3089 |
|
25626
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3090 |
* isatool tty runs Isabelle process with plain tty interaction; |
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3091 |
optional line editor may be specified via ISABELLE_LINE_EDITOR |
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3092 |
setting, the default settings attempt to locate "ledit" and "rlwrap". |
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3093 |
|
25651 | 3094 |
* isatool browser now works with Cygwin as well, using general |
3095 |
"javapath" function defined in Isabelle process environment. |
|
3096 |
||
27067 | 3097 |
* YXML notation provides a simple and efficient alternative to |
3098 |
standard XML transfer syntax. See src/Pure/General/yxml.ML and |
|
3099 |
isatool yxml as described in the Isabelle system manual. |
|
25651 | 3100 |
|
25652 | 3101 |
* JVM class isabelle.IsabelleProcess (located in Isabelle/lib/classes) |
25651 | 3102 |
provides general wrapper for managing an Isabelle process in a robust |
3103 |
fashion, with ``cooked'' output from stdin/stderr. |
|
3104 |
||
25855 | 3105 |
* Rudimentary Isabelle plugin for jEdit (see Isabelle/lib/jedit), |
3106 |
based on Isabelle/JVM process wrapper (see Isabelle/lib/classes). |
|
3107 |
||
27067 | 3108 |
* Removed obsolete THIS_IS_ISABELLE_BUILD feature. NB: the documented |
3109 |
way of changing the user's settings is via |
|
3110 |
ISABELLE_HOME_USER/etc/settings, which is a fully featured bash |
|
3111 |
script. |
|
3112 |
||
3113 |
* Multithreading.max_threads := 0 refers to the number of actual CPU |
|
3114 |
cores of the underlying machine, which is a good starting point for |
|
3115 |
optimal performance tuning. The corresponding usedir option -M allows |
|
3116 |
"max" as an alias for "0". WARNING: does not work on certain versions |
|
3117 |
of Mac OS (with Poly/ML 5.1). |
|
3118 |
||
3119 |
* isabelle-process: non-ML sessions are run with "nice", to reduce the |
|
3120 |
adverse effect of Isabelle flooding interactive front-ends (notably |
|
3121 |
ProofGeneral / XEmacs). |
|
3122 |
||
25626
3000965b1fdf
* isatool tty runs Isabelle process with plain tty interaction;
wenzelm
parents:
25609
diff
changeset
|
3123 |
|
25464
0ca80ce89001
moved new NEWS from Isabelle2007 to this Isabelle version'';
wenzelm
parents:
25459
diff
changeset
|
3124 |
|
25429 | 3125 |
New in Isabelle2007 (November 2007) |
3126 |
----------------------------------- |
|
17754
58a306d9f736
* Command 'find_theorems': support * wildcard in name: criterion.
wenzelm
parents:
17725
diff
changeset
|
3127 |
|
58a306d9f736
* Command 'find_theorems': support * wildcard in name: criterion.
wenzelm
parents:
17725
diff
changeset
|
3128 |
*** General *** |
58a306d9f736
* Command 'find_theorems': support * wildcard in name: criterion.
wenzelm
parents:
17725
diff
changeset
|
3129 |
|
22826 | 3130 |
* More uniform information about legacy features, notably a |
3131 |
warning/error of "Legacy feature: ...", depending on the state of the |
|
23367 | 3132 |
tolerate_legacy_features flag (default true). FUTURE INCOMPATIBILITY: |
3133 |
legacy features will disappear eventually. |
|
22826 | 3134 |
|
17918
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3135 |
* Theory syntax: the header format ``theory A = B + C:'' has been |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3136 |
discontinued in favour of ``theory A imports B C begin''. Use isatool |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3137 |
fixheaders to convert existing theory files. INCOMPATIBILITY. |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3138 |
|
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3139 |
* Theory syntax: the old non-Isar theory file format has been |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3140 |
discontinued altogether. Note that ML proof scripts may still be used |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3141 |
with Isar theories; migration is usually quite simple with the ML |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3142 |
function use_legacy_bindings. INCOMPATIBILITY. |
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3143 |
|
22871 | 3144 |
* Theory syntax: some popular names (e.g. 'class', 'declaration', |
3145 |
'fun', 'help', 'if') are now keywords. INCOMPATIBILITY, use double |
|
3146 |
quotes. |
|
19814
faa698d46686
* Theory syntax: some popular names (e.g. "class", "if") are now keywords.
wenzelm
parents:
19783
diff
changeset
|
3147 |
|
23888
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3148 |
* Theory loader: be more serious about observing the static theory |
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3149 |
header specifications (including optional directories), but not the |
24172
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3150 |
accidental file locations of previously successful loads. The strict |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3151 |
update policy of former update_thy is now already performed by |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3152 |
use_thy, so the former has been removed; use_thys updates several |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3153 |
theories simultaneously, just as 'imports' within a theory header |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3154 |
specification, but without merging the results. Potential |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3155 |
INCOMPATIBILITY: may need to refine theory headers and commands |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3156 |
ROOT.ML which depend on load order. |
23888
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3157 |
|
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3158 |
* Theory loader: optional support for content-based file |
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3159 |
identification, instead of the traditional scheme of full physical |
23889 | 3160 |
path plus date stamp; configured by the ISABELLE_FILE_IDENT setting |
23888
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3161 |
(cf. the system manual). The new scheme allows to work with |
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3162 |
non-finished theories in persistent session images, such that source |
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3163 |
files may be moved later on without requiring reloads. |
babe337cce2d
* Theory loader: be more serious about observing the static theory header specifications;
wenzelm
parents:
23881
diff
changeset
|
3164 |
|
24187
8bdf5ca5871f
* Theory loader: old-style ML proof scripts are considered a legacy feature;
wenzelm
parents:
24172
diff
changeset
|
3165 |
* Theory loader: old-style ML proof scripts being *attached* to a thy |
8bdf5ca5871f
* Theory loader: old-style ML proof scripts are considered a legacy feature;
wenzelm
parents:
24172
diff
changeset
|
3166 |
file (with the same base name as the theory) are considered a legacy |
24800 | 3167 |
feature, which will disappear eventually. Even now, the theory loader |
3168 |
no longer maintains dependencies on such files. |
|
3169 |
||
3170 |
* Syntax: the scope for resolving ambiguities via type-inference is |
|
3171 |
now limited to individual terms, instead of whole simultaneous |
|
24234
4714e04fb8e9
* Syntax: scope for resolving ambiguities via type-inference is now limited to individual terms;
wenzelm
parents:
24213
diff
changeset
|
3172 |
specifications as before. This greatly reduces the complexity of the |
4714e04fb8e9
* Syntax: scope for resolving ambiguities via type-inference is now limited to individual terms;
wenzelm
parents:
24213
diff
changeset
|
3173 |
syntax module and improves flexibility by separating parsing and |
4714e04fb8e9
* Syntax: scope for resolving ambiguities via type-inference is now limited to individual terms;
wenzelm
parents:
24213
diff
changeset
|
3174 |
type-checking. INCOMPATIBILITY: additional type-constraints (explicit |
4714e04fb8e9
* Syntax: scope for resolving ambiguities via type-inference is now limited to individual terms;
wenzelm
parents:
24213
diff
changeset
|
3175 |
'fixes' etc.) are required in rare situations. |
4714e04fb8e9
* Syntax: scope for resolving ambiguities via type-inference is now limited to individual terms;
wenzelm
parents:
24213
diff
changeset
|
3176 |
|
25034 | 3177 |
* Syntax: constants introduced by new-style packages ('definition', |
3178 |
'abbreviation' etc.) are passed through the syntax module in |
|
3179 |
``authentic mode''. This means that associated mixfix annotations |
|
3180 |
really stick to such constants, independently of potential name space |
|
3181 |
ambiguities introduced later on. INCOMPATIBILITY: constants in parse |
|
3182 |
trees are represented slightly differently, may need to adapt syntax |
|
3183 |
translations accordingly. Use CONST marker in 'translations' and |
|
3184 |
@{const_syntax} antiquotation in 'parse_translation' etc. |
|
3185 |
||
17981
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3186 |
* Legacy goal package: reduced interface to the bare minimum required |
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3187 |
to keep existing proof scripts running. Most other user-level |
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3188 |
functions are now part of the OldGoals structure, which is *not* open |
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3189 |
by default (consider isatool expandshort before open OldGoals). |
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3190 |
Removed top_sg, prin, printyp, pprint_term/typ altogether, because |
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3191 |
these tend to cause confusion about the actual goal (!) context being |
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
3192 |
used here, which is not necessarily the same as the_context(). |
17918
93e26302733e
* Theory syntax: discontinued non-Isar format and old Isar headers;
wenzelm
parents:
17890
diff
changeset
|
3193 |
|
23379
d0e3f790bd73
updated 'find_theorems' -- moved ProofGeneral specifics to ProofGeneral/CHANGES;
wenzelm
parents:
23377
diff
changeset
|
3194 |
* Command 'find_theorems': supports "*" wild-card in "name:" |
d0e3f790bd73
updated 'find_theorems' -- moved ProofGeneral specifics to ProofGeneral/CHANGES;
wenzelm
parents:
23377
diff
changeset
|
3195 |
criterion; "with_dups" option. Certain ProofGeneral versions might |
d0e3f790bd73
updated 'find_theorems' -- moved ProofGeneral specifics to ProofGeneral/CHANGES;
wenzelm
parents:
23377
diff
changeset
|
3196 |
support a specific search form (see ProofGeneral/CHANGES). |
22965 | 3197 |
|
20370 | 3198 |
* The ``prems limit'' option (cf. ProofContext.prems_limit) is now -1 |
3199 |
by default, which means that "prems" (and also "fixed variables") are |
|
3200 |
suppressed from proof state output. Note that the ProofGeneral |
|
3201 |
settings mechanism allows to change and save options persistently, but |
|
3202 |
older versions of Isabelle will fail to start up if a negative prems |
|
3203 |
limit is imposed. |
|
3204 |
||
21308
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3205 |
* Local theory targets may be specified by non-nested blocks of |
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3206 |
``context/locale/class ... begin'' followed by ``end''. The body may |
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3207 |
contain definitions, theorems etc., including any derived mechanism |
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3208 |
that has been implemented on top of these primitives. This concept |
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3209 |
generalizes the existing ``theorem (in ...)'' towards more versatility |
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3210 |
and scalability. |
73883a528b26
* Local theory targets ``context/locale/class ... begin'' followed by ``end''.
wenzelm
parents:
21265
diff
changeset
|
3211 |
|
21960
0574f192b78a
* Proof General: proper undo of final 'end'; discontinued Isabelle/classic;
wenzelm
parents:
21896
diff
changeset
|
3212 |
* Proof General interface: proper undo of final 'end' command; |
0574f192b78a
* Proof General: proper undo of final 'end'; discontinued Isabelle/classic;
wenzelm
parents:
21896
diff
changeset
|
3213 |
discontinued Isabelle/classic mode (ML proof scripts). |
0574f192b78a
* Proof General: proper undo of final 'end'; discontinued Isabelle/classic;
wenzelm
parents:
21896
diff
changeset
|
3214 |
|
17754
58a306d9f736
* Command 'find_theorems': support * wildcard in name: criterion.
wenzelm
parents:
17725
diff
changeset
|
3215 |
|
17865 | 3216 |
*** Document preparation *** |
3217 |
||
21717 | 3218 |
* Added antiquotation @{theory name} which prints the given name, |
3219 |
after checking that it refers to a valid ancestor theory in the |
|
3220 |
current context. |
|
21339 | 3221 |
|
17869 | 3222 |
* Added antiquotations @{ML_type text} and @{ML_struct text} which |
3223 |
check the given source text as ML type/structure, printing verbatim. |
|
17865 | 3224 |
|
21717 | 3225 |
* Added antiquotation @{abbrev "c args"} which prints the abbreviation |
3226 |
"c args == rhs" given in the current context. (Any number of |
|
21735 | 3227 |
arguments may be given on the LHS.) |
21717 | 3228 |
|
3229 |
||
17779 | 3230 |
*** Pure *** |
3231 |
||
24800 | 3232 |
* The 'class' package offers a combination of axclass and locale to |
25129 | 3233 |
achieve Haskell-like type classes in Isabelle. Definitions and |
3234 |
theorems within a class context produce both relative results (with |
|
3235 |
implicit parameters according to the locale context), and polymorphic |
|
3236 |
constants with qualified polymorphism (according to the class |
|
3237 |
context). Within the body context of a 'class' target, a separate |
|
3238 |
syntax layer ("user space type system") takes care of converting |
|
3239 |
between global polymorphic consts and internal locale representation. |
|
25177 | 3240 |
See src/HOL/ex/Classpackage.thy for examples (as well as main HOL). |
25184 | 3241 |
"isatool doc classes" provides a tutorial. |
20807 | 3242 |
|
25199 | 3243 |
* Generic code generator framework allows to generate executable |
24800 | 3244 |
code for ML and Haskell (including Isabelle classes). A short usage |
3245 |
sketch: |
|
20188
8b22026445af
added notes on class_package.ML and codegen_package.ML
haftmann
parents:
20169
diff
changeset
|
3246 |
|
8b22026445af
added notes on class_package.ML and codegen_package.ML
haftmann
parents:
20169
diff
changeset
|
3247 |
internal compilation: |
25199 | 3248 |
export_code <list of constants (term syntax)> in SML |
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3249 |
writing SML code to a file: |
25199 | 3250 |
export_code <list of constants (term syntax)> in SML <filename> |
22735 | 3251 |
writing OCaml code to a file: |
25199 | 3252 |
export_code <list of constants (term syntax)> in OCaml <filename> |
20188
8b22026445af
added notes on class_package.ML and codegen_package.ML
haftmann
parents:
20169
diff
changeset
|
3253 |
writing Haskell code to a bunch of files: |
25199 | 3254 |
export_code <list of constants (term syntax)> in Haskell <filename> |
3255 |
||
3256 |
evaluating closed propositions to True/False using code generation: |
|
25184 | 3257 |
method ``eval'' |
3258 |
||
3259 |
Reasonable default setup of framework in HOL. |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3260 |
|
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3261 |
Theorem attributs for selecting and transforming function equations theorems: |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3262 |
|
22845 | 3263 |
[code fun]: select a theorem as function equation for a specific constant |
3264 |
[code fun del]: deselect a theorem as function equation for a specific constant |
|
3265 |
[code inline]: select an equation theorem for unfolding (inlining) in place |
|
3266 |
[code inline del]: deselect an equation theorem for unfolding (inlining) in place |
|
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3267 |
|
22735 | 3268 |
User-defined serializations (target in {SML, OCaml, Haskell}): |
20453
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3269 |
|
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3270 |
code_const <and-list of constants (term syntax)> |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3271 |
{(target) <and-list of const target syntax>}+ |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3272 |
|
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3273 |
code_type <and-list of type constructors> |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3274 |
{(target) <and-list of type target syntax>}+ |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3275 |
|
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3276 |
code_instance <and-list of instances> |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3277 |
{(target)}+ |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3278 |
where instance ::= <type constructor> :: <class> |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3279 |
|
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3280 |
code_class <and_list of classes> |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3281 |
{(target) <and-list of class target syntax>}+ |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3282 |
where class target syntax ::= <class name> {where {<classop> == <target syntax>}+}? |
855f07fabd76
final syntax for some Isar code generator keywords
haftmann
parents:
20375
diff
changeset
|
3283 |
|
25199 | 3284 |
code_instance and code_class only are effective to target Haskell. |
22735 | 3285 |
|
25177 | 3286 |
For example usage see src/HOL/ex/Codegenerator.thy and |
3287 |
src/HOL/ex/Codegenerator_Pretty.thy. A separate tutorial on code |
|
24800 | 3288 |
generation from Isabelle/HOL theories is available via "isatool doc |
3289 |
codegen". |
|
20188
8b22026445af
added notes on class_package.ML and codegen_package.ML
haftmann
parents:
20169
diff
changeset
|
3290 |
|
25129 | 3291 |
* Code generator: consts in 'consts_code' Isar commands are now |
3292 |
referred to by usual term syntax (including optional type |
|
3293 |
annotations). |
|
3294 |
||
19254 | 3295 |
* Command 'no_translations' removes translation rules from theory |
3296 |
syntax. |
|
3297 |
||
19625
285771cec083
* Pure: overloaded definitions are now actually checked for acyclic dependencies;
wenzelm
parents:
19587
diff
changeset
|
3298 |
* Overloaded definitions are now actually checked for acyclic |
19714 | 3299 |
dependencies. The overloading scheme is slightly more general than |
3300 |
that of Haskell98, although Isabelle does not demand an exact |
|
3301 |
correspondence to type class and instance declarations. |
|
3302 |
INCOMPATIBILITY, use ``defs (unchecked overloaded)'' to admit more |
|
3303 |
exotic versions of overloading -- at the discretion of the user! |
|
19711 | 3304 |
|
3305 |
Polymorphic constants are represented via type arguments, i.e. the |
|
3306 |
instantiation that matches an instance against the most general |
|
3307 |
declaration given in the signature. For example, with the declaration |
|
3308 |
c :: 'a => 'a => 'a, an instance c :: nat => nat => nat is represented |
|
3309 |
as c(nat). Overloading is essentially simultaneous structural |
|
3310 |
recursion over such type arguments. Incomplete specification patterns |
|
19714 | 3311 |
impose global constraints on all occurrences, e.g. c('a * 'a) on the |
19715 | 3312 |
LHS means that more general c('a * 'b) will be disallowed on any RHS. |
19714 | 3313 |
Command 'print_theory' outputs the normalized system of recursive |
3314 |
equations, see section "definitions". |
|
19625
285771cec083
* Pure: overloaded definitions are now actually checked for acyclic dependencies;
wenzelm
parents:
19587
diff
changeset
|
3315 |
|
24086 | 3316 |
* Configuration options are maintained within the theory or proof |
3317 |
context (with name and type bool/int/string), providing a very simple |
|
3318 |
interface to a poor-man's version of general context data. Tools may |
|
24110
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3319 |
declare options in ML (e.g. using Attrib.config_int) and then refer to |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3320 |
these values using Config.get etc. Users may change options via an |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3321 |
associated attribute of the same name. This form of context |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3322 |
declaration works particularly well with commands 'declare' or |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3323 |
'using', for example ``declare [[foo = 42]]''. Thus it has become |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3324 |
very easy to avoid global references, which would not observe Isar |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3325 |
toplevel undo/redo and fail to work with multithreading. |
24086 | 3326 |
|
24172
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3327 |
Various global ML references of Pure and HOL have been turned into |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3328 |
configuration options: |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3329 |
|
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3330 |
Unify.search_bound unify_search_bound |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3331 |
Unify.trace_bound unify_trace_bound |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3332 |
Unify.trace_simp unify_trace_simp |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3333 |
Unify.trace_types unify_trace_types |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3334 |
Simplifier.simp_depth_limit simp_depth_limit |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3335 |
Blast.depth_limit blast_depth_limit |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3336 |
DatatypeProp.dtK datatype_distinctness_limit |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3337 |
fast_arith_neq_limit fast_arith_neq_limit |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3338 |
fast_arith_split_limit fast_arith_split_limit |
06e42cf7df4e
theory loader: added use_thys, removed obsolete update_thy;
wenzelm
parents:
24110
diff
changeset
|
3339 |
|
24086 | 3340 |
* Named collections of theorems may be easily installed as context |
24800 | 3341 |
data using the functor NamedThmsFun (see also |
24086 | 3342 |
src/Pure/Tools/named_thms.ML). The user may add or delete facts via |
24110
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3343 |
attributes; there is also a toplevel print command. This facility is |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3344 |
just a common case of general context data, which is the preferred way |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3345 |
for anything more complex than just a list of facts in canonical |
4ab3084e311c
tuned config options: eliminated separate attribute "option";
wenzelm
parents:
24086
diff
changeset
|
3346 |
order. |
24086 | 3347 |
|
24032 | 3348 |
* Isar: command 'declaration' augments a local theory by generic |
3349 |
declaration functions written in ML. This enables arbitrary content |
|
3350 |
being added to the context, depending on a morphism that tells the |
|
3351 |
difference of the original declaration context wrt. the application |
|
3352 |
context encountered later on. |
|
3353 |
||
3354 |
* Isar: proper interfaces for simplification procedures. Command |
|
3355 |
'simproc_setup' declares named simprocs (with match patterns, and body |
|
3356 |
text in ML). Attribute "simproc" adds/deletes simprocs in the current |
|
3357 |
context. ML antiquotation @{simproc name} retrieves named simprocs. |
|
3358 |
||
3359 |
* Isar: an extra pair of brackets around attribute declarations |
|
3360 |
abbreviates a theorem reference involving an internal dummy fact, |
|
3361 |
which will be ignored later --- only the effect of the attribute on |
|
3362 |
the background context will persist. This form of in-place |
|
3363 |
declarations is particularly useful with commands like 'declare' and |
|
3364 |
'using', for example ``have A using [[simproc a]] by simp''. |
|
3365 |
||
23369
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3366 |
* Isar: method "assumption" (and implicit closing of subproofs) now |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3367 |
takes simple non-atomic goal assumptions into account: after applying |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3368 |
an assumption as a rule the resulting subgoals are solved by atomic |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3369 |
assumption steps. This is particularly useful to finish 'obtain' |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3370 |
goals, such as "!!x. (!!x. P x ==> thesis) ==> P x ==> thesis", |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3371 |
without referring to the original premise "!!x. P x ==> thesis" in the |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3372 |
Isar proof context. POTENTIAL INCOMPATIBILITY: method "assumption" is |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3373 |
more permissive. |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3374 |
|
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3375 |
* Isar: implicit use of prems from the Isar proof context is |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3376 |
considered a legacy feature. Common applications like ``have A .'' |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3377 |
may be replaced by ``have A by fact'' or ``note `A`''. In general, |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3378 |
referencing facts explicitly here improves readability and |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3379 |
maintainability of proof texts. |
227c51012cdb
* Isar: method "assumption" (implicit closing of subproofs) takes non-atomic goal assumptions into account;
wenzelm
parents:
23367
diff
changeset
|
3380 |
|
17865 | 3381 |
* Isar: improper proof element 'guess' is like 'obtain', but derives |
3382 |
the obtained context from the course of reasoning! For example: |
|
3383 |
||
3384 |
assume "EX x y. A x & B y" -- "any previous fact" |
|
3385 |
then guess x and y by clarify |
|
3386 |
||
3387 |
This technique is potentially adventurous, depending on the facts and |
|
3388 |
proof tools being involved here. |
|
3389 |
||
18020 | 3390 |
* Isar: known facts from the proof context may be specified as literal |
3391 |
propositions, using ASCII back-quote syntax. This works wherever |
|
3392 |
named facts used to be allowed so far, in proof commands, proof |
|
3393 |
methods, attributes etc. Literal facts are retrieved from the context |
|
3394 |
according to unification of type and term parameters. For example, |
|
3395 |
provided that "A" and "A ==> B" and "!!x. P x ==> Q x" are known |
|
3396 |
theorems in the current context, then these are valid literal facts: |
|
3397 |
`A` and `A ==> B` and `!!x. P x ==> Q x" as well as `P a ==> Q a` etc. |
|
3398 |
||
3399 |
There is also a proof method "fact" which does the same composition |
|
18044 | 3400 |
for explicit goal states, e.g. the following proof texts coincide with |
3401 |
certain special cases of literal facts: |
|
18020 | 3402 |
|
3403 |
have "A" by fact == note `A` |
|
3404 |
have "A ==> B" by fact == note `A ==> B` |
|
3405 |
have "!!x. P x ==> Q x" by fact == note `!!x. P x ==> Q x` |
|
3406 |
have "P a ==> Q a" by fact == note `P a ==> Q a` |
|
3407 |
||
20118
0c1ec587a5a8
* Isar: ":" (colon) is no longer a symbolic identifier character;
wenzelm
parents:
20090
diff
changeset
|
3408 |
* Isar: ":" (colon) is no longer a symbolic identifier character in |
0c1ec587a5a8
* Isar: ":" (colon) is no longer a symbolic identifier character;
wenzelm
parents:
20090
diff
changeset
|
3409 |
outer syntax. Thus symbolic identifiers may be used without |
0c1ec587a5a8
* Isar: ":" (colon) is no longer a symbolic identifier character;
wenzelm
parents:
20090
diff
changeset
|
3410 |
additional white space in declarations like this: ``assume *: A''. |
0c1ec587a5a8
* Isar: ":" (colon) is no longer a symbolic identifier character;
wenzelm
parents:
20090
diff
changeset
|
3411 |
|
20013 | 3412 |
* Isar: 'print_facts' prints all local facts of the current context, |
3413 |
both named and unnamed ones. |
|
3414 |
||
18308 | 3415 |
* Isar: 'def' now admits simultaneous definitions, e.g.: |
3416 |
||
3417 |
def x == "t" and y == "u" |
|
3418 |
||
18540 | 3419 |
* Isar: added command 'unfolding', which is structurally similar to |
3420 |
'using', but affects both the goal state and facts by unfolding given |
|
18815
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3421 |
rewrite rules. Thus many occurrences of the 'unfold' method or |
18540 | 3422 |
'unfolded' attribute may be replaced by first-class proof text. |
3423 |
||
18815
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3424 |
* Isar: methods 'unfold' / 'fold', attributes 'unfolded' / 'folded', |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3425 |
and command 'unfolding' now all support object-level equalities |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3426 |
(potentially conditional). The underlying notion of rewrite rule is |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3427 |
analogous to the 'rule_format' attribute, but *not* that of the |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3428 |
Simplifier (which is usually more generous). |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
3429 |
|
24238 | 3430 |
* Isar: the new attribute [rotated n] (default n = 1) rotates the |
3431 |
premises of a theorem by n. Useful in conjunction with drule. |
|
3432 |
||
19220 | 3433 |
* Isar: the goal restriction operator [N] (default N = 1) evaluates a |
3434 |
method expression within a sandbox consisting of the first N |
|
19240 | 3435 |
sub-goals, which need to exist. For example, ``simp_all [3]'' |
3436 |
simplifies the first three sub-goals, while (rule foo, simp_all)[] |
|
3437 |
simplifies all new goals that emerge from applying rule foo to the |
|
3438 |
originally first one. |
|
19220 | 3439 |
|
19814
faa698d46686
* Theory syntax: some popular names (e.g. "class", "if") are now keywords.
wenzelm
parents:
19783
diff
changeset
|
3440 |
* Isar: schematic goals are no longer restricted to higher-order |
faa698d46686
* Theory syntax: some popular names (e.g. "class", "if") are now keywords.
wenzelm
parents:
19783
diff
changeset
|
3441 |
patterns; e.g. ``lemma "?P(?x)" by (rule TrueI)'' now works as |
faa698d46686
* Theory syntax: some popular names (e.g. "class", "if") are now keywords.
wenzelm
parents:
19783
diff
changeset
|
3442 |
expected. |
faa698d46686
* Theory syntax: some popular names (e.g. "class", "if") are now keywords.
wenzelm
parents:
19783
diff
changeset
|
3443 |
|
18901 | 3444 |
* Isar: the conclusion of a long theorem statement is now either |
3445 |
'shows' (a simultaneous conjunction, as before), or 'obtains' |
|
3446 |
(essentially a disjunction of cases with local parameters and |
|
3447 |
assumptions). The latter allows to express general elimination rules |
|
18910 | 3448 |
adequately; in this notation common elimination rules look like this: |
18901 | 3449 |
|
3450 |
lemma exE: -- "EX x. P x ==> (!!x. P x ==> thesis) ==> thesis" |
|
3451 |
assumes "EX x. P x" |
|
3452 |
obtains x where "P x" |
|
3453 |
||
3454 |
lemma conjE: -- "A & B ==> (A ==> B ==> thesis) ==> thesis" |
|
3455 |
assumes "A & B" |
|
3456 |
obtains A and B |
|
3457 |
||
3458 |
lemma disjE: -- "A | B ==> (A ==> thesis) ==> (B ==> thesis) ==> thesis" |
|
3459 |
assumes "A | B" |
|
3460 |
obtains |
|
3461 |
A |
|
3462 |
| B |
|
3463 |
||
18910 | 3464 |
The subsequent classical rules even refer to the formal "thesis" |
18901 | 3465 |
explicitly: |
3466 |
||
3467 |
lemma classical: -- "(~ thesis ==> thesis) ==> thesis" |
|
3468 |
obtains "~ thesis" |
|
3469 |
||
18910 | 3470 |
lemma Peirce's_Law: -- "((thesis ==> something) ==> thesis) ==> thesis" |
3471 |
obtains "thesis ==> something" |
|
18901 | 3472 |
|
3473 |
The actual proof of an 'obtains' statement is analogous to that of the |
|
18910 | 3474 |
Isar proof element 'obtain', only that there may be several cases. |
3475 |
Optional case names may be specified in parentheses; these will be |
|
3476 |
available both in the present proof and as annotations in the |
|
3477 |
resulting rule, for later use with the 'cases' method (cf. attribute |
|
3478 |
case_names). |
|
18901 | 3479 |
|
21447
379f130843f7
* Isar: the assumptions of a long theorem statement are available as assms;
wenzelm
parents:
21406
diff
changeset
|
3480 |
* Isar: the assumptions of a long theorem statement are available as |
379f130843f7
* Isar: the assumptions of a long theorem statement are available as assms;
wenzelm
parents:
21406
diff
changeset
|
3481 |
"assms" fact in the proof context. This is more appropriate than the |
379f130843f7
* Isar: the assumptions of a long theorem statement are available as assms;
wenzelm
parents:
21406
diff
changeset
|
3482 |
(historical) "prems", which refers to all assumptions of the current |
379f130843f7
* Isar: the assumptions of a long theorem statement are available as assms;
wenzelm
parents:
21406
diff
changeset
|
3483 |
context, including those from the target locale, proof body etc. |
379f130843f7
* Isar: the assumptions of a long theorem statement are available as assms;
wenzelm
parents:
21406
diff
changeset
|
3484 |
|
19263 | 3485 |
* Isar: 'print_statement' prints theorems from the current theory or |
3486 |
proof context in long statement form, according to the syntax of a |
|
3487 |
top-level lemma. |
|
3488 |
||
18901 | 3489 |
* Isar: 'obtain' takes an optional case name for the local context |
3490 |
introduction rule (default "that"). |
|
3491 |
||
19587 | 3492 |
* Isar: removed obsolete 'concl is' patterns. INCOMPATIBILITY, use |
3493 |
explicit (is "_ ==> ?foo") in the rare cases where this still happens |
|
3494 |
to occur. |
|
3495 |
||
19682
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3496 |
* Pure: syntax "CONST name" produces a fully internalized constant |
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3497 |
according to the current context. This is particularly useful for |
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3498 |
syntax translations that should refer to internal constant |
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3499 |
representations independently of name spaces. |
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3500 |
|
21537
45b3a85ee548
* Pure: syntax constant for foo (binder) is called foo_binder;
wenzelm
parents:
21471
diff
changeset
|
3501 |
* Pure: syntax constant for foo (binder "FOO ") is called "foo_binder" |
45b3a85ee548
* Pure: syntax constant for foo (binder) is called foo_binder;
wenzelm
parents:
21471
diff
changeset
|
3502 |
instead of "FOO ". This allows multiple binder declarations to coexist |
45b3a85ee548
* Pure: syntax constant for foo (binder) is called foo_binder;
wenzelm
parents:
21471
diff
changeset
|
3503 |
in the same context. INCOMPATIBILITY. |
45b3a85ee548
* Pure: syntax constant for foo (binder) is called foo_binder;
wenzelm
parents:
21471
diff
changeset
|
3504 |
|
21209
dbb8decc36bc
'const_syntax' command: allow fixed variables, renamed to 'notation';
wenzelm
parents:
21200
diff
changeset
|
3505 |
* Isar/locales: 'notation' provides a robust interface to the 'syntax' |
dbb8decc36bc
'const_syntax' command: allow fixed variables, renamed to 'notation';
wenzelm
parents:
21200
diff
changeset
|
3506 |
primitive that also works in a locale context (both for constants and |
24950 | 3507 |
fixed variables). Type declaration and internal syntactic representation |
3508 |
of given constants retrieved from the context. Likewise, the |
|
3509 |
'no_notation' command allows to remove given syntax annotations from the |
|
3510 |
current context. |
|
19682
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3511 |
|
19665 | 3512 |
* Isar/locales: new derived specification elements 'axiomatization', |
3513 |
'definition', 'abbreviation', which support type-inference, admit |
|
19083 | 3514 |
object-level specifications (equality, equivalence). See also the |
3515 |
isar-ref manual. Examples: |
|
19081
085b5badb8de
* Isar/locales: new derived specification elements 'definition', 'abbreviation', 'axiomatization';
wenzelm
parents:
19034
diff
changeset
|
3516 |
|
19665 | 3517 |
axiomatization |
21595 | 3518 |
eq (infix "===" 50) where |
3519 |
eq_refl: "x === x" and eq_subst: "x === y ==> P x ==> P y" |
|
3520 |
||
3521 |
definition "f x y = x + y + 1" |
|
3522 |
definition g where "g x = f x x" |
|
19081
085b5badb8de
* Isar/locales: new derived specification elements 'definition', 'abbreviation', 'axiomatization';
wenzelm
parents:
19034
diff
changeset
|
3523 |
|
19363 | 3524 |
abbreviation |
21595 | 3525 |
neq (infix "=!=" 50) where |
19363 | 3526 |
"x =!= y == ~ (x === y)" |
19081
085b5badb8de
* Isar/locales: new derived specification elements 'definition', 'abbreviation', 'axiomatization';
wenzelm
parents:
19034
diff
changeset
|
3527 |
|
19083 | 3528 |
These specifications may be also used in a locale context. Then the |
3529 |
constants being introduced depend on certain fixed parameters, and the |
|
3530 |
constant name is qualified by the locale base name. An internal |
|
3531 |
abbreviation takes care for convenient input and output, making the |
|
19088 | 3532 |
parameters implicit and using the original short name. See also |
25177 | 3533 |
src/HOL/ex/Abstract_NAT.thy for an example of deriving polymorphic |
19083 | 3534 |
entities from a monomorphic theory. |
3535 |
||
3536 |
Presently, abbreviations are only available 'in' a target locale, but |
|
19363 | 3537 |
not inherited by general import expressions. Also note that |
3538 |
'abbreviation' may be used as a type-safe replacement for 'syntax' + |
|
24735
3a55ee2cae70
* Pure/Isar: unified specification syntax admits type inference and dummy patterns;
wenzelm
parents:
24706
diff
changeset
|
3539 |
'translations' in common applications. The "no_abbrevs" print mode |
3a55ee2cae70
* Pure/Isar: unified specification syntax admits type inference and dummy patterns;
wenzelm
parents:
24706
diff
changeset
|
3540 |
prevents folding of abbreviations in term output. |
19084 | 3541 |
|
19682
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3542 |
Concrete syntax is attached to specified constants in internal form, |
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3543 |
independently of name spaces. The parse tree representation is |
21209
dbb8decc36bc
'const_syntax' command: allow fixed variables, renamed to 'notation';
wenzelm
parents:
21200
diff
changeset
|
3544 |
slightly different -- use 'notation' instead of raw 'syntax', and |
19682
c8c301eb965a
* Pure: syntax 'CONST name' produces a fully internalized constant;
wenzelm
parents:
19665
diff
changeset
|
3545 |
'translations' with explicit "CONST" markup to accommodate this. |
19665 | 3546 |
|
24800 | 3547 |
* Pure/Isar: unified syntax for new-style specification mechanisms |
3548 |
(e.g. 'definition', 'abbreviation', or 'inductive' in HOL) admits |
|
3549 |
full type inference and dummy patterns ("_"). For example: |
|
24735
3a55ee2cae70
* Pure/Isar: unified specification syntax admits type inference and dummy patterns;
wenzelm
parents:
24706
diff
changeset
|
3550 |
|
3a55ee2cae70
* Pure/Isar: unified specification syntax admits type inference and dummy patterns;
wenzelm
parents:
24706
diff
changeset
|
3551 |
definition "K x _ = x" |
3a55ee2cae70
* Pure/Isar: unified specification syntax admits type inference and dummy patterns;
wenzelm
parents:
24706
diff
changeset
|
3552 |
|
24738 | 3553 |
inductive conj for A B |
3554 |
where "A ==> B ==> conj A B" |
|
3555 |
||
21735 | 3556 |
* Pure: command 'print_abbrevs' prints all constant abbreviations of |
3557 |
the current context. Print mode "no_abbrevs" prevents inversion of |
|
3558 |
abbreviations on output. |
|
3559 |
||
24800 | 3560 |
* Isar/locales: improved parameter handling: use of locales "var" and |
3561 |
"struct" no longer necessary; - parameter renamings are no longer |
|
3562 |
required to be injective. For example, this allows to define |
|
3563 |
endomorphisms as locale endom = homom mult mult h. |
|
19783 | 3564 |
|
19931
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
19895
diff
changeset
|
3565 |
* Isar/locales: changed the way locales with predicates are defined. |
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
19895
diff
changeset
|
3566 |
Instead of accumulating the specification, the imported expression is |
22126 | 3567 |
now an interpretation. INCOMPATIBILITY: different normal form of |
3568 |
locale expressions. In particular, in interpretations of locales with |
|
3569 |
predicates, goals repesenting already interpreted fragments are not |
|
3570 |
removed automatically. Use methods `intro_locales' and |
|
3571 |
`unfold_locales'; see below. |
|
3572 |
||
3573 |
* Isar/locales: new methods `intro_locales' and `unfold_locales' |
|
3574 |
provide backward reasoning on locales predicates. The methods are |
|
3575 |
aware of interpretations and discharge corresponding goals. |
|
3576 |
`intro_locales' is less aggressive then `unfold_locales' and does not |
|
3577 |
unfold predicates to assumptions. |
|
19931
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
19895
diff
changeset
|
3578 |
|
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
19895
diff
changeset
|
3579 |
* Isar/locales: the order in which locale fragments are accumulated |
22126 | 3580 |
has changed. This enables to override declarations from fragments due |
3581 |
to interpretations -- for example, unwanted simp rules. |
|
19931
fb32b43e7f80
Restructured locales with predicates: import is now an interpretation.
ballarin
parents:
19895
diff
changeset
|
3582 |
|
23920 | 3583 |
* Isar/locales: interpretation in theories and proof contexts has been |
3584 |
extended. One may now specify (and prove) equations, which are |
|
3585 |
unfolded in interpreted theorems. This is useful for replacing |
|
3586 |
defined concepts (constants depending on locale parameters) by |
|
3587 |
concepts already existing in the target context. Example: |
|
3588 |
||
3589 |
interpretation partial_order ["op <= :: [int, int] => bool"] |
|
3590 |
where "partial_order.less (op <=) (x::int) y = (x < y)" |
|
3591 |
||
24800 | 3592 |
Typically, the constant `partial_order.less' is created by a |
3593 |
definition specification element in the context of locale |
|
3594 |
partial_order. |
|
3595 |
||
24859 | 3596 |
* Method "induct": improved internal context management to support |
24800 | 3597 |
local fixes and defines on-the-fly. Thus explicit meta-level |
3598 |
connectives !! and ==> are rarely required anymore in inductive goals |
|
3599 |
(using object-logic connectives for this purpose has been long |
|
3600 |
obsolete anyway). Common proof patterns are explained in |
|
25177 | 3601 |
src/HOL/Induct/Common_Patterns.thy, see also |
3602 |
src/HOL/Isar_examples/Puzzle.thy and src/HOL/Lambda for realistic |
|
3603 |
examples. |
|
24606
7acbb982fc77
moved induct patterns to HOL/Induct/Common_Patterns.thy;
wenzelm
parents:
24507
diff
changeset
|
3604 |
|
24859 | 3605 |
* Method "induct": improved handling of simultaneous goals. Instead of |
24606
7acbb982fc77
moved induct patterns to HOL/Induct/Common_Patterns.thy;
wenzelm
parents:
24507
diff
changeset
|
3606 |
introducing object-level conjunction, the statement is now split into |
7acbb982fc77
moved induct patterns to HOL/Induct/Common_Patterns.thy;
wenzelm
parents:
24507
diff
changeset
|
3607 |
several conclusions, while the corresponding symbolic cases are nested |
7acbb982fc77
moved induct patterns to HOL/Induct/Common_Patterns.thy;
wenzelm
parents:
24507
diff
changeset
|
3608 |
accordingly. INCOMPATIBILITY, proofs need to be structured explicitly, |
25177 | 3609 |
see src/HOL/Induct/Common_Patterns.thy, for example. |
24606
7acbb982fc77
moved induct patterns to HOL/Induct/Common_Patterns.thy;
wenzelm
parents:
24507
diff
changeset
|
3610 |
|
24859 | 3611 |
* Method "induct": mutual induction rules are now specified as a list |
24800 | 3612 |
of rule sharing the same induction cases. HOL packages usually provide |
24606
7acbb982fc77
moved induct patterns to HOL/Induct/Common_Patterns.thy;
wenzelm
parents:
24507
diff
changeset
|
3613 |
foo_bar.inducts for mutually defined items foo and bar (e.g. inductive |
24859 | 3614 |
predicates/sets or datatypes). INCOMPATIBILITY, users need to specify |
3615 |
mutual induction rules differently, i.e. like this: |
|
18506
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3616 |
|
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3617 |
(induct rule: foo_bar.inducts) |
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3618 |
(induct set: foo bar) |
24859 | 3619 |
(induct pred: foo bar) |
18506
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3620 |
(induct type: foo bar) |
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3621 |
|
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3622 |
The ML function ProjectRule.projections turns old-style rules into the |
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3623 |
new format. |
96260fb11449
* Provers/induct: support simultaneous goals with mutual rules;
wenzelm
parents:
18495
diff
changeset
|
3624 |
|
24859 | 3625 |
* Method "coinduct": dual of induction, see |
18399 | 3626 |
src/HOL/Library/Coinductive_List.thy for various examples. |
3627 |
||
24859 | 3628 |
* Method "cases", "induct", "coinduct": the ``(open)'' option is |
3629 |
considered a legacy feature. |
|
3630 |
||
20919
dab803075c62
attribute "symmetric": standardized schematic variables;
wenzelm
parents:
20857
diff
changeset
|
3631 |
* Attribute "symmetric" produces result with standardized schematic |
dab803075c62
attribute "symmetric": standardized schematic variables;
wenzelm
parents:
20857
diff
changeset
|
3632 |
variables (index 0). Potential INCOMPATIBILITY. |
dab803075c62
attribute "symmetric": standardized schematic variables;
wenzelm
parents:
20857
diff
changeset
|
3633 |
|
22126 | 3634 |
* Simplifier: by default the simplifier trace only shows top level |
3635 |
rewrites now. That is, trace_simp_depth_limit is set to 1 by |
|
3636 |
default. Thus there is less danger of being flooded by the trace. The |
|
3637 |
trace indicates where parts have been suppressed. |
|
18674 | 3638 |
|
18536
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3639 |
* Provers/classical: removed obsolete classical version of elim_format |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3640 |
attribute; classical elim/dest rules are now treated uniformly when |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3641 |
manipulating the claset. |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3642 |
|
18694 | 3643 |
* Provers/classical: stricter checks to ensure that supplied intro, |
3644 |
dest and elim rules are well-formed; dest and elim rules must have at |
|
3645 |
least one premise. |
|
3646 |
||
3647 |
* Provers/classical: attributes dest/elim/intro take an optional |
|
18695 | 3648 |
weight argument for the rule (just as the Pure versions). Weights are |
18696 | 3649 |
ignored by automated tools, but determine the search order of single |
18694 | 3650 |
rule steps. |
18557
60a0f9caa0a2
Provers/classical: stricter checks to ensure that supplied intro, dest and
paulson
parents:
18549
diff
changeset
|
3651 |
|
18536
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3652 |
* Syntax: input syntax now supports dummy variable binding "%_. b", |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3653 |
where the body does not mention the bound variable. Note that dummy |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3654 |
patterns implicitly depend on their context of bounds, which makes |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3655 |
"{_. _}" match any set comprehension as expected. Potential |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3656 |
INCOMPATIBILITY -- parse translations need to cope with syntactic |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3657 |
constant "_idtdummy" in the binding position. |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3658 |
|
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3659 |
* Syntax: removed obsolete syntactic constant "_K" and its associated |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3660 |
parse translation. INCOMPATIBILITY -- use dummy abstraction instead, |
ab3f32f86847
* Provers/classical: removed obsolete classical version of elim_format;
wenzelm
parents:
18507
diff
changeset
|
3661 |
for example "A -> B" => "Pi A (%_. B)". |
17779 | 3662 |
|
20582
ebd0e03c6a9b
* Pure: 'class_deps' command visualizes the subclass relation;
wenzelm
parents:
20503
diff
changeset
|
3663 |
* Pure: 'class_deps' command visualizes the subclass relation, using |
ebd0e03c6a9b
* Pure: 'class_deps' command visualizes the subclass relation;
wenzelm
parents:
20503
diff
changeset
|
3664 |
the graph browser tool. |
ebd0e03c6a9b
* Pure: 'class_deps' command visualizes the subclass relation;
wenzelm
parents:
20503
diff
changeset
|
3665 |
|
24800 | 3666 |
* Pure: 'print_theory' now suppresses certain internal declarations by |
3667 |
default; use '!' option for full details. |
|
20620
8b26f58c5646
* Pure: 'print_theory' now suppresses entities with internal name;
wenzelm
parents:
20607
diff
changeset
|
3668 |
|
17865 | 3669 |
|
17806 | 3670 |
*** HOL *** |
3671 |
||
25129 | 3672 |
* Method "metis" proves goals by applying the Metis general-purpose |
3673 |
resolution prover (see also http://gilith.com/software/metis/). |
|
3674 |
Examples are in the directory MetisExamples. WARNING: the |
|
3675 |
Isabelle/HOL-Metis integration does not yet work properly with |
|
3676 |
multi-threading. |
|
3677 |
||
3678 |
* Command 'sledgehammer' invokes external automatic theorem provers as |
|
3679 |
background processes. It generates calls to the "metis" method if |
|
3680 |
successful. These can be pasted into the proof. Users do not have to |
|
3681 |
wait for the automatic provers to return. WARNING: does not really |
|
3682 |
work with multi-threading. |
|
3683 |
||
24804 | 3684 |
* New "auto_quickcheck" feature tests outermost goal statements for |
3685 |
potential counter-examples. Controlled by ML references |
|
3686 |
auto_quickcheck (default true) and auto_quickcheck_time_limit (default |
|
25129 | 3687 |
5000 milliseconds). Fails silently if statements is outside of |
3688 |
executable fragment, or any other codgenerator problem occurs. |
|
24804 | 3689 |
|
25184 | 3690 |
* New constant "undefined" with axiom "undefined x = undefined". |
3691 |
||
3692 |
* Added class "HOL.eq", allowing for code generation with polymorphic |
|
3693 |
equality. |
|
3694 |
||
3695 |
* Some renaming of class constants due to canonical name prefixing in |
|
3696 |
the new 'class' package: |
|
3697 |
||
3698 |
HOL.abs ~> HOL.abs_class.abs |
|
3699 |
HOL.divide ~> HOL.divide_class.divide |
|
3700 |
0 ~> HOL.zero_class.zero |
|
3701 |
1 ~> HOL.one_class.one |
|
3702 |
op + ~> HOL.plus_class.plus |
|
3703 |
op - ~> HOL.minus_class.minus |
|
3704 |
uminus ~> HOL.minus_class.uminus |
|
3705 |
op * ~> HOL.times_class.times |
|
3706 |
op < ~> HOL.ord_class.less |
|
3707 |
op <= > HOL.ord_class.less_eq |
|
3708 |
Nat.power ~> Power.power_class.power |
|
3709 |
Nat.size ~> Nat.size_class.size |
|
3710 |
Numeral.number_of ~> Numeral.number_class.number_of |
|
3711 |
FixedPoint.Inf ~> Lattices.complete_lattice_class.Inf |
|
3712 |
FixedPoint.Sup ~> Lattices.complete_lattice_class.Sup |
|
3713 |
Orderings.min ~> Orderings.ord_class.min |
|
3714 |
Orderings.max ~> Orderings.ord_class.max |
|
3715 |
Divides.op div ~> Divides.div_class.div |
|
3716 |
Divides.op mod ~> Divides.div_class.mod |
|
3717 |
Divides.op dvd ~> Divides.div_class.dvd |
|
3718 |
||
3719 |
INCOMPATIBILITY. Adaptions may be required in the following cases: |
|
3720 |
||
3721 |
a) User-defined constants using any of the names "plus", "minus", |
|
3722 |
"times", "less" or "less_eq". The standard syntax translations for |
|
3723 |
"+", "-" and "*" may go wrong. INCOMPATIBILITY: use more specific |
|
3724 |
names. |
|
3725 |
||
3726 |
b) Variables named "plus", "minus", "times", "less", "less_eq" |
|
3727 |
INCOMPATIBILITY: use more specific names. |
|
3728 |
||
3729 |
c) Permutative equations (e.g. "a + b = b + a") |
|
3730 |
Since the change of names also changes the order of terms, permutative |
|
3731 |
rewrite rules may get applied in a different order. Experience shows |
|
3732 |
that this is rarely the case (only two adaptions in the whole Isabelle |
|
3733 |
distribution). INCOMPATIBILITY: rewrite proofs |
|
3734 |
||
3735 |
d) ML code directly refering to constant names |
|
3736 |
This in general only affects hand-written proof tactics, simprocs and |
|
3737 |
so on. INCOMPATIBILITY: grep your sourcecode and replace names. |
|
3738 |
Consider using @{const_name} antiquotation. |
|
3739 |
||
3740 |
* New class "default" with associated constant "default". |
|
3741 |
||
3742 |
* Function "sgn" is now overloaded and available on int, real, complex |
|
3743 |
(and other numeric types), using class "sgn". Two possible defs of |
|
3744 |
sgn are given as equational assumptions in the classes sgn_if and |
|
3745 |
sgn_div_norm; ordered_idom now also inherits from sgn_if. |
|
3746 |
INCOMPATIBILITY. |
|
3747 |
||
3748 |
* Locale "partial_order" now unified with class "order" (cf. theory |
|
3749 |
Orderings), added parameter "less". INCOMPATIBILITY. |
|
3750 |
||
3751 |
* Renamings in classes "order" and "linorder": facts "refl", "trans" and |
|
3752 |
"cases" to "order_refl", "order_trans" and "linorder_cases", to avoid |
|
3753 |
clashes with HOL "refl" and "trans". INCOMPATIBILITY. |
|
3754 |
||
3755 |
* Classes "order" and "linorder": potential INCOMPATIBILITY due to |
|
3756 |
changed order of proof goals in instance proofs. |
|
3757 |
||
3758 |
* The transitivity reasoner for partial and linear orders is set up |
|
3759 |
for classes "order" and "linorder". Instances of the reasoner are available |
|
3760 |
in all contexts importing or interpreting the corresponding locales. |
|
3761 |
Method "order" invokes the reasoner separately; the reasoner |
|
3762 |
is also integrated with the Simplifier as a solver. Diagnostic |
|
3763 |
command 'print_orders' shows the available instances of the reasoner |
|
3764 |
in the current context. |
|
3765 |
||
3766 |
* Localized monotonicity predicate in theory "Orderings"; integrated |
|
3767 |
lemmas max_of_mono and min_of_mono with this predicate. |
|
3768 |
INCOMPATIBILITY. |
|
3769 |
||
3770 |
* Formulation of theorem "dense" changed slightly due to integration |
|
3771 |
with new class dense_linear_order. |
|
3772 |
||
3773 |
* Uniform lattice theory development in HOL. |
|
3774 |
||
3775 |
constants "meet" and "join" now named "inf" and "sup" |
|
3776 |
constant "Meet" now named "Inf" |
|
3777 |
||
3778 |
classes "meet_semilorder" and "join_semilorder" now named |
|
3779 |
"lower_semilattice" and "upper_semilattice" |
|
3780 |
class "lorder" now named "lattice" |
|
3781 |
class "comp_lat" now named "complete_lattice" |
|
3782 |
||
3783 |
Instantiation of lattice classes allows explicit definitions |
|
3784 |
for "inf" and "sup" operations (or "Inf" and "Sup" for complete lattices). |
|
3785 |
||
3786 |
INCOMPATIBILITY. Theorem renames: |
|
3787 |
||
3788 |
meet_left_le ~> inf_le1 |
|
3789 |
meet_right_le ~> inf_le2 |
|
3790 |
join_left_le ~> sup_ge1 |
|
3791 |
join_right_le ~> sup_ge2 |
|
3792 |
meet_join_le ~> inf_sup_ord |
|
3793 |
le_meetI ~> le_infI |
|
3794 |
join_leI ~> le_supI |
|
3795 |
le_meet ~> le_inf_iff |
|
3796 |
le_join ~> ge_sup_conv |
|
3797 |
meet_idempotent ~> inf_idem |
|
3798 |
join_idempotent ~> sup_idem |
|
3799 |
meet_comm ~> inf_commute |
|
3800 |
join_comm ~> sup_commute |
|
3801 |
meet_leI1 ~> le_infI1 |
|
3802 |
meet_leI2 ~> le_infI2 |
|
3803 |
le_joinI1 ~> le_supI1 |
|
3804 |
le_joinI2 ~> le_supI2 |
|
3805 |
meet_assoc ~> inf_assoc |
|
3806 |
join_assoc ~> sup_assoc |
|
3807 |
meet_left_comm ~> inf_left_commute |
|
3808 |
meet_left_idempotent ~> inf_left_idem |
|
3809 |
join_left_comm ~> sup_left_commute |
|
3810 |
join_left_idempotent ~> sup_left_idem |
|
3811 |
meet_aci ~> inf_aci |
|
3812 |
join_aci ~> sup_aci |
|
3813 |
le_def_meet ~> le_iff_inf |
|
3814 |
le_def_join ~> le_iff_sup |
|
3815 |
join_absorp2 ~> sup_absorb2 |
|
3816 |
join_absorp1 ~> sup_absorb1 |
|
3817 |
meet_absorp1 ~> inf_absorb1 |
|
3818 |
meet_absorp2 ~> inf_absorb2 |
|
3819 |
meet_join_absorp ~> inf_sup_absorb |
|
3820 |
join_meet_absorp ~> sup_inf_absorb |
|
3821 |
distrib_join_le ~> distrib_sup_le |
|
3822 |
distrib_meet_le ~> distrib_inf_le |
|
3823 |
||
3824 |
add_meet_distrib_left ~> add_inf_distrib_left |
|
3825 |
add_join_distrib_left ~> add_sup_distrib_left |
|
3826 |
is_join_neg_meet ~> is_join_neg_inf |
|
3827 |
is_meet_neg_join ~> is_meet_neg_sup |
|
3828 |
add_meet_distrib_right ~> add_inf_distrib_right |
|
3829 |
add_join_distrib_right ~> add_sup_distrib_right |
|
3830 |
add_meet_join_distribs ~> add_sup_inf_distribs |
|
3831 |
join_eq_neg_meet ~> sup_eq_neg_inf |
|
3832 |
meet_eq_neg_join ~> inf_eq_neg_sup |
|
3833 |
add_eq_meet_join ~> add_eq_inf_sup |
|
3834 |
meet_0_imp_0 ~> inf_0_imp_0 |
|
3835 |
join_0_imp_0 ~> sup_0_imp_0 |
|
3836 |
meet_0_eq_0 ~> inf_0_eq_0 |
|
3837 |
join_0_eq_0 ~> sup_0_eq_0 |
|
3838 |
neg_meet_eq_join ~> neg_inf_eq_sup |
|
3839 |
neg_join_eq_meet ~> neg_sup_eq_inf |
|
3840 |
join_eq_if ~> sup_eq_if |
|
3841 |
||
3842 |
mono_meet ~> mono_inf |
|
3843 |
mono_join ~> mono_sup |
|
3844 |
meet_bool_eq ~> inf_bool_eq |
|
3845 |
join_bool_eq ~> sup_bool_eq |
|
3846 |
meet_fun_eq ~> inf_fun_eq |
|
3847 |
join_fun_eq ~> sup_fun_eq |
|
3848 |
meet_set_eq ~> inf_set_eq |
|
3849 |
join_set_eq ~> sup_set_eq |
|
3850 |
meet1_iff ~> inf1_iff |
|
3851 |
meet2_iff ~> inf2_iff |
|
3852 |
meet1I ~> inf1I |
|
3853 |
meet2I ~> inf2I |
|
3854 |
meet1D1 ~> inf1D1 |
|
3855 |
meet2D1 ~> inf2D1 |
|
3856 |
meet1D2 ~> inf1D2 |
|
3857 |
meet2D2 ~> inf2D2 |
|
3858 |
meet1E ~> inf1E |
|
3859 |
meet2E ~> inf2E |
|
3860 |
join1_iff ~> sup1_iff |
|
3861 |
join2_iff ~> sup2_iff |
|
3862 |
join1I1 ~> sup1I1 |
|
3863 |
join2I1 ~> sup2I1 |
|
3864 |
join1I1 ~> sup1I1 |
|
3865 |
join2I2 ~> sup1I2 |
|
3866 |
join1CI ~> sup1CI |
|
3867 |
join2CI ~> sup2CI |
|
3868 |
join1E ~> sup1E |
|
3869 |
join2E ~> sup2E |
|
3870 |
||
3871 |
is_meet_Meet ~> is_meet_Inf |
|
3872 |
Meet_bool_def ~> Inf_bool_def |
|
3873 |
Meet_fun_def ~> Inf_fun_def |
|
3874 |
Meet_greatest ~> Inf_greatest |
|
3875 |
Meet_lower ~> Inf_lower |
|
3876 |
Meet_set_def ~> Inf_set_def |
|
3877 |
||
3878 |
Sup_def ~> Sup_Inf |
|
3879 |
Sup_bool_eq ~> Sup_bool_def |
|
3880 |
Sup_fun_eq ~> Sup_fun_def |
|
3881 |
Sup_set_eq ~> Sup_set_def |
|
3882 |
||
3883 |
listsp_meetI ~> listsp_infI |
|
3884 |
listsp_meet_eq ~> listsp_inf_eq |
|
3885 |
||
3886 |
meet_min ~> inf_min |
|
3887 |
join_max ~> sup_max |
|
3888 |
||
3889 |
* Added syntactic class "size"; overloaded constant "size" now has |
|
3890 |
type "'a::size ==> bool" |
|
3891 |
||
24800 | 3892 |
* Internal reorganisation of `size' of datatypes: size theorems |
3893 |
"foo.size" are no longer subsumed by "foo.simps" (but are still |
|
3894 |
simplification rules by default!); theorems "prod.size" now named |
|
25184 | 3895 |
"*.size". |
3896 |
||
3897 |
* Class "div" now inherits from class "times" rather than "type". |
|
3898 |
INCOMPATIBILITY. |
|
24800 | 3899 |
|
3900 |
* HOL/Finite_Set: "name-space" locales Lattice, Distrib_lattice, |
|
3901 |
Linorder etc. have disappeared; operations defined in terms of |
|
3902 |
fold_set now are named Inf_fin, Sup_fin. INCOMPATIBILITY. |
|
3903 |
||
25129 | 3904 |
* HOL/Nat: neq0_conv no longer declared as iff. INCOMPATIBILITY. |
3905 |
||
24800 | 3906 |
* HOL-Word: New extensive library and type for generic, fixed size |
3907 |
machine words, with arithemtic, bit-wise, shifting and rotating |
|
3908 |
operations, reflection into int, nat, and bool lists, automation for |
|
3909 |
linear arithmetic (by automatic reflection into nat or int), including |
|
3910 |
lemmas on overflow and monotonicity. Instantiated to all appropriate |
|
3911 |
arithmetic type classes, supporting automatic simplification of |
|
3912 |
numerals on all operations. |
|
24333 | 3913 |
|
3914 |
* Library/Boolean_Algebra: locales for abstract boolean algebras. |
|
3915 |
||
3916 |
* Library/Numeral_Type: numbers as types, e.g. TYPE(32). |
|
3917 |
||
23850 | 3918 |
* Code generator library theories: |
24993 | 3919 |
- Code_Integer represents HOL integers by big integer literals in target |
23850 | 3920 |
languages. |
24993 | 3921 |
- Code_Char represents HOL characters by character literals in target |
23850 | 3922 |
languages. |
24993 | 3923 |
- Code_Char_chr like Code_Char, but also offers treatment of character |
3924 |
codes; includes Code_Integer. |
|
24800 | 3925 |
- Executable_Set allows to generate code for finite sets using lists. |
3926 |
- Executable_Rat implements rational numbers as triples (sign, enumerator, |
|
23850 | 3927 |
denominator). |
24800 | 3928 |
- Executable_Real implements a subset of real numbers, namly those |
23850 | 3929 |
representable by rational numbers. |
24800 | 3930 |
- Efficient_Nat implements natural numbers by integers, which in general will |
23850 | 3931 |
result in higher efficency; pattern matching with 0/Suc is eliminated; |
24993 | 3932 |
includes Code_Integer. |
3933 |
- Code_Index provides an additional datatype index which is mapped to |
|
3934 |
target-language built-in integers. |
|
26355 | 3935 |
- Code_Message provides an additional datatype message_string which is isomorphic to |
24993 | 3936 |
strings; messages are mapped to target-language strings. |
23850 | 3937 |
|
23783
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3938 |
* New package for inductive predicates |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3939 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3940 |
An n-ary predicate p with m parameters z_1, ..., z_m can now be defined via |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3941 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3942 |
inductive |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3943 |
p :: "U_1 => ... => U_m => T_1 => ... => T_n => bool" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3944 |
for z_1 :: U_1 and ... and z_n :: U_m |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3945 |
where |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3946 |
rule_1: "... ==> p z_1 ... z_m t_1_1 ... t_1_n" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3947 |
| ... |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3948 |
|
24800 | 3949 |
with full support for type-inference, rather than |
23783
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3950 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3951 |
consts s :: "U_1 => ... => U_m => (T_1 * ... * T_n) set" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3952 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3953 |
abbreviation p :: "U_1 => ... => U_m => T_1 => ... => T_n => bool" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3954 |
where "p z_1 ... z_m x_1 ... x_n == (x_1, ..., x_n) : s z_1 ... z_m" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3955 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3956 |
inductive "s z_1 ... z_m" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3957 |
intros |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3958 |
rule_1: "... ==> (t_1_1, ..., t_1_n) : s z_1 ... z_m" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3959 |
... |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3960 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3961 |
For backward compatibility, there is a wrapper allowing inductive |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3962 |
sets to be defined with the new package via |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3963 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3964 |
inductive_set |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3965 |
s :: "U_1 => ... => U_m => (T_1 * ... * T_n) set" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3966 |
for z_1 :: U_1 and ... and z_n :: U_m |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3967 |
where |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3968 |
rule_1: "... ==> (t_1_1, ..., t_1_n) : s z_1 ... z_m" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3969 |
| ... |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3970 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3971 |
or |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3972 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3973 |
inductive_set |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3974 |
s :: "U_1 => ... => U_m => (T_1 * ... * T_n) set" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3975 |
and p :: "U_1 => ... => U_m => T_1 => ... => T_n => bool" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3976 |
for z_1 :: U_1 and ... and z_n :: U_m |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3977 |
where |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3978 |
"p z_1 ... z_m x_1 ... x_n == (x_1, ..., x_n) : s z_1 ... z_m" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3979 |
| rule_1: "... ==> p z_1 ... z_m t_1_1 ... t_1_n" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3980 |
| ... |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3981 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3982 |
if the additional syntax "p ..." is required. |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3983 |
|
25177 | 3984 |
Numerous examples can be found in the subdirectories src/HOL/Auth, |
3985 |
src/HOL/Bali, src/HOL/Induct, and src/HOL/MicroJava. |
|
23783
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3986 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3987 |
INCOMPATIBILITIES: |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3988 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
3989 |
- Since declaration and definition of inductive sets or predicates |
24800 | 3990 |
is no longer separated, abbreviations involving the newly |
3991 |
introduced sets or predicates must be specified together with the |
|
3992 |
introduction rules after the 'where' keyword (see above), rather |
|
3993 |
than before the actual inductive definition. |
|
3994 |
||
3995 |
- The variables in induction and elimination rules are now |
|
3996 |
quantified in the order of their occurrence in the introduction |
|
3997 |
rules, rather than in alphabetical order. Since this may break |
|
3998 |
some proofs, these proofs either have to be repaired, e.g. by |
|
3999 |
reordering the variables a_i_1 ... a_i_{k_i} in Isar 'case' |
|
4000 |
statements of the form |
|
23783
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4001 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4002 |
case (rule_i a_i_1 ... a_i_{k_i}) |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4003 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4004 |
or the old order of quantification has to be restored by explicitly adding |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4005 |
meta-level quantifiers in the introduction rules, i.e. |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4006 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4007 |
| rule_i: "!!a_i_1 ... a_i_{k_i}. ... ==> p z_1 ... z_m t_i_1 ... t_i_n" |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4008 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4009 |
- The format of the elimination rules is now |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4010 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4011 |
p z_1 ... z_m x_1 ... x_n ==> |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4012 |
(!!a_1_1 ... a_1_{k_1}. x_1 = t_1_1 ==> ... ==> x_n = t_1_n ==> ... ==> P) |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4013 |
==> ... ==> P |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4014 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4015 |
for predicates and |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4016 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4017 |
(x_1, ..., x_n) : s z_1 ... z_m ==> |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4018 |
(!!a_1_1 ... a_1_{k_1}. x_1 = t_1_1 ==> ... ==> x_n = t_1_n ==> ... ==> P) |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4019 |
==> ... ==> P |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4020 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4021 |
for sets rather than |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4022 |
|
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4023 |
x : s z_1 ... z_m ==> |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4024 |
(!!a_1_1 ... a_1_{k_1}. x = (t_1_1, ..., t_1_n) ==> ... ==> P) |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4025 |
==> ... ==> P |
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4026 |
|
24800 | 4027 |
This may require terms in goals to be expanded to n-tuples |
4028 |
(e.g. using case_tac or simplification with the split_paired_all |
|
4029 |
rule) before the above elimination rule is applicable. |
|
4030 |
||
4031 |
- The elimination or case analysis rules for (mutually) inductive |
|
4032 |
sets or predicates are now called "p_1.cases" ... "p_k.cases". The |
|
4033 |
list of rules "p_1_..._p_k.elims" is no longer available. |
|
23783
e4d514f81d95
Added entry for new inductive definition package.
berghofe
parents:
23565
diff
changeset
|
4034 |
|
25198 | 4035 |
* New package "function"/"fun" for general recursive functions, |
4036 |
supporting mutual and nested recursion, definitions in local contexts, |
|
4037 |
more general pattern matching and partiality. See HOL/ex/Fundefs.thy |
|
4038 |
for small examples, and the separate tutorial on the function |
|
4039 |
package. The old recdef "package" is still available as before, but |
|
4040 |
users are encouraged to use the new package. |
|
4041 |
||
4042 |
* Method "lexicographic_order" automatically synthesizes termination |
|
4043 |
relations as lexicographic combinations of size measures. |
|
4044 |
||
24800 | 4045 |
* Case-expressions allow arbitrary constructor-patterns (including |
4046 |
"_") and take their order into account, like in functional |
|
4047 |
programming. Internally, this is translated into nested |
|
4048 |
case-expressions; missing cases are added and mapped to the predefined |
|
4049 |
constant "undefined". In complicated cases printing may no longer show |
|
4050 |
the original input but the internal form. Lambda-abstractions allow |
|
4051 |
the same form of pattern matching: "% pat1 => e1 | ..." is an |
|
4052 |
abbreviation for "%x. case x of pat1 => e1 | ..." where x is a new |
|
4053 |
variable. |
|
23564 | 4054 |
|
23468 | 4055 |
* IntDef: The constant "int :: nat => int" has been removed; now "int" |
24800 | 4056 |
is an abbreviation for "of_nat :: nat => int". The simplification |
4057 |
rules for "of_nat" have been changed to work like "int" did |
|
4058 |
previously. Potential INCOMPATIBILITY: |
|
23468 | 4059 |
- "of_nat (Suc m)" simplifies to "1 + of_nat m" instead of "of_nat m + 1" |
4060 |
- of_nat_diff and of_nat_mult are no longer default simp rules |
|
23377 | 4061 |
|
23295
86e225406859
Method "algebra" solves polynomial equations over (semi)rings
chaieb
parents:
23251
diff
changeset
|
4062 |
* Method "algebra" solves polynomial equations over (semi)rings using |
24800 | 4063 |
Groebner bases. The (semi)ring structure is defined by locales and the |
4064 |
tool setup depends on that generic context. Installing the method for |
|
4065 |
a specific type involves instantiating the locale and possibly adding |
|
4066 |
declarations for computation on the coefficients. The method is |
|
4067 |
already instantiated for natural numbers and for the axiomatic class |
|
4068 |
of idoms with numerals. See also the paper by Chaieb and Wenzel at |
|
4069 |
CALCULEMUS 2007 for the general principles underlying this |
|
4070 |
architecture of context-aware proof-tools. |
|
4071 |
||
25033 | 4072 |
* Method "ferrack" implements quantifier elimination over |
4073 |
special-purpose dense linear orders using locales (analogous to |
|
4074 |
"algebra"). The method is already installed for class |
|
4075 |
{ordered_field,recpower,number_ring} which subsumes real, hyperreal, |
|
4076 |
rat, etc. |
|
4077 |
||
24800 | 4078 |
* Former constant "List.op @" now named "List.append". Use ML |
4079 |
antiquotations @{const_name List.append} or @{term " ... @ ... "} to |
|
4080 |
circumvent possible incompatibilities when working on ML level. |
|
4081 |
||
24996 | 4082 |
* primrec: missing cases mapped to "undefined" instead of "arbitrary". |
22845 | 4083 |
|
24800 | 4084 |
* New function listsum :: 'a list => 'a for arbitrary monoids. |
4085 |
Special syntax: "SUM x <- xs. f x" (and latex variants) |
|
4086 |
||
4087 |
* New syntax for Haskell-like list comprehension (input only), eg. |
|
25177 | 4088 |
[(x,y). x <- xs, y <- ys, x ~= y], see also src/HOL/List.thy. |
24800 | 4089 |
|
4090 |
* The special syntax for function "filter" has changed from [x : |
|
4091 |
xs. P] to [x <- xs. P] to avoid an ambiguity caused by list |
|
4092 |
comprehension syntax, and for uniformity. INCOMPATIBILITY. |
|
4093 |
||
4094 |
* [a..b] is now defined for arbitrary linear orders. It used to be |
|
4095 |
defined on nat only, as an abbreviation for [a..<Suc b] |
|
4096 |
INCOMPATIBILITY. |
|
4097 |
||
4098 |
* Renamed lemma "set_take_whileD" to "set_takeWhileD". |
|
4099 |
||
25177 | 4100 |
* New functions "sorted" and "sort" in src/HOL/List.thy. |
24800 | 4101 |
|
4102 |
* New lemma collection field_simps (an extension of ring_simps) for |
|
4103 |
manipulating (in)equations involving division. Multiplies with all |
|
4104 |
denominators that can be proved to be non-zero (in equations) or |
|
4105 |
positive/negative (in inequations). |
|
23480 | 4106 |
|
4107 |
* Lemma collections ring_eq_simps, group_eq_simps and ring_distrib |
|
24800 | 4108 |
have been improved and renamed to ring_simps, group_simps and |
4109 |
ring_distribs. Removed lemmas field_xyz in theory Ring_and_Field |
|
4110 |
because they were subsumed by lemmas xyz. INCOMPATIBILITY. |
|
4111 |
||
25177 | 4112 |
* Theory Library/Commutative_Ring: switched from recdef to function |
24800 | 4113 |
package; constants add, mul, pow now curried. Infix syntax for |
4114 |
algebraic operations. |
|
22735 | 4115 |
|
24800 | 4116 |
* Dropped redundant lemma def_imp_eq in favor of meta_eq_to_obj_eq. |
22218 | 4117 |
INCOMPATIBILITY. |
4118 |
||
24800 | 4119 |
* Dropped redundant lemma if_def2 in favor of if_bool_eq_conj. |
22218 | 4120 |
INCOMPATIBILITY. |
4121 |
||
22126 | 4122 |
* HOL/records: generalised field-update to take a function on the |
4123 |
field rather than the new value: r(|A := x|) is translated to A_update |
|
4124 |
(K x) r The K-combinator that is internally used is called K_record. |
|
21226
a607ae87ee81
field-update in records is generalised to take a function on the field
schirmer
parents:
21215
diff
changeset
|
4125 |
INCOMPATIBILITY: Usage of the plain update functions has to be |
a607ae87ee81
field-update in records is generalised to take a function on the field
schirmer
parents:
21215
diff
changeset
|
4126 |
adapted. |
a607ae87ee81
field-update in records is generalised to take a function on the field
schirmer
parents:
21215
diff
changeset
|
4127 |
|
24800 | 4128 |
* Class "semiring_0" now contains annihilation axioms x * 0 = 0 and 0 |
4129 |
* x = 0, which are required for a semiring. Richer structures do not |
|
4130 |
inherit from semiring_0 anymore, because this property is a theorem |
|
4131 |
there, not an axiom. INCOMPATIBILITY: In instances of semiring_0, |
|
4132 |
there is more to prove, but this is mostly trivial. |
|
4133 |
||
4134 |
* Class "recpower" is generalized to arbitrary monoids, not just |
|
4135 |
commutative semirings. INCOMPATIBILITY: may need to incorporate |
|
25163 | 4136 |
commutativity or semiring properties additionally. |
21215
7c9337a0e30a
made locale partial_order compatible with axclass order
haftmann
parents:
21209
diff
changeset
|
4137 |
|
21099 | 4138 |
* Constant "List.list_all2" in List.thy now uses authentic syntax. |
24800 | 4139 |
INCOMPATIBILITY: translations containing list_all2 may go wrong, |
4140 |
better use 'abbreviation'. |
|
4141 |
||
4142 |
* Renamed constant "List.op mem" to "List.member". INCOMPATIBILITY. |
|
4143 |
||
22126 | 4144 |
* Numeral syntax: type 'bin' which was a mere type copy of 'int' has |
24800 | 4145 |
been abandoned in favour of plain 'int'. INCOMPATIBILITY -- |
22126 | 4146 |
significant changes for setting up numeral syntax for types: |
24800 | 4147 |
- New constants Numeral.pred and Numeral.succ instead |
20485 | 4148 |
of former Numeral.bin_pred and Numeral.bin_succ. |
4149 |
- Use integer operations instead of bin_add, bin_mult and so on. |
|
4150 |
- Numeral simplification theorems named Numeral.numeral_simps instead of Bin_simps. |
|
4151 |
- ML structure Bin_Simprocs now named Int_Numeral_Base_Simprocs. |
|
4152 |
||
25177 | 4153 |
See src/HOL/Integ/IntArith.thy for an example setup. |
4154 |
||
4155 |
* Command 'normal_form' computes the normal form of a term that may |
|
4156 |
contain free variables. For example ``normal_form "rev [a, b, c]"'' |
|
4157 |
produces ``[b, c, a]'' (without proof). This command is suitable for |
|
4158 |
heavy-duty computations because the functions are compiled to ML |
|
4159 |
first. Correspondingly, a method "normalization" is provided. See |
|
4160 |
further src/HOL/ex/NormalForm.thy and src/Tools/nbe.ML. |
|
19895 | 4161 |
|
17996 | 4162 |
* Alternative iff syntax "A <-> B" for equality on bool (with priority |
4163 |
25 like -->); output depends on the "iff" print_mode, the default is |
|
4164 |
"A = B" (with priority 50). |
|
4165 |
||
21265 | 4166 |
* Relations less (<) and less_eq (<=) are also available on type bool. |
4167 |
Modified syntax to disallow nesting without explicit parentheses, |
|
24800 | 4168 |
e.g. "(x < y) < z" or "x < (y < z)", but NOT "x < y < z". Potential |
4169 |
INCOMPATIBILITY. |
|
21265 | 4170 |
|
18674 | 4171 |
* "LEAST x:A. P" expands to "LEAST x. x:A & P" (input only). |
4172 |
||
20716
a6686a8e1b68
Changed precedence of "op O" (relation composition) from 60 to 75.
krauss
parents:
20712
diff
changeset
|
4173 |
* Relation composition operator "op O" now has precedence 75 and binds |
a6686a8e1b68
Changed precedence of "op O" (relation composition) from 60 to 75.
krauss
parents:
20712
diff
changeset
|
4174 |
stronger than union and intersection. INCOMPATIBILITY. |
a6686a8e1b68
Changed precedence of "op O" (relation composition) from 60 to 75.
krauss
parents:
20712
diff
changeset
|
4175 |
|
22126 | 4176 |
* The old set interval syntax "{m..n(}" (and relatives) has been |
4177 |
removed. Use "{m..<n}" (and relatives) instead. |
|
19377 | 4178 |
|
17865 | 4179 |
* In the context of the assumption "~(s = t)" the Simplifier rewrites |
24800 | 4180 |
"t = s" to False (by simproc "neq"). INCOMPATIBILITY, consider using |
4181 |
``declare [[simproc del: neq]]''. |
|
4182 |
||
4183 |
* Simplifier: "m dvd n" where m and n are numbers is evaluated to |
|
4184 |
True/False. |
|
4185 |
||
4186 |
* Theorem Cons_eq_map_conv no longer declared as "simp". |
|
19211 | 4187 |
|
19279 | 4188 |
* Theorem setsum_mult renamed to setsum_right_distrib. |
4189 |
||
19211 | 4190 |
* Prefer ex1I over ex_ex1I in single-step reasoning, e.g. by the |
22126 | 4191 |
``rule'' method. |
4192 |
||
24800 | 4193 |
* Reimplemented methods "sat" and "satx", with several improvements: |
4194 |
goals no longer need to be stated as "<prems> ==> False", equivalences |
|
4195 |
(i.e. "=" on type bool) are handled, variable names of the form |
|
4196 |
"lit_<n>" are no longer reserved, significant speedup. |
|
4197 |
||
4198 |
* Methods "sat" and "satx" can now replay MiniSat proof traces. |
|
22126 | 4199 |
zChaff is still supported as well. |
4200 |
||
4201 |
* 'inductive' and 'datatype': provide projections of mutual rules, |
|
4202 |
bundled as foo_bar.inducts; |
|
4203 |
||
4204 |
* Library: moved theories Parity, GCD, Binomial, Infinite_Set to |
|
4205 |
Library. |
|
21256 | 4206 |
|
4207 |
* Library: moved theory Accessible_Part to main HOL. |
|
19572
a4b3176f19dd
* Library: theory Accessible_Part has been move to main HOL.
wenzelm
parents:
19508
diff
changeset
|
4208 |
|
18446 | 4209 |
* Library: added theory Coinductive_List of potentially infinite lists |
4210 |
as greatest fixed-point. |
|
18399 | 4211 |
|
19254 | 4212 |
* Library: added theory AssocList which implements (finite) maps as |
19252 | 4213 |
association lists. |
17809
195045659c06
Tactics sat and satx reimplemented, several improvements
webertj
parents:
17806
diff
changeset
|
4214 |
|
24800 | 4215 |
* Method "evaluation" solves goals (i.e. a boolean expression) |
4216 |
efficiently by compiling it to ML. The goal is "proved" (via an |
|
4217 |
oracle) if it evaluates to True. |
|
20807 | 4218 |
|
4219 |
* Linear arithmetic now splits certain operators (e.g. min, max, abs) |
|
24800 | 4220 |
also when invoked by the simplifier. This results in the Simplifier |
4221 |
being more powerful on arithmetic goals. INCOMPATIBILITY. |
|
4222 |
Configuration option fast_arith_split_limit=0 recovers the old |
|
4223 |
behavior. |
|
20217
25b068a99d2b
linear arithmetic splits certain operators (e.g. min, max, abs)
webertj
parents:
20188
diff
changeset
|
4224 |
|
22126 | 4225 |
* Support for hex (0x20) and binary (0b1001) numerals. |
19254 | 4226 |
|
20807 | 4227 |
* New method: reify eqs (t), where eqs are equations for an |
4228 |
interpretation I :: 'a list => 'b => 'c and t::'c is an optional |
|
4229 |
parameter, computes a term s::'b and a list xs::'a list and proves the |
|
4230 |
theorem I xs s = t. This is also known as reification or quoting. The |
|
4231 |
resulting theorem is applied to the subgoal to substitute t with I xs |
|
4232 |
s. If t is omitted, the subgoal itself is reified. |
|
4233 |
||
4234 |
* New method: reflection corr_thm eqs (t). The parameters eqs and (t) |
|
4235 |
are as explained above. corr_thm is a theorem for I vs (f t) = I vs t, |
|
4236 |
where f is supposed to be a computable function (in the sense of code |
|
4237 |
generattion). The method uses reify to compute s and xs as above then |
|
4238 |
applies corr_thm and uses normalization by evaluation to "prove" f s = |
|
4239 |
r and finally gets the theorem t = r, which is again applied to the |
|
25177 | 4240 |
subgoal. An Example is available in src/HOL/ex/ReflectionEx.thy. |
4241 |
||
4242 |
* Reflection: Automatic reification now handels binding, an example is |
|
4243 |
available in src/HOL/ex/ReflectionEx.thy |
|
20807 | 4244 |
|
25397 | 4245 |
* HOL-Statespace: ``State Spaces: The Locale Way'' introduces a |
25409 | 4246 |
command 'statespace' that is similar to 'record', but introduces an |
25397 | 4247 |
abstract specification based on the locale infrastructure instead of |
4248 |
HOL types. This leads to extra flexibility in composing state spaces, |
|
4249 |
in particular multiple inheritance and renaming of components. |
|
4250 |
||
4251 |
||
19653 | 4252 |
*** HOL-Complex *** |
4253 |
||
22971 | 4254 |
* Hyperreal: Functions root and sqrt are now defined on negative real |
4255 |
inputs so that root n (- x) = - root n x and sqrt (- x) = - sqrt x. |
|
4256 |
Nonnegativity side conditions have been removed from many lemmas, so |
|
4257 |
that more subgoals may now be solved by simplification; potential |
|
4258 |
INCOMPATIBILITY. |
|
4259 |
||
24800 | 4260 |
* Real: new type classes formalize real normed vector spaces and |
21791 | 4261 |
algebras, using new overloaded constants scaleR :: real => 'a => 'a |
4262 |
and norm :: 'a => real. |
|
4263 |
||
24800 | 4264 |
* Real: constant of_real :: real => 'a::real_algebra_1 injects from |
4265 |
reals into other types. The overloaded constant Reals :: 'a set is now |
|
4266 |
defined as range of_real; potential INCOMPATIBILITY. |
|
4267 |
||
4268 |
* Real: proper support for ML code generation, including 'quickcheck'. |
|
23013 | 4269 |
Reals are implemented as arbitrary precision rationals. |
4270 |
||
22126 | 4271 |
* Hyperreal: Several constants that previously worked only for the |
4272 |
reals have been generalized, so they now work over arbitrary vector |
|
4273 |
spaces. Type annotations may need to be added in some cases; potential |
|
4274 |
INCOMPATIBILITY. |
|
21791 | 4275 |
|
22972
3e96b98d37c6
generalized sgn function to work on any real normed vector space
huffman
parents:
22971
diff
changeset
|
4276 |
Infinitesimal :: ('a::real_normed_vector) star set |
3e96b98d37c6
generalized sgn function to work on any real normed vector space
huffman
parents:
22971
diff
changeset
|
4277 |
HFinite :: ('a::real_normed_vector) star set |
3e96b98d37c6
generalized sgn function to work on any real normed vector space
huffman
parents:
22971
diff
changeset
|
4278 |
HInfinite :: ('a::real_normed_vector) star set |
21791 | 4279 |
approx :: ('a::real_normed_vector) star => 'a star => bool |
4280 |
monad :: ('a::real_normed_vector) star => 'a star set |
|
4281 |
galaxy :: ('a::real_normed_vector) star => 'a star set |
|
22972
3e96b98d37c6
generalized sgn function to work on any real normed vector space
huffman
parents:
22971
diff
changeset
|
4282 |
(NS)LIMSEQ :: [nat => 'a::real_normed_vector, 'a] => bool |
21791 | 4283 |
(NS)convergent :: (nat => 'a::real_normed_vector) => bool |
4284 |
(NS)Bseq :: (nat => 'a::real_normed_vector) => bool |
|
4285 |
(NS)Cauchy :: (nat => 'a::real_normed_vector) => bool |
|
4286 |
(NS)LIM :: ['a::real_normed_vector => 'b::real_normed_vector, 'a, 'b] => bool |
|
4287 |
is(NS)Cont :: ['a::real_normed_vector => 'b::real_normed_vector, 'a] => bool |
|
4288 |
deriv :: ['a::real_normed_field => 'a, 'a, 'a] => bool |
|
22972
3e96b98d37c6
generalized sgn function to work on any real normed vector space
huffman
parents:
22971
diff
changeset
|
4289 |
sgn :: 'a::real_normed_vector => 'a |
23116 | 4290 |
exp :: 'a::{recpower,real_normed_field,banach} => 'a |
21791 | 4291 |
|
4292 |
* Complex: Some complex-specific constants are now abbreviations for |
|
22126 | 4293 |
overloaded ones: complex_of_real = of_real, cmod = norm, hcmod = |
4294 |
hnorm. Other constants have been entirely removed in favor of the |
|
4295 |
polymorphic versions (INCOMPATIBILITY): |
|
21791 | 4296 |
|
4297 |
approx <-- capprox |
|
4298 |
HFinite <-- CFinite |
|
4299 |
HInfinite <-- CInfinite |
|
4300 |
Infinitesimal <-- CInfinitesimal |
|
4301 |
monad <-- cmonad |
|
4302 |
galaxy <-- cgalaxy |
|
4303 |
(NS)LIM <-- (NS)CLIM, (NS)CRLIM |
|
4304 |
is(NS)Cont <-- is(NS)Contc, is(NS)contCR |
|
4305 |
(ns)deriv <-- (ns)cderiv |
|
4306 |
||
19653 | 4307 |
|
24801 | 4308 |
*** HOL-Algebra *** |
4309 |
||
4310 |
* Formalisation of ideals and the quotient construction over rings. |
|
4311 |
||
4312 |
* Order and lattice theory no longer based on records. |
|
4313 |
INCOMPATIBILITY. |
|
4314 |
||
4315 |
* Renamed lemmas least_carrier -> least_closed and greatest_carrier -> |
|
4316 |
greatest_closed. INCOMPATIBILITY. |
|
4317 |
||
4318 |
* Method algebra is now set up via an attribute. For examples see |
|
4319 |
Ring.thy. INCOMPATIBILITY: the method is now weaker on combinations |
|
4320 |
of algebraic structures. |
|
4321 |
||
4322 |
* Renamed theory CRing to Ring. |
|
4323 |
||
4324 |
||
4325 |
*** HOL-Nominal *** |
|
4326 |
||
25148 | 4327 |
* Substantial, yet incomplete support for nominal datatypes (binding |
25177 | 4328 |
structures) based on HOL-Nominal logic. See src/HOL/Nominal and |
4329 |
src/HOL/Nominal/Examples. Prospective users should consult |
|
25148 | 4330 |
http://isabelle.in.tum.de/nominal/ |
4331 |
||
24801 | 4332 |
|
17878 | 4333 |
*** ML *** |
4334 |
||
24643 | 4335 |
* ML basics: just one true type int, which coincides with IntInf.int |
4336 |
(even on SML/NJ). |
|
4337 |
||
22138 | 4338 |
* ML within Isar: antiquotations allow to embed statically-checked |
4339 |
formal entities in the source, referring to the context available at |
|
4340 |
compile-time. For example: |
|
4341 |
||
25142 | 4342 |
ML {* @{sort "{zero,one}"} *} |
22138 | 4343 |
ML {* @{typ "'a => 'b"} *} |
4344 |
ML {* @{term "%x. x"} *} |
|
4345 |
ML {* @{prop "x == y"} *} |
|
4346 |
ML {* @{ctyp "'a => 'b"} *} |
|
4347 |
ML {* @{cterm "%x. x"} *} |
|
4348 |
ML {* @{cprop "x == y"} *} |
|
4349 |
ML {* @{thm asm_rl} *} |
|
4350 |
ML {* @{thms asm_rl} *} |
|
24692 | 4351 |
ML {* @{type_name c} *} |
25142 | 4352 |
ML {* @{type_syntax c} *} |
22376 | 4353 |
ML {* @{const_name c} *} |
4354 |
ML {* @{const_syntax c} *} |
|
22138 | 4355 |
ML {* @{context} *} |
4356 |
ML {* @{theory} *} |
|
4357 |
ML {* @{theory Pure} *} |
|
24692 | 4358 |
ML {* @{theory_ref} *} |
4359 |
ML {* @{theory_ref Pure} *} |
|
22138 | 4360 |
ML {* @{simpset} *} |
4361 |
ML {* @{claset} *} |
|
4362 |
ML {* @{clasimpset} *} |
|
4363 |
||
22151 | 4364 |
The same works for sources being ``used'' within an Isar context. |
4365 |
||
22152 | 4366 |
* ML in Isar: improved error reporting; extra verbosity with |
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4367 |
ML_Context.trace enabled. |
22152 | 4368 |
|
19032 | 4369 |
* Pure/General/table.ML: the join operations now works via exceptions |
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4370 |
DUP/SAME instead of type option. This is simpler in simple cases, and |
19081
085b5badb8de
* Isar/locales: new derived specification elements 'definition', 'abbreviation', 'axiomatization';
wenzelm
parents:
19034
diff
changeset
|
4371 |
admits slightly more efficient complex applications. |
18446 | 4372 |
|
24800 | 4373 |
* Pure: 'advanced' translation functions (parse_translation etc.) now |
4374 |
use Context.generic instead of just theory. |
|
4375 |
||
18642 | 4376 |
* Pure: datatype Context.generic joins theory/Proof.context and |
18644 | 4377 |
provides some facilities for code that works in either kind of |
18642 | 4378 |
context, notably GenericDataFun for uniform theory and proof data. |
4379 |
||
18737 | 4380 |
* Pure: simplified internal attribute type, which is now always |
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4381 |
Context.generic * thm -> Context.generic * thm. Global (theory) vs. |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4382 |
local (Proof.context) attributes have been discontinued, while |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4383 |
minimizing code duplication. Thm.rule_attribute and |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4384 |
Thm.declaration_attribute build canonical attributes; see also structure |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4385 |
Context for further operations on Context.generic, notably |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4386 |
GenericDataFun. INCOMPATIBILITY, need to adapt attribute type |
19006
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4387 |
declarations and definitions. |
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4388 |
|
24800 | 4389 |
* Context data interfaces (Theory/Proof/GenericDataFun): removed |
4390 |
name/print, uninitialized data defaults to ad-hoc copy of empty value, |
|
4391 |
init only required for impure data. INCOMPATIBILITY: empty really need |
|
4392 |
to be empty (no dependencies on theory content!) |
|
4393 |
||
19508 | 4394 |
* Pure/kernel: consts certification ignores sort constraints given in |
24800 | 4395 |
signature declarations. (This information is not relevant to the |
4396 |
logic, but only for type inference.) SIGNIFICANT INTERNAL CHANGE, |
|
4397 |
potential INCOMPATIBILITY. |
|
19508 | 4398 |
|
4399 |
* Pure: axiomatic type classes are now purely definitional, with |
|
4400 |
explicit proofs of class axioms and super class relations performed |
|
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4401 |
internally. See Pure/axclass.ML for the main internal interfaces -- |
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
4402 |
notably AxClass.define_class supercedes AxClass.add_axclass, and |
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4403 |
AxClass.axiomatize_class/classrel/arity supersede |
19508 | 4404 |
Sign.add_classes/classrel/arities. |
4405 |
||
19006
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4406 |
* Pure/Isar: Args/Attrib parsers operate on Context.generic -- |
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4407 |
global/local versions on theory vs. Proof.context have been |
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4408 |
discontinued; Attrib.syntax and Method.syntax have been adapted |
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4409 |
accordingly. INCOMPATIBILITY, need to adapt parser expressions for |
2427684c201c
* ML/Pure: generic Args/Attrib syntax everywhere;
wenzelm
parents:
18979
diff
changeset
|
4410 |
attributes, methods, etc. |
18642 | 4411 |
|
18446 | 4412 |
* Pure: several functions of signature "... -> theory -> theory * ..." |
4413 |
have been reoriented to "... -> theory -> ... * theory" in order to |
|
4414 |
allow natural usage in combination with the ||>, ||>>, |-> and |
|
4415 |
fold_map combinators. |
|
18051 | 4416 |
|
21647
fccafa917a68
* Pure: official theorem names and additional comments are now strictly separate.
wenzelm
parents:
21595
diff
changeset
|
4417 |
* Pure: official theorem names (closed derivations) and additional |
fccafa917a68
* Pure: official theorem names and additional comments are now strictly separate.
wenzelm
parents:
21595
diff
changeset
|
4418 |
comments (tags) are now strictly separate. Name hints -- which are |
fccafa917a68
* Pure: official theorem names and additional comments are now strictly separate.
wenzelm
parents:
21595
diff
changeset
|
4419 |
maintained as tags -- may be attached any time without affecting the |
fccafa917a68
* Pure: official theorem names and additional comments are now strictly separate.
wenzelm
parents:
21595
diff
changeset
|
4420 |
derivation. |
fccafa917a68
* Pure: official theorem names and additional comments are now strictly separate.
wenzelm
parents:
21595
diff
changeset
|
4421 |
|
18020 | 4422 |
* Pure: primitive rule lift_rule now takes goal cterm instead of an |
18145 | 4423 |
actual goal state (thm). Use Thm.lift_rule (Thm.cprem_of st i) to |
18020 | 4424 |
achieve the old behaviour. |
4425 |
||
4426 |
* Pure: the "Goal" constant is now called "prop", supporting a |
|
4427 |
slightly more general idea of ``protecting'' meta-level rule |
|
4428 |
statements. |
|
4429 |
||
20040
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4430 |
* Pure: Logic.(un)varify only works in a global context, which is now |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4431 |
enforced instead of silently assumed. INCOMPATIBILITY, may use |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4432 |
Logic.legacy_(un)varify as temporary workaround. |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4433 |
|
20090 | 4434 |
* Pure: structure Name provides scalable operations for generating |
4435 |
internal variable names, notably Name.variants etc. This replaces |
|
4436 |
some popular functions from term.ML: |
|
4437 |
||
4438 |
Term.variant -> Name.variant |
|
24800 | 4439 |
Term.variantlist -> Name.variant_list |
20090 | 4440 |
Term.invent_names -> Name.invent_list |
4441 |
||
4442 |
Note that low-level renaming rarely occurs in new code -- operations |
|
4443 |
from structure Variable are used instead (see below). |
|
4444 |
||
20040
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4445 |
* Pure: structure Variable provides fundamental operations for proper |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4446 |
treatment of fixed/schematic variables in a context. For example, |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4447 |
Variable.import introduces fixes for schematics of given facts and |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4448 |
Variable.export reverses the effect (up to renaming) -- this replaces |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4449 |
various freeze_thaw operations. |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4450 |
|
18567 | 4451 |
* Pure: structure Goal provides simple interfaces for |
17981
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
4452 |
init/conclude/finish and tactical prove operations (replacing former |
20040
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4453 |
Tactic.prove). Goal.prove is the canonical way to prove results |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4454 |
within a given context; Goal.prove_global is a degraded version for |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4455 |
theory level goals, including a global Drule.standard. Note that |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4456 |
OldGoals.prove_goalw_cterm has long been obsolete, since it is |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4457 |
ill-behaved in a local proof context (e.g. with local fixes/assumes or |
02c59ec2f2e1
* Pure: structure Variable provides operations for proper treatment of fixed/schematic variables;
wenzelm
parents:
20013
diff
changeset
|
4458 |
in a locale context). |
17981
2602be0d99ae
* Legacy goal package: reduced interface to the bare minimum required to keep existing proof scripts running.
wenzelm
parents:
17918
diff
changeset
|
4459 |
|
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4460 |
* Pure/Syntax: generic interfaces for parsing (Syntax.parse_term etc.) |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4461 |
and type checking (Syntax.check_term etc.), with common combinations |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4462 |
(Syntax.read_term etc.). These supersede former Sign.read_term etc. |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4463 |
which are considered legacy and await removal. |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4464 |
|
24920 | 4465 |
* Pure/Syntax: generic interfaces for type unchecking |
4466 |
(Syntax.uncheck_terms etc.) and unparsing (Syntax.unparse_term etc.), |
|
4467 |
with common combinations (Syntax.pretty_term, Syntax.string_of_term |
|
4468 |
etc.). Former Sign.pretty_term, Sign.string_of_term etc. are still |
|
24924 | 4469 |
available for convenience, but refer to the very same operations using |
4470 |
a mere theory instead of a full context. |
|
24920 | 4471 |
|
18815
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
4472 |
* Isar: simplified treatment of user-level errors, using exception |
18687 | 4473 |
ERROR of string uniformly. Function error now merely raises ERROR, |
18686
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4474 |
without any side effect on output channels. The Isar toplevel takes |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4475 |
care of proper display of ERROR exceptions. ML code may use plain |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4476 |
handle/can/try; cat_error may be used to concatenate errors like this: |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4477 |
|
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4478 |
... handle ERROR msg => cat_error msg "..." |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4479 |
|
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4480 |
Toplevel ML code (run directly or through the Isar toplevel) may be |
18687 | 4481 |
embedded into the Isar toplevel with exception display/debug like |
4482 |
this: |
|
18686
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4483 |
|
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4484 |
Isar.toplevel (fn () => ...) |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4485 |
|
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4486 |
INCOMPATIBILITY, removed special transform_error facilities, removed |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4487 |
obsolete variants of user-level exceptions (ERROR_MESSAGE, |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4488 |
Context.PROOF, ProofContext.CONTEXT, Proof.STATE, ProofHistory.FAIL) |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4489 |
-- use plain ERROR instead. |
cbbc71acf994
* ML/Isar: simplified treatment of user-level errors;
wenzelm
parents:
18674
diff
changeset
|
4490 |
|
18815
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
4491 |
* Isar: theory setup now has type (theory -> theory), instead of a |
18722
0888eca0f1be
* ML/Isar: theory setup has type (theory -> theory);
wenzelm
parents:
18696
diff
changeset
|
4492 |
list. INCOMPATIBILITY, may use #> to compose setup functions. |
0888eca0f1be
* ML/Isar: theory setup has type (theory -> theory);
wenzelm
parents:
18696
diff
changeset
|
4493 |
|
24706
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4494 |
* Isar: ML toplevel pretty printer for type Proof.context, subject to |
c58547ff329b
* Pure/Syntax: generic interfaces for parsing and type checking;
wenzelm
parents:
24699
diff
changeset
|
4495 |
ProofContext.debug/verbose flags. |
18815
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
4496 |
|
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
4497 |
* Isar: Toplevel.theory_to_proof admits transactions that modify the |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
4498 |
theory before entering a proof state. Transactions now always see a |
cb778c0ce1b5
Pure/Isar: (un)folded, (un)fold, unfolding support
wenzelm
parents:
18738
diff
changeset
|
4499 |
quasi-functional intermediate checkpoint, both in interactive and |
18590
f6a553aa3d81
Pure/Isar: Toplevel.theory_to_proof admits transactions that modify the theory;
wenzelm
parents:
18568
diff
changeset
|
4500 |
batch mode. |
18567 | 4501 |
|
24867 | 4502 |
* Isar: simplified interfaces for outer syntax. Renamed |
4503 |
OuterSyntax.add_keywords to OuterSyntax.keywords. Removed |
|
4504 |
OuterSyntax.add_parsers -- this functionality is now included in |
|
4505 |
OuterSyntax.command etc. INCOMPATIBILITY. |
|
4506 |
||
17878 | 4507 |
* Simplifier: the simpset of a running simplification process now |
4508 |
contains a proof context (cf. Simplifier.the_context), which is the |
|
4509 |
very context that the initial simpset has been retrieved from (by |
|
17890 | 4510 |
simpset_of/local_simpset_of). Consequently, all plug-in components |
17878 | 4511 |
(solver, looper etc.) may depend on arbitrary proof data. |
4512 |
||
4513 |
* Simplifier.inherit_context inherits the proof context (plus the |
|
4514 |
local bounds) of the current simplification process; any simproc |
|
4515 |
etc. that calls the Simplifier recursively should do this! Removed |
|
4516 |
former Simplifier.inherit_bounds, which is already included here -- |
|
17890 | 4517 |
INCOMPATIBILITY. Tools based on low-level rewriting may even have to |
4518 |
specify an explicit context using Simplifier.context/theory_context. |
|
17878 | 4519 |
|
4520 |
* Simplifier/Classical Reasoner: more abstract interfaces |
|
4521 |
change_simpset/claset for modifying the simpset/claset reference of a |
|
4522 |
theory; raw versions simpset/claset_ref etc. have been discontinued -- |
|
4523 |
INCOMPATIBILITY. |
|
4524 |
||
18540 | 4525 |
* Provers: more generic wrt. syntax of object-logics, avoid hardwired |
4526 |
"Trueprop" etc. |
|
4527 |
||
17878 | 4528 |
|
20988
0887d0dd3210
* isabelle-process: option -S (secure mode) disables some critical operations;
wenzelm
parents:
20951
diff
changeset
|
4529 |
*** System *** |
0887d0dd3210
* isabelle-process: option -S (secure mode) disables some critical operations;
wenzelm
parents:
20951
diff
changeset
|
4530 |
|
25433 | 4531 |
* settings: the default heap location within ISABELLE_HOME_USER now |
4532 |
includes ISABELLE_IDENTIFIER. This simplifies use of multiple |
|
4533 |
Isabelle installations. |
|
21471
03a5ef1936c5
* settings: ML_IDENTIFIER includes the Isabelle version identifier;
wenzelm
parents:
21462
diff
changeset
|
4534 |
|
20988
0887d0dd3210
* isabelle-process: option -S (secure mode) disables some critical operations;
wenzelm
parents:
20951
diff
changeset
|
4535 |
* isabelle-process: option -S (secure mode) disables some critical |
0887d0dd3210
* isabelle-process: option -S (secure mode) disables some critical operations;
wenzelm
parents:
20951
diff
changeset
|
4536 |
operations, notably runtime compilation and evaluation of ML source |
0887d0dd3210
* isabelle-process: option -S (secure mode) disables some critical operations;
wenzelm
parents:
20951
diff
changeset
|
4537 |
code. |
0887d0dd3210
* isabelle-process: option -S (secure mode) disables some critical operations;
wenzelm
parents:
20951
diff
changeset
|
4538 |
|
24891 | 4539 |
* Basic Isabelle mode for jEdit, see Isabelle/lib/jedit/. |
4540 |
||
24801 | 4541 |
* Support for parallel execution, using native multicore support of |
24800 | 4542 |
Poly/ML 5.1. The theory loader exploits parallelism when processing |
4543 |
independent theories, according to the given theory header |
|
4544 |
specifications. The maximum number of worker threads is specified via |
|
4545 |
usedir option -M or the "max-threads" setting in Proof General. A |
|
4546 |
speedup factor of 1.5--3.5 can be expected on a 4-core machine, and up |
|
4547 |
to 6 on a 8-core machine. User-code needs to observe certain |
|
4548 |
guidelines for thread-safe programming, see appendix A in the Isar |
|
4549 |
Implementation manual. |
|
24210
a865059c4fcb
* Experimental support for multithreading, using Poly/ML 5.1;
wenzelm
parents:
24187
diff
changeset
|
4550 |
|
17754
58a306d9f736
* Command 'find_theorems': support * wildcard in name: criterion.
wenzelm
parents:
17725
diff
changeset
|
4551 |
|
25448 | 4552 |
|
17720 | 4553 |
New in Isabelle2005 (October 2005) |
4554 |
---------------------------------- |
|
14655
8a95abf87dd3
Pure: considerably improved version of 'constdefs' command;
wenzelm
parents:
14624
diff
changeset
|
4555 |
|
8a95abf87dd3
Pure: considerably improved version of 'constdefs' command;
wenzelm
parents:
14624
diff
changeset
|
4556 |
*** General *** |
8a95abf87dd3
Pure: considerably improved version of 'constdefs' command;
wenzelm
parents:
14624
diff
changeset
|
4557 |
|
15130 | 4558 |
* Theory headers: the new header syntax for Isar theories is |
4559 |
||
4560 |
theory <name> |
|
16234 | 4561 |
imports <theory1> ... <theoryN> |
4562 |
uses <file1> ... <fileM> |
|
15130 | 4563 |
begin |
4564 |
||
16234 | 4565 |
where the 'uses' part is optional. The previous syntax |
4566 |
||
4567 |
theory <name> = <theory1> + ... + <theoryN>: |
|
4568 |
||
16717 | 4569 |
will disappear in the next release. Use isatool fixheaders to convert |
4570 |
existing theory files. Note that there is no change in ancient |
|
17371 | 4571 |
non-Isar theories now, but these will disappear soon. |
15130 | 4572 |
|
15475
fdf9434b04ea
- Proofs are now hidden by default when generating documents
berghofe
parents:
15454
diff
changeset
|
4573 |
* Theory loader: parent theories can now also be referred to via |
16234 | 4574 |
relative and absolute paths. |
4575 |
||
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4576 |
* Command 'find_theorems' searches for a list of criteria instead of a |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4577 |
list of constants. Known criteria are: intro, elim, dest, name:string, |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4578 |
simp:term, and any term. Criteria can be preceded by '-' to select |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4579 |
theorems that do not match. Intro, elim, dest select theorems that |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4580 |
match the current goal, name:s selects theorems whose fully qualified |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4581 |
name contain s, and simp:term selects all simplification rules whose |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4582 |
lhs match term. Any other term is interpreted as pattern and selects |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4583 |
all theorems matching the pattern. Available in ProofGeneral under |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4584 |
'ProofGeneral -> Find Theorems' or C-c C-f. Example: |
16234 | 4585 |
|
17275
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4586 |
C-c C-f (100) "(_::nat) + _ + _" intro -name: "HOL." |
16234 | 4587 |
|
4588 |
prints the last 100 theorems matching the pattern "(_::nat) + _ + _", |
|
4589 |
matching the current goal as introduction rule and not having "HOL." |
|
4590 |
in their name (i.e. not being defined in theory HOL). |
|
16013
3010430d894d
removed find_rewrites (superceded by improved thms_containing);
wenzelm
parents:
16000
diff
changeset
|
4591 |
|
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4592 |
* Command 'thms_containing' has been discontinued in favour of |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4593 |
'find_theorems'; INCOMPATIBILITY. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4594 |
|
17385 | 4595 |
* Communication with Proof General is now 8bit clean, which means that |
4596 |
Unicode text in UTF-8 encoding may be used within theory texts (both |
|
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
4597 |
formal and informal parts). Cf. option -U of the Isabelle Proof |
17538 | 4598 |
General interface. Here are some simple examples (cf. src/HOL/ex): |
4599 |
||
4600 |
http://isabelle.in.tum.de/library/HOL/ex/Hebrew.html |
|
4601 |
http://isabelle.in.tum.de/library/HOL/ex/Chinese.html |
|
17385 | 4602 |
|
17425 | 4603 |
* Improved efficiency of the Simplifier and, to a lesser degree, the |
4604 |
Classical Reasoner. Typical big applications run around 2 times |
|
4605 |
faster. |
|
4606 |
||
15703 | 4607 |
|
4608 |
*** Document preparation *** |
|
4609 |
||
16234 | 4610 |
* Commands 'display_drafts' and 'print_drafts' perform simple output |
4611 |
of raw sources. Only those symbols that do not require additional |
|
4612 |
LaTeX packages (depending on comments in isabellesym.sty) are |
|
4613 |
displayed properly, everything else is left verbatim. isatool display |
|
4614 |
and isatool print are used as front ends (these are subject to the |
|
4615 |
DVI/PDF_VIEWER and PRINT_COMMAND settings, respectively). |
|
4616 |
||
17047
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4617 |
* Command tags control specific markup of certain regions of text, |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4618 |
notably folding and hiding. Predefined tags include "theory" (for |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4619 |
theory begin and end), "proof" for proof commands, and "ML" for |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4620 |
commands involving ML code; the additional tags "visible" and |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4621 |
"invisible" are unused by default. Users may give explicit tag |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4622 |
specifications in the text, e.g. ''by %invisible (auto)''. The |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4623 |
interpretation of tags is determined by the LaTeX job during document |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4624 |
preparation: see option -V of isatool usedir, or options -n and -t of |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4625 |
isatool document, or even the LaTeX macros \isakeeptag, \isafoldtag, |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4626 |
\isadroptag. |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4627 |
|
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4628 |
Several document versions may be produced at the same time via isatool |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4629 |
usedir (the generated index.html will link all of them). Typical |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4630 |
specifications include ''-V document=theory,proof,ML'' to present |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4631 |
theory/proof/ML parts faithfully, ''-V outline=/proof,/ML'' to fold |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4632 |
proof and ML commands, and ''-V mutilated=-theory,-proof,-ML'' to omit |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4633 |
these parts without any formal replacement text. The Isabelle site |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4634 |
default settings produce ''document'' and ''outline'' versions as |
e2e2d75bb37b
* Command tags control specific markup of certain regions of text (replaces usedir -H);
wenzelm
parents:
17016
diff
changeset
|
4635 |
specified above. |
16234 | 4636 |
|
17402 | 4637 |
* Several new antiquotations: |
15979 | 4638 |
|
4639 |
@{term_type term} prints a term with its type annotated; |
|
4640 |
||
4641 |
@{typeof term} prints the type of a term; |
|
4642 |
||
16234 | 4643 |
@{const const} is the same as @{term const}, but checks that the |
4644 |
argument is a known logical constant; |
|
15979 | 4645 |
|
4646 |
@{term_style style term} and @{thm_style style thm} print a term or |
|
16234 | 4647 |
theorem applying a "style" to it |
4648 |
||
17117
e2bed9e82454
* The ML antiquotation prints type-checked ML expressions verbatim.
wenzelm
parents:
17097
diff
changeset
|
4649 |
@{ML text} |
e2bed9e82454
* The ML antiquotation prints type-checked ML expressions verbatim.
wenzelm
parents:
17097
diff
changeset
|
4650 |
|
16234 | 4651 |
Predefined styles are 'lhs' and 'rhs' printing the lhs/rhs of |
4652 |
definitions, equations, inequations etc., 'concl' printing only the |
|
17393 | 4653 |
conclusion of a meta-logical statement theorem, and 'prem1' .. 'prem19' |
16234 | 4654 |
to print the specified premise. TermStyle.add_style provides an ML |
4655 |
interface for introducing further styles. See also the "LaTeX Sugar" |
|
17117
e2bed9e82454
* The ML antiquotation prints type-checked ML expressions verbatim.
wenzelm
parents:
17097
diff
changeset
|
4656 |
document practical applications. The ML antiquotation prints |
e2bed9e82454
* The ML antiquotation prints type-checked ML expressions verbatim.
wenzelm
parents:
17097
diff
changeset
|
4657 |
type-checked ML expressions verbatim. |
16234 | 4658 |
|
17259
dda237f1d299
Markup commands 'chapter' .. 'text' support optional locale specification;
wenzelm
parents:
17228
diff
changeset
|
4659 |
* Markup commands 'chapter', 'section', 'subsection', 'subsubsection', |
dda237f1d299
Markup commands 'chapter' .. 'text' support optional locale specification;
wenzelm
parents:
17228
diff
changeset
|
4660 |
and 'text' support optional locale specification '(in loc)', which |
17269 | 4661 |
specifies the default context for interpreting antiquotations. For |
4662 |
example: 'text (in lattice) {* @{thm inf_assoc}*}'. |
|
17259
dda237f1d299
Markup commands 'chapter' .. 'text' support optional locale specification;
wenzelm
parents:
17228
diff
changeset
|
4663 |
|
dda237f1d299
Markup commands 'chapter' .. 'text' support optional locale specification;
wenzelm
parents:
17228
diff
changeset
|
4664 |
* Option 'locale=NAME' of antiquotations specifies an alternative |
dda237f1d299
Markup commands 'chapter' .. 'text' support optional locale specification;
wenzelm
parents:
17228
diff
changeset
|
4665 |
context interpreting the subsequent argument. For example: @{thm |
17269 | 4666 |
[locale=lattice] inf_assoc}. |
17259
dda237f1d299
Markup commands 'chapter' .. 'text' support optional locale specification;
wenzelm
parents:
17228
diff
changeset
|
4667 |
|
17097
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4668 |
* Proper output of proof terms (@{prf ...} and @{full_prf ...}) within |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4669 |
a proof context. |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4670 |
|
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4671 |
* Proper output of antiquotations for theory commands involving a |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4672 |
proof context (such as 'locale' or 'theorem (in loc) ...'). |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4673 |
|
17193
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4674 |
* Delimiters of outer tokens (string etc.) now produce separate LaTeX |
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4675 |
macros (\isachardoublequoteopen, isachardoublequoteclose etc.). |
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4676 |
|
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4677 |
* isatool usedir: new option -C (default true) controls whether option |
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4678 |
-D should include a copy of the original document directory; -C false |
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4679 |
prevents unwanted effects such as copying of administrative CVS data. |
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
4680 |
|
16234 | 4681 |
|
4682 |
*** Pure *** |
|
4683 |
||
4684 |
* Considerably improved version of 'constdefs' command. Now performs |
|
4685 |
automatic type-inference of declared constants; additional support for |
|
4686 |
local structure declarations (cf. locales and HOL records), see also |
|
4687 |
isar-ref manual. Potential INCOMPATIBILITY: need to observe strictly |
|
4688 |
sequential dependencies of definitions within a single 'constdefs' |
|
4689 |
section; moreover, the declared name needs to be an identifier. If |
|
4690 |
all fails, consider to fall back on 'consts' and 'defs' separately. |
|
4691 |
||
4692 |
* Improved indexed syntax and implicit structures. First of all, |
|
4693 |
indexed syntax provides a notational device for subscripted |
|
4694 |
application, using the new syntax \<^bsub>term\<^esub> for arbitrary |
|
4695 |
expressions. Secondly, in a local context with structure |
|
4696 |
declarations, number indexes \<^sub>n or the empty index (default |
|
4697 |
number 1) refer to a certain fixed variable implicitly; option |
|
4698 |
show_structs controls printing of implicit structures. Typical |
|
4699 |
applications of these concepts involve record types and locales. |
|
4700 |
||
4701 |
* New command 'no_syntax' removes grammar declarations (and |
|
4702 |
translations) resulting from the given syntax specification, which is |
|
4703 |
interpreted in the same manner as for the 'syntax' command. |
|
4704 |
||
4705 |
* 'Advanced' translation functions (parse_translation etc.) may depend |
|
4706 |
on the signature of the theory context being presently used for |
|
4707 |
parsing/printing, see also isar-ref manual. |
|
4708 |
||
16856 | 4709 |
* Improved 'oracle' command provides a type-safe interface to turn an |
4710 |
ML expression of type theory -> T -> term into a primitive rule of |
|
4711 |
type theory -> T -> thm (i.e. the functionality of Thm.invoke_oracle |
|
4712 |
is already included here); see also FOL/ex/IffExample.thy; |
|
4713 |
INCOMPATIBILITY. |
|
4714 |
||
17275
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4715 |
* axclass: name space prefix for class "c" is now "c_class" (was "c" |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4716 |
before); "cI" is no longer bound, use "c.intro" instead. |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4717 |
INCOMPATIBILITY. This change avoids clashes of fact bindings for |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4718 |
axclasses vs. locales. |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4719 |
|
16234 | 4720 |
* Improved internal renaming of symbolic identifiers -- attach primes |
4721 |
instead of base 26 numbers. |
|
4722 |
||
4723 |
* New flag show_question_marks controls printing of leading question |
|
4724 |
marks in schematic variable names. |
|
4725 |
||
4726 |
* In schematic variable names, *any* symbol following \<^isub> or |
|
4727 |
\<^isup> is now treated as part of the base name. For example, the |
|
4728 |
following works without printing of awkward ".0" indexes: |
|
4729 |
||
4730 |
lemma "x\<^isub>1 = x\<^isub>2 ==> x\<^isub>2 = x\<^isub>1" |
|
4731 |
by simp |
|
4732 |
||
4733 |
* Inner syntax includes (*(*nested*) comments*). |
|
4734 |
||
17548 | 4735 |
* Pretty printer now supports unbreakable blocks, specified in mixfix |
16234 | 4736 |
annotations as "(00...)". |
4737 |
||
4738 |
* Clear separation of logical types and nonterminals, where the latter |
|
4739 |
may only occur in 'syntax' specifications or type abbreviations. |
|
4740 |
Before that distinction was only partially implemented via type class |
|
4741 |
"logic" vs. "{}". Potential INCOMPATIBILITY in rare cases of improper |
|
4742 |
use of 'types'/'consts' instead of 'nonterminals'/'syntax'. Some very |
|
4743 |
exotic syntax specifications may require further adaption |
|
17691 | 4744 |
(e.g. Cube/Cube.thy). |
16234 | 4745 |
|
4746 |
* Removed obsolete type class "logic", use the top sort {} instead. |
|
4747 |
Note that non-logical types should be declared as 'nonterminals' |
|
4748 |
rather than 'types'. INCOMPATIBILITY for new object-logic |
|
4749 |
specifications. |
|
4750 |
||
17095 | 4751 |
* Attributes 'induct' and 'cases': type or set names may now be |
4752 |
locally fixed variables as well. |
|
4753 |
||
16234 | 4754 |
* Simplifier: can now control the depth to which conditional rewriting |
4755 |
is traced via the PG menu Isabelle -> Settings -> Trace Simp Depth |
|
4756 |
Limit. |
|
4757 |
||
4758 |
* Simplifier: simplification procedures may now take the current |
|
4759 |
simpset into account (cf. Simplifier.simproc(_i) / mk_simproc |
|
4760 |
interface), which is very useful for calling the Simplifier |
|
4761 |
recursively. Minor INCOMPATIBILITY: the 'prems' argument of simprocs |
|
4762 |
is gone -- use prems_of_ss on the simpset instead. Moreover, the |
|
4763 |
low-level mk_simproc no longer applies Logic.varify internally, to |
|
4764 |
allow for use in a context of fixed variables. |
|
4765 |
||
4766 |
* thin_tac now works even if the assumption being deleted contains !! |
|
4767 |
or ==>. More generally, erule now works even if the major premise of |
|
4768 |
the elimination rule contains !! or ==>. |
|
4769 |
||
17597 | 4770 |
* Method 'rules' has been renamed to 'iprover'. INCOMPATIBILITY. |
17590 | 4771 |
|
16234 | 4772 |
* Reorganized bootstrapping of the Pure theories; CPure is now derived |
4773 |
from Pure, which contains all common declarations already. Both |
|
4774 |
theories are defined via plain Isabelle/Isar .thy files. |
|
4775 |
INCOMPATIBILITY: elements of CPure (such as the CPure.intro / |
|
4776 |
CPure.elim / CPure.dest attributes) now appear in the Pure name space; |
|
4777 |
use isatool fixcpure to adapt your theory and ML sources. |
|
4778 |
||
4779 |
* New syntax 'name(i-j, i-, i, ...)' for referring to specific |
|
4780 |
selections of theorems in named facts via index ranges. |
|
4781 |
||
17097
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4782 |
* 'print_theorems': in theory mode, really print the difference |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4783 |
wrt. the last state (works for interactive theory development only), |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4784 |
in proof mode print all local facts (cf. 'print_facts'); |
78f1b66f70a4
* Proper output of proof terms within a proof context;
wenzelm
parents:
17095
diff
changeset
|
4785 |
|
17397 | 4786 |
* 'hide': option '(open)' hides only base names. |
4787 |
||
17275
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4788 |
* More efficient treatment of intermediate checkpoints in interactive |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4789 |
theory development. |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4790 |
|
17663
28be54ff74f8
Added entries for code_module, code_library, and value.
berghofe
parents:
17641
diff
changeset
|
4791 |
* Code generator is now invoked via code_module (incremental code |
17664 | 4792 |
generation) and code_library (modular code generation, ML structures |
4793 |
for each theory). INCOMPATIBILITY: new keywords 'file' and 'contains' |
|
4794 |
must be quoted when used as identifiers. |
|
4795 |
||
4796 |
* New 'value' command for reading, evaluating and printing terms using |
|
4797 |
the code generator. INCOMPATIBILITY: command keyword 'value' must be |
|
4798 |
quoted when used as identifier. |
|
17663
28be54ff74f8
Added entries for code_module, code_library, and value.
berghofe
parents:
17641
diff
changeset
|
4799 |
|
16234 | 4800 |
|
4801 |
*** Locales *** |
|
17095 | 4802 |
|
17385 | 4803 |
* New commands for the interpretation of locale expressions in |
4804 |
theories (1), locales (2) and proof contexts (3). These generate |
|
4805 |
proof obligations from the expression specification. After the |
|
4806 |
obligations have been discharged, theorems of the expression are added |
|
4807 |
to the theory, target locale or proof context. The synopsis of the |
|
4808 |
commands is a follows: |
|
4809 |
||
17095 | 4810 |
(1) interpretation expr inst |
4811 |
(2) interpretation target < expr |
|
4812 |
(3) interpret expr inst |
|
17385 | 4813 |
|
17095 | 4814 |
Interpretation in theories and proof contexts require a parameter |
4815 |
instantiation of terms from the current context. This is applied to |
|
17385 | 4816 |
specifications and theorems of the interpreted expression. |
4817 |
Interpretation in locales only permits parameter renaming through the |
|
4818 |
locale expression. Interpretation is smart in that interpretations |
|
4819 |
that are active already do not occur in proof obligations, neither are |
|
4820 |
instantiated theorems stored in duplicate. Use 'print_interps' to |
|
4821 |
inspect active interpretations of a particular locale. For details, |
|
17436 | 4822 |
see the Isar Reference manual. Examples can be found in |
4823 |
HOL/Finite_Set.thy and HOL/Algebra/UnivPoly.thy. |
|
16234 | 4824 |
|
4825 |
INCOMPATIBILITY: former 'instantiate' has been withdrawn, use |
|
4826 |
'interpret' instead. |
|
4827 |
||
17385 | 4828 |
* New context element 'constrains' for adding type constraints to |
4829 |
parameters. |
|
4830 |
||
4831 |
* Context expressions: renaming of parameters with syntax |
|
4832 |
redeclaration. |
|
17095 | 4833 |
|
4834 |
* Locale declaration: 'includes' disallowed. |
|
4835 |
||
16234 | 4836 |
* Proper static binding of attribute syntax -- i.e. types / terms / |
4837 |
facts mentioned as arguments are always those of the locale definition |
|
4838 |
context, independently of the context of later invocations. Moreover, |
|
4839 |
locale operations (renaming and type / term instantiation) are applied |
|
4840 |
to attribute arguments as expected. |
|
4841 |
||
4842 |
INCOMPATIBILITY of the ML interface: always pass Attrib.src instead of |
|
4843 |
actual attributes; rare situations may require Attrib.attribute to |
|
4844 |
embed those attributes into Attrib.src that lack concrete syntax. |
|
4845 |
Attribute implementations need to cooperate properly with the static |
|
4846 |
binding mechanism. Basic parsers Args.XXX_typ/term/prop and |
|
4847 |
Attrib.XXX_thm etc. already do the right thing without further |
|
4848 |
intervention. Only unusual applications -- such as "where" or "of" |
|
4849 |
(cf. src/Pure/Isar/attrib.ML), which process arguments depending both |
|
4850 |
on the context and the facts involved -- may have to assign parsed |
|
4851 |
values to argument tokens explicitly. |
|
4852 |
||
4853 |
* Changed parameter management in theorem generation for long goal |
|
4854 |
statements with 'includes'. INCOMPATIBILITY: produces a different |
|
4855 |
theorem statement in rare situations. |
|
4856 |
||
17228 | 4857 |
* Locale inspection command 'print_locale' omits notes elements. Use |
4858 |
'print_locale!' to have them included in the output. |
|
4859 |
||
16234 | 4860 |
|
4861 |
*** Provers *** |
|
4862 |
||
4863 |
* Provers/hypsubst.ML: improved version of the subst method, for |
|
4864 |
single-step rewriting: it now works in bound variable contexts. New is |
|
4865 |
'subst (asm)', for rewriting an assumption. INCOMPATIBILITY: may |
|
4866 |
rewrite a different subterm than the original subst method, which is |
|
4867 |
still available as 'simplesubst'. |
|
4868 |
||
4869 |
* Provers/quasi.ML: new transitivity reasoners for transitivity only |
|
4870 |
and quasi orders. |
|
4871 |
||
4872 |
* Provers/trancl.ML: new transitivity reasoner for transitive and |
|
4873 |
reflexive-transitive closure of relations. |
|
4874 |
||
4875 |
* Provers/blast.ML: new reference depth_limit to make blast's depth |
|
4876 |
limit (previously hard-coded with a value of 20) user-definable. |
|
4877 |
||
4878 |
* Provers/simplifier.ML has been moved to Pure, where Simplifier.setup |
|
4879 |
is peformed already. Object-logics merely need to finish their |
|
4880 |
initial simpset configuration as before. INCOMPATIBILITY. |
|
15703 | 4881 |
|
15475
fdf9434b04ea
- Proofs are now hidden by default when generating documents
berghofe
parents:
15454
diff
changeset
|
4882 |
|
14700
2f885b7e5ba7
reimplementation of HOL records; only one type is created for
schirmer
parents:
14699
diff
changeset
|
4883 |
*** HOL *** |
2f885b7e5ba7
reimplementation of HOL records; only one type is created for
schirmer
parents:
14699
diff
changeset
|
4884 |
|
16234 | 4885 |
* Symbolic syntax of Hilbert Choice Operator is now as follows: |
14878 | 4886 |
|
4887 |
syntax (epsilon) |
|
4888 |
"_Eps" :: "[pttrn, bool] => 'a" ("(3\<some>_./ _)" [0, 10] 10) |
|
4889 |
||
16234 | 4890 |
The symbol \<some> is displayed as the alternative epsilon of LaTeX |
4891 |
and x-symbol; use option '-m epsilon' to get it actually printed. |
|
4892 |
Moreover, the mathematically important symbolic identifier \<epsilon> |
|
4893 |
becomes available as variable, constant etc. INCOMPATIBILITY, |
|
4894 |
||
4895 |
* "x > y" abbreviates "y < x" and "x >= y" abbreviates "y <= x". |
|
4896 |
Similarly for all quantifiers: "ALL x > y" etc. The x-symbol for >= |
|
17371 | 4897 |
is \<ge>. New transitivity rules have been added to HOL/Orderings.thy to |
17016
73c74cb1d744
mentioned change to exp_ge_add_one_self, new transitivity rules
avigad
parents:
16997
diff
changeset
|
4898 |
support corresponding Isar calculations. |
16234 | 4899 |
|
4900 |
* "{x:A. P}" abbreviates "{x. x:A & P}", and similarly for "\<in>" |
|
4901 |
instead of ":". |
|
4902 |
||
4903 |
* theory SetInterval: changed the syntax for open intervals: |
|
4904 |
||
4905 |
Old New |
|
4906 |
{..n(} {..<n} |
|
4907 |
{)n..} {n<..} |
|
4908 |
{m..n(} {m..<n} |
|
4909 |
{)m..n} {m<..n} |
|
4910 |
{)m..n(} {m<..<n} |
|
4911 |
||
4912 |
The old syntax is still supported but will disappear in the next |
|
4913 |
release. For conversion use the following Emacs search and replace |
|
4914 |
patterns (these are not perfect but work quite well): |
|
15046 | 4915 |
|
4916 |
{)\([^\.]*\)\.\. -> {\1<\.\.} |
|
4917 |
\.\.\([^(}]*\)(} -> \.\.<\1} |
|
4918 |
||
17533 | 4919 |
* Theory Commutative_Ring (in Library): method comm_ring for proving |
4920 |
equalities in commutative rings; method 'algebra' provides a generic |
|
4921 |
interface. |
|
17389
b4743198b939
Method comm_ring for proving equalities in commutative rings.
wenzelm
parents:
17385
diff
changeset
|
4922 |
|
b4743198b939
Method comm_ring for proving equalities in commutative rings.
wenzelm
parents:
17385
diff
changeset
|
4923 |
* Theory Finite_Set: changed the syntax for 'setsum', summation over |
16234 | 4924 |
finite sets: "setsum (%x. e) A", which used to be "\<Sum>x:A. e", is |
17371 | 4925 |
now either "SUM x:A. e" or "\<Sum>x \<in> A. e". The bound variable can |
17189 | 4926 |
be a tuple pattern. |
16234 | 4927 |
|
4928 |
Some new syntax forms are available: |
|
4929 |
||
4930 |
"\<Sum>x | P. e" for "setsum (%x. e) {x. P}" |
|
4931 |
"\<Sum>x = a..b. e" for "setsum (%x. e) {a..b}" |
|
4932 |
"\<Sum>x = a..<b. e" for "setsum (%x. e) {a..<b}" |
|
4933 |
"\<Sum>x < k. e" for "setsum (%x. e) {..<k}" |
|
4934 |
||
4935 |
The latter form "\<Sum>x < k. e" used to be based on a separate |
|
4936 |
function "Summation", which has been discontinued. |
|
4937 |
||
4938 |
* theory Finite_Set: in structured induction proofs, the insert case |
|
4939 |
is now 'case (insert x F)' instead of the old counterintuitive 'case |
|
4940 |
(insert F x)'. |
|
4941 |
||
4942 |
* The 'refute' command has been extended to support a much larger |
|
4943 |
fragment of HOL, including axiomatic type classes, constdefs and |
|
4944 |
typedefs, inductive datatypes and recursion. |
|
4945 |
||
17700 | 4946 |
* New tactics 'sat' and 'satx' to prove propositional tautologies. |
4947 |
Requires zChaff with proof generation to be installed. See |
|
4948 |
HOL/ex/SAT_Examples.thy for examples. |
|
17619 | 4949 |
|
16234 | 4950 |
* Datatype induction via method 'induct' now preserves the name of the |
4951 |
induction variable. For example, when proving P(xs::'a list) by |
|
4952 |
induction on xs, the induction step is now P(xs) ==> P(a#xs) rather |
|
4953 |
than P(list) ==> P(a#list) as previously. Potential INCOMPATIBILITY |
|
4954 |
in unstructured proof scripts. |
|
4955 |
||
4956 |
* Reworked implementation of records. Improved scalability for |
|
4957 |
records with many fields, avoiding performance problems for type |
|
4958 |
inference. Records are no longer composed of nested field types, but |
|
4959 |
of nested extension types. Therefore the record type only grows linear |
|
4960 |
in the number of extensions and not in the number of fields. The |
|
4961 |
top-level (users) view on records is preserved. Potential |
|
4962 |
INCOMPATIBILITY only in strange cases, where the theory depends on the |
|
4963 |
old record representation. The type generated for a record is called |
|
4964 |
<record_name>_ext_type. |
|
4965 |
||
4966 |
Flag record_quick_and_dirty_sensitive can be enabled to skip the |
|
4967 |
proofs triggered by a record definition or a simproc (if |
|
4968 |
quick_and_dirty is enabled). Definitions of large records can take |
|
4969 |
quite long. |
|
4970 |
||
4971 |
New simproc record_upd_simproc for simplification of multiple record |
|
4972 |
updates enabled by default. Moreover, trivial updates are also |
|
4973 |
removed: r(|x := x r|) = r. INCOMPATIBILITY: old proofs break |
|
4974 |
occasionally, since simplification is more powerful by default. |
|
4975 |
||
17275
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4976 |
* typedef: proper support for polymorphic sets, which contain extra |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4977 |
type-variables in the term. |
44d8fbc2e52d
axclass: name space prefix is now "c_class" instead of just "c";
wenzelm
parents:
17269
diff
changeset
|
4978 |
|
16234 | 4979 |
* Simplifier: automatically reasons about transitivity chains |
4980 |
involving "trancl" (r^+) and "rtrancl" (r^*) by setting up tactics |
|
4981 |
provided by Provers/trancl.ML as additional solvers. INCOMPATIBILITY: |
|
4982 |
old proofs break occasionally as simplification may now solve more |
|
4983 |
goals than previously. |
|
4984 |
||
4985 |
* Simplifier: converts x <= y into x = y if assumption y <= x is |
|
4986 |
present. Works for all partial orders (class "order"), in particular |
|
4987 |
numbers and sets. For linear orders (e.g. numbers) it treats ~ x < y |
|
4988 |
just like y <= x. |
|
4989 |
||
4990 |
* Simplifier: new simproc for "let x = a in f x". If a is a free or |
|
4991 |
bound variable or a constant then the let is unfolded. Otherwise |
|
4992 |
first a is simplified to b, and then f b is simplified to g. If |
|
4993 |
possible we abstract b from g arriving at "let x = b in h x", |
|
4994 |
otherwise we unfold the let and arrive at g. The simproc can be |
|
4995 |
enabled/disabled by the reference use_let_simproc. Potential |
|
4996 |
INCOMPATIBILITY since simplification is more powerful by default. |
|
15776 | 4997 |
|
16563 | 4998 |
* Classical reasoning: the meson method now accepts theorems as arguments. |
4999 |
||
17595 | 5000 |
* Prover support: pre-release of the Isabelle-ATP linkup, which runs background |
5001 |
jobs to provide advice on the provability of subgoals. |
|
5002 |
||
16891 | 5003 |
* Theory OrderedGroup and Ring_and_Field: various additions and |
5004 |
improvements to faciliate calculations involving equalities and |
|
5005 |
inequalities. |
|
5006 |
||
5007 |
The following theorems have been eliminated or modified |
|
5008 |
(INCOMPATIBILITY): |
|
16888 | 5009 |
|
5010 |
abs_eq now named abs_of_nonneg |
|
17371 | 5011 |
abs_of_ge_0 now named abs_of_nonneg |
5012 |
abs_minus_eq now named abs_of_nonpos |
|
16888 | 5013 |
imp_abs_id now named abs_of_nonneg |
5014 |
imp_abs_neg_id now named abs_of_nonpos |
|
5015 |
mult_pos now named mult_pos_pos |
|
5016 |
mult_pos_le now named mult_nonneg_nonneg |
|
5017 |
mult_pos_neg_le now named mult_nonneg_nonpos |
|
5018 |
mult_pos_neg2_le now named mult_nonneg_nonpos2 |
|
5019 |
mult_neg now named mult_neg_neg |
|
5020 |
mult_neg_le now named mult_nonpos_nonpos |
|
5021 |
||
23495
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5022 |
* The following lemmas in Ring_and_Field have been added to the simplifier: |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5023 |
|
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5024 |
zero_le_square |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5025 |
not_square_less_zero |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5026 |
|
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5027 |
The following lemmas have been deleted from Real/RealPow: |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5028 |
|
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5029 |
realpow_zero_zero |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5030 |
realpow_two |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5031 |
realpow_less |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5032 |
zero_le_power |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5033 |
realpow_two_le |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5034 |
abs_realpow_two |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5035 |
realpow_two_abs |
e4dd6beeafab
commented changes in HOL/Ring_and_Field.thy, and in HOL/Real/RealPow.thy
obua
parents:
23481
diff
changeset
|
5036 |
|
16891 | 5037 |
* Theory Parity: added rules for simplifying exponents. |
5038 |
||
17092 | 5039 |
* Theory List: |
5040 |
||
5041 |
The following theorems have been eliminated or modified |
|
5042 |
(INCOMPATIBILITY): |
|
5043 |
||
5044 |
list_all_Nil now named list_all.simps(1) |
|
5045 |
list_all_Cons now named list_all.simps(2) |
|
5046 |
list_all_conv now named list_all_iff |
|
5047 |
set_mem_eq now named mem_iff |
|
5048 |
||
16929 | 5049 |
* Theories SetsAndFunctions and BigO (see HOL/Library) support |
5050 |
asymptotic "big O" calculations. See the notes in BigO.thy. |
|
5051 |
||
16888 | 5052 |
|
5053 |
*** HOL-Complex *** |
|
5054 |
||
16891 | 5055 |
* Theory RealDef: better support for embedding natural numbers and |
5056 |
integers in the reals. |
|
5057 |
||
5058 |
The following theorems have been eliminated or modified |
|
5059 |
(INCOMPATIBILITY): |
|
5060 |
||
17016
73c74cb1d744
mentioned change to exp_ge_add_one_self, new transitivity rules
avigad
parents:
16997
diff
changeset
|
5061 |
exp_ge_add_one_self now requires no hypotheses |
73c74cb1d744
mentioned change to exp_ge_add_one_self, new transitivity rules
avigad
parents:
16997
diff
changeset
|
5062 |
real_of_int_add reversed direction of equality (use [symmetric]) |
73c74cb1d744
mentioned change to exp_ge_add_one_self, new transitivity rules
avigad
parents:
16997
diff
changeset
|
5063 |
real_of_int_minus reversed direction of equality (use [symmetric]) |
73c74cb1d744
mentioned change to exp_ge_add_one_self, new transitivity rules
avigad
parents:
16997
diff
changeset
|
5064 |
real_of_int_diff reversed direction of equality (use [symmetric]) |
73c74cb1d744
mentioned change to exp_ge_add_one_self, new transitivity rules
avigad
parents:
16997
diff
changeset
|
5065 |
real_of_int_mult reversed direction of equality (use [symmetric]) |
16891 | 5066 |
|
5067 |
* Theory RComplete: expanded support for floor and ceiling functions. |
|
16888 | 5068 |
|
16962 | 5069 |
* Theory Ln is new, with properties of the natural logarithm |
5070 |
||
17423 | 5071 |
* Hyperreal: There is a new type constructor "star" for making |
5072 |
nonstandard types. The old type names are now type synonyms: |
|
5073 |
||
5074 |
hypreal = real star |
|
5075 |
hypnat = nat star |
|
5076 |
hcomplex = complex star |
|
5077 |
||
5078 |
* Hyperreal: Many groups of similarly-defined constants have been |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5079 |
replaced by polymorphic versions (INCOMPATIBILITY): |
17423 | 5080 |
|
5081 |
star_of <-- hypreal_of_real, hypnat_of_nat, hcomplex_of_complex |
|
5082 |
||
5083 |
starset <-- starsetNat, starsetC |
|
5084 |
*s* <-- *sNat*, *sc* |
|
5085 |
starset_n <-- starsetNat_n, starsetC_n |
|
5086 |
*sn* <-- *sNatn*, *scn* |
|
5087 |
InternalSets <-- InternalNatSets, InternalCSets |
|
5088 |
||
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5089 |
starfun <-- starfun{Nat,Nat2,C,RC,CR} |
17423 | 5090 |
*f* <-- *fNat*, *fNat2*, *fc*, *fRc*, *fcR* |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5091 |
starfun_n <-- starfun{Nat,Nat2,C,RC,CR}_n |
17423 | 5092 |
*fn* <-- *fNatn*, *fNat2n*, *fcn*, *fRcn*, *fcRn* |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5093 |
InternalFuns <-- InternalNatFuns, InternalNatFuns2, Internal{C,RC,CR}Funs |
17423 | 5094 |
|
5095 |
* Hyperreal: Many type-specific theorems have been removed in favor of |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5096 |
theorems specific to various axiomatic type classes (INCOMPATIBILITY): |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5097 |
|
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5098 |
add_commute <-- {hypreal,hypnat,hcomplex}_add_commute |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5099 |
add_assoc <-- {hypreal,hypnat,hcomplex}_add_assocs |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5100 |
OrderedGroup.add_0 <-- {hypreal,hypnat,hcomplex}_add_zero_left |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5101 |
OrderedGroup.add_0_right <-- {hypreal,hcomplex}_add_zero_right |
17423 | 5102 |
right_minus <-- hypreal_add_minus |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5103 |
left_minus <-- {hypreal,hcomplex}_add_minus_left |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5104 |
mult_commute <-- {hypreal,hypnat,hcomplex}_mult_commute |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5105 |
mult_assoc <-- {hypreal,hypnat,hcomplex}_mult_assoc |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5106 |
mult_1_left <-- {hypreal,hypnat}_mult_1, hcomplex_mult_one_left |
17423 | 5107 |
mult_1_right <-- hcomplex_mult_one_right |
5108 |
mult_zero_left <-- hcomplex_mult_zero_left |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5109 |
left_distrib <-- {hypreal,hypnat,hcomplex}_add_mult_distrib |
17423 | 5110 |
right_distrib <-- hypnat_add_mult_distrib2 |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5111 |
zero_neq_one <-- {hypreal,hypnat,hcomplex}_zero_not_eq_one |
17423 | 5112 |
right_inverse <-- hypreal_mult_inverse |
5113 |
left_inverse <-- hypreal_mult_inverse_left, hcomplex_mult_inv_left |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5114 |
order_refl <-- {hypreal,hypnat}_le_refl |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5115 |
order_trans <-- {hypreal,hypnat}_le_trans |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5116 |
order_antisym <-- {hypreal,hypnat}_le_anti_sym |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5117 |
order_less_le <-- {hypreal,hypnat}_less_le |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5118 |
linorder_linear <-- {hypreal,hypnat}_le_linear |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5119 |
add_left_mono <-- {hypreal,hypnat}_add_left_mono |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5120 |
mult_strict_left_mono <-- {hypreal,hypnat}_mult_less_mono2 |
17423 | 5121 |
add_nonneg_nonneg <-- hypreal_le_add_order |
5122 |
||
5123 |
* Hyperreal: Separate theorems having to do with type-specific |
|
5124 |
versions of constants have been merged into theorems that apply to the |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5125 |
new polymorphic constants (INCOMPATIBILITY): |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5126 |
|
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5127 |
STAR_UNIV_set <-- {STAR_real,NatStar_real,STARC_complex}_set |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5128 |
STAR_empty_set <-- {STAR,NatStar,STARC}_empty_set |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5129 |
STAR_Un <-- {STAR,NatStar,STARC}_Un |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5130 |
STAR_Int <-- {STAR,NatStar,STARC}_Int |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5131 |
STAR_Compl <-- {STAR,NatStar,STARC}_Compl |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5132 |
STAR_subset <-- {STAR,NatStar,STARC}_subset |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5133 |
STAR_mem <-- {STAR,NatStar,STARC}_mem |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5134 |
STAR_mem_Compl <-- {STAR,STARC}_mem_Compl |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5135 |
STAR_diff <-- {STAR,STARC}_diff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5136 |
STAR_star_of_image_subset <-- {STAR_hypreal_of_real, NatStar_hypreal_of_real, |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5137 |
STARC_hcomplex_of_complex}_image_subset |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5138 |
starset_n_Un <-- starset{Nat,C}_n_Un |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5139 |
starset_n_Int <-- starset{Nat,C}_n_Int |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5140 |
starset_n_Compl <-- starset{Nat,C}_n_Compl |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5141 |
starset_n_diff <-- starset{Nat,C}_n_diff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5142 |
InternalSets_Un <-- Internal{Nat,C}Sets_Un |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5143 |
InternalSets_Int <-- Internal{Nat,C}Sets_Int |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5144 |
InternalSets_Compl <-- Internal{Nat,C}Sets_Compl |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5145 |
InternalSets_diff <-- Internal{Nat,C}Sets_diff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5146 |
InternalSets_UNIV_diff <-- Internal{Nat,C}Sets_UNIV_diff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5147 |
InternalSets_starset_n <-- Internal{Nat,C}Sets_starset{Nat,C}_n |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5148 |
starset_starset_n_eq <-- starset{Nat,C}_starset{Nat,C}_n_eq |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5149 |
starset_n_starset <-- starset{Nat,C}_n_starset{Nat,C} |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5150 |
starfun_n_starfun <-- starfun{Nat,Nat2,C,RC,CR}_n_starfun{Nat,Nat2,C,RC,CR} |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5151 |
starfun <-- starfun{Nat,Nat2,C,RC,CR} |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5152 |
starfun_mult <-- starfun{Nat,Nat2,C,RC,CR}_mult |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5153 |
starfun_add <-- starfun{Nat,Nat2,C,RC,CR}_add |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5154 |
starfun_minus <-- starfun{Nat,Nat2,C,RC,CR}_minus |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5155 |
starfun_diff <-- starfun{C,RC,CR}_diff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5156 |
starfun_o <-- starfun{NatNat2,Nat2,_stafunNat,C,C_starfunRC,_starfunCR}_o |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5157 |
starfun_o2 <-- starfun{NatNat2,_stafunNat,C,C_starfunRC,_starfunCR}_o2 |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5158 |
starfun_const_fun <-- starfun{Nat,Nat2,C,RC,CR}_const_fun |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5159 |
starfun_inverse <-- starfun{Nat,C,RC,CR}_inverse |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5160 |
starfun_eq <-- starfun{Nat,Nat2,C,RC,CR}_eq |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5161 |
starfun_eq_iff <-- starfun{C,RC,CR}_eq_iff |
17423 | 5162 |
starfun_Id <-- starfunC_Id |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5163 |
starfun_approx <-- starfun{Nat,CR}_approx |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5164 |
starfun_capprox <-- starfun{C,RC}_capprox |
17423 | 5165 |
starfun_abs <-- starfunNat_rabs |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5166 |
starfun_lambda_cancel <-- starfun{C,CR,RC}_lambda_cancel |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5167 |
starfun_lambda_cancel2 <-- starfun{C,CR,RC}_lambda_cancel2 |
17423 | 5168 |
starfun_mult_HFinite_approx <-- starfunCR_mult_HFinite_capprox |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5169 |
starfun_mult_CFinite_capprox <-- starfun{C,RC}_mult_CFinite_capprox |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5170 |
starfun_add_capprox <-- starfun{C,RC}_add_capprox |
17423 | 5171 |
starfun_add_approx <-- starfunCR_add_approx |
5172 |
starfun_inverse_inverse <-- starfunC_inverse_inverse |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5173 |
starfun_divide <-- starfun{C,CR,RC}_divide |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5174 |
starfun_n <-- starfun{Nat,C}_n |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5175 |
starfun_n_mult <-- starfun{Nat,C}_n_mult |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5176 |
starfun_n_add <-- starfun{Nat,C}_n_add |
17423 | 5177 |
starfun_n_add_minus <-- starfunNat_n_add_minus |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5178 |
starfun_n_const_fun <-- starfun{Nat,C}_n_const_fun |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5179 |
starfun_n_minus <-- starfun{Nat,C}_n_minus |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5180 |
starfun_n_eq <-- starfun{Nat,C}_n_eq |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5181 |
|
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5182 |
star_n_add <-- {hypreal,hypnat,hcomplex}_add |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5183 |
star_n_minus <-- {hypreal,hcomplex}_minus |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5184 |
star_n_diff <-- {hypreal,hcomplex}_diff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5185 |
star_n_mult <-- {hypreal,hcomplex}_mult |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5186 |
star_n_inverse <-- {hypreal,hcomplex}_inverse |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5187 |
star_n_le <-- {hypreal,hypnat}_le |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5188 |
star_n_less <-- {hypreal,hypnat}_less |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5189 |
star_n_zero_num <-- {hypreal,hypnat,hcomplex}_zero_num |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5190 |
star_n_one_num <-- {hypreal,hypnat,hcomplex}_one_num |
17423 | 5191 |
star_n_abs <-- hypreal_hrabs |
5192 |
star_n_divide <-- hcomplex_divide |
|
5193 |
||
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5194 |
star_of_add <-- {hypreal_of_real,hypnat_of_nat,hcomplex_of_complex}_add |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5195 |
star_of_minus <-- {hypreal_of_real,hcomplex_of_complex}_minus |
17423 | 5196 |
star_of_diff <-- hypreal_of_real_diff |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5197 |
star_of_mult <-- {hypreal_of_real,hypnat_of_nat,hcomplex_of_complex}_mult |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5198 |
star_of_one <-- {hypreal_of_real,hcomplex_of_complex}_one |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5199 |
star_of_zero <-- {hypreal_of_real,hypnat_of_nat,hcomplex_of_complex}_zero |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5200 |
star_of_le <-- {hypreal_of_real,hypnat_of_nat}_le_iff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5201 |
star_of_less <-- {hypreal_of_real,hypnat_of_nat}_less_iff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5202 |
star_of_eq <-- {hypreal_of_real,hypnat_of_nat,hcomplex_of_complex}_eq_iff |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5203 |
star_of_inverse <-- {hypreal_of_real,hcomplex_of_complex}_inverse |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5204 |
star_of_divide <-- {hypreal_of_real,hcomplex_of_complex}_divide |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5205 |
star_of_of_nat <-- {hypreal_of_real,hcomplex_of_complex}_of_nat |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5206 |
star_of_of_int <-- {hypreal_of_real,hcomplex_of_complex}_of_int |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5207 |
star_of_number_of <-- {hypreal,hcomplex}_number_of |
17423 | 5208 |
star_of_number_less <-- number_of_less_hypreal_of_real_iff |
5209 |
star_of_number_le <-- number_of_le_hypreal_of_real_iff |
|
5210 |
star_of_eq_number <-- hypreal_of_real_eq_number_of_iff |
|
5211 |
star_of_less_number <-- hypreal_of_real_less_number_of_iff |
|
5212 |
star_of_le_number <-- hypreal_of_real_le_number_of_iff |
|
5213 |
star_of_power <-- hypreal_of_real_power |
|
5214 |
star_of_eq_0 <-- hcomplex_of_complex_zero_iff |
|
5215 |
||
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5216 |
* Hyperreal: new method "transfer" that implements the transfer |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5217 |
principle of nonstandard analysis. With a subgoal that mentions |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5218 |
nonstandard types like "'a star", the command "apply transfer" |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5219 |
replaces it with an equivalent one that mentions only standard types. |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5220 |
To be successful, all free variables must have standard types; non- |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5221 |
standard variables must have explicit universal quantifiers. |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5222 |
|
17641 | 5223 |
* Hyperreal: A theory of Taylor series. |
5224 |
||
14655
8a95abf87dd3
Pure: considerably improved version of 'constdefs' command;
wenzelm
parents:
14624
diff
changeset
|
5225 |
|
14682
a5072752114c
HOLCF: discontinued special version of 'constdefs';
wenzelm
parents:
14655
diff
changeset
|
5226 |
*** HOLCF *** |
a5072752114c
HOLCF: discontinued special version of 'constdefs';
wenzelm
parents:
14655
diff
changeset
|
5227 |
|
17533 | 5228 |
* Discontinued special version of 'constdefs' (which used to support |
5229 |
continuous functions) in favor of the general Pure one with full |
|
5230 |
type-inference. |
|
5231 |
||
5232 |
* New simplification procedure for solving continuity conditions; it |
|
5233 |
is much faster on terms with many nested lambda abstractions (cubic |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5234 |
instead of exponential time). |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5235 |
|
17533 | 5236 |
* New syntax for domain package: selector names are now optional. |
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5237 |
Parentheses should be omitted unless argument is lazy, for example: |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5238 |
|
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5239 |
domain 'a stream = cons "'a" (lazy "'a stream") |
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5240 |
|
17533 | 5241 |
* New command 'fixrec' for defining recursive functions with pattern |
5242 |
matching; defining multiple functions with mutual recursion is also |
|
5243 |
supported. Patterns may include the constants cpair, spair, up, sinl, |
|
5244 |
sinr, or any data constructor defined by the domain package. The given |
|
5245 |
equations are proven as rewrite rules. See HOLCF/ex/Fixrec_ex.thy for |
|
5246 |
syntax and examples. |
|
5247 |
||
5248 |
* New commands 'cpodef' and 'pcpodef' for defining predicate subtypes |
|
5249 |
of cpo and pcpo types. Syntax is exactly like the 'typedef' command, |
|
5250 |
but the proof obligation additionally includes an admissibility |
|
5251 |
requirement. The packages generate instances of class cpo or pcpo, |
|
5252 |
with continuity and strictness theorems for Rep and Abs. |
|
17442
c0f0b92c198c
add HOLCF entries for pcpodef, cont_proc, fixrec;
huffman
parents:
17436
diff
changeset
|
5253 |
|
17584 | 5254 |
* HOLCF: Many theorems have been renamed according to a more standard naming |
5255 |
scheme (INCOMPATIBILITY): |
|
5256 |
||
5257 |
foo_inject: "foo$x = foo$y ==> x = y" |
|
5258 |
foo_eq: "(foo$x = foo$y) = (x = y)" |
|
5259 |
foo_less: "(foo$x << foo$y) = (x << y)" |
|
5260 |
foo_strict: "foo$UU = UU" |
|
5261 |
foo_defined: "... ==> foo$x ~= UU" |
|
5262 |
foo_defined_iff: "(foo$x = UU) = (x = UU)" |
|
5263 |
||
14682
a5072752114c
HOLCF: discontinued special version of 'constdefs';
wenzelm
parents:
14655
diff
changeset
|
5264 |
|
14885 | 5265 |
*** ZF *** |
5266 |
||
16234 | 5267 |
* ZF/ex: theories Group and Ring provide examples in abstract algebra, |
5268 |
including the First Isomorphism Theorem (on quotienting by the kernel |
|
5269 |
of a homomorphism). |
|
15089
430264838064
ZF/Simplifier: second copy of context type solver;
wenzelm
parents:
15076
diff
changeset
|
5270 |
|
430264838064
ZF/Simplifier: second copy of context type solver;
wenzelm
parents:
15076
diff
changeset
|
5271 |
* ZF/Simplifier: install second copy of type solver that actually |
16234 | 5272 |
makes use of TC rules declared to Isar proof contexts (or locales); |
5273 |
the old version is still required for ML proof scripts. |
|
15703 | 5274 |
|
5275 |
||
17445 | 5276 |
*** Cube *** |
5277 |
||
5278 |
* Converted to Isar theory format; use locales instead of axiomatic |
|
5279 |
theories. |
|
5280 |
||
5281 |
||
15703 | 5282 |
*** ML *** |
5283 |
||
21339 | 5284 |
* Pure/library.ML: added ##>, ##>>, #>> -- higher-order counterparts |
5285 |
for ||>, ||>>, |>>, |
|
5286 |
||
15973 | 5287 |
* Pure/library.ML no longer defines its own option datatype, but uses |
16234 | 5288 |
that of the SML basis, which has constructors NONE and SOME instead of |
5289 |
None and Some, as well as exception Option.Option instead of OPTION. |
|
5290 |
The functions the, if_none, is_some, is_none have been adapted |
|
5291 |
accordingly, while Option.map replaces apsome. |
|
15973 | 5292 |
|
16860
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5293 |
* Pure/library.ML: the exception LIST has been given up in favour of |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5294 |
the standard exceptions Empty and Subscript, as well as |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5295 |
Library.UnequalLengths. Function like Library.hd and Library.tl are |
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
5296 |
superceded by the standard hd and tl functions etc. |
16860
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5297 |
|
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5298 |
A number of basic list functions are no longer exported to the ML |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5299 |
toplevel, as they are variants of predefined functions. The following |
16234 | 5300 |
suggests how one can translate existing code: |
15973 | 5301 |
|
5302 |
rev_append xs ys = List.revAppend (xs, ys) |
|
5303 |
nth_elem (i, xs) = List.nth (xs, i) |
|
5304 |
last_elem xs = List.last xs |
|
5305 |
flat xss = List.concat xss |
|
16234 | 5306 |
seq fs = List.app fs |
15973 | 5307 |
partition P xs = List.partition P xs |
5308 |
mapfilter f xs = List.mapPartial f xs |
|
5309 |
||
16860
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5310 |
* Pure/library.ML: several combinators for linear functional |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5311 |
transformations, notably reverse application and composition: |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5312 |
|
17371 | 5313 |
x |> f f #> g |
5314 |
(x, y) |-> f f #-> g |
|
16860
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5315 |
|
17495 | 5316 |
* Pure/library.ML: introduced/changed precedence of infix operators: |
5317 |
||
5318 |
infix 1 |> |-> ||> ||>> |>> |>>> #> #->; |
|
5319 |
infix 2 ?; |
|
5320 |
infix 3 o oo ooo oooo; |
|
5321 |
infix 4 ~~ upto downto; |
|
5322 |
||
5323 |
Maybe INCOMPATIBILITY when any of those is used in conjunction with other |
|
5324 |
infix operators. |
|
5325 |
||
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5326 |
* Pure/library.ML: natural list combinators fold, fold_rev, and |
16869 | 5327 |
fold_map support linear functional transformations and nesting. For |
16860
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5328 |
example: |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5329 |
|
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5330 |
fold f [x1, ..., xN] y = |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5331 |
y |> f x1 |> ... |> f xN |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5332 |
|
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5333 |
(fold o fold) f [xs1, ..., xsN] y = |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5334 |
y |> fold f xs1 |> ... |> fold f xsN |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5335 |
|
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5336 |
fold f [x1, ..., xN] = |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5337 |
f x1 #> ... #> f xN |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5338 |
|
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5339 |
(fold o fold) f [xs1, ..., xsN] = |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5340 |
fold f xs1 #> ... #> fold f xsN |
43abdba4da5c
* Pure/library.ML: several combinators for linear functional transformations;
wenzelm
parents:
16856
diff
changeset
|
5341 |
|
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5342 |
* Pure/library.ML: the following selectors on type 'a option are |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5343 |
available: |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5344 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5345 |
the: 'a option -> 'a (*partial*) |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5346 |
these: 'a option -> 'a where 'a = 'b list |
17402 | 5347 |
the_default: 'a -> 'a option -> 'a |
5348 |
the_list: 'a option -> 'a list |
|
5349 |
||
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5350 |
* Pure/General: structure AList (cf. Pure/General/alist.ML) provides |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5351 |
basic operations for association lists, following natural argument |
17564 | 5352 |
order; moreover the explicit equality predicate passed here avoids |
17495 | 5353 |
potentially expensive polymorphic runtime equality checks. |
5354 |
The old functions may be expressed as follows: |
|
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5355 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5356 |
assoc = uncurry (AList.lookup (op =)) |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5357 |
assocs = these oo AList.lookup (op =) |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5358 |
overwrite = uncurry (AList.update (op =)) o swap |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5359 |
|
17564 | 5360 |
* Pure/General: structure AList (cf. Pure/General/alist.ML) provides |
5361 |
||
5362 |
val make: ('a -> 'b) -> 'a list -> ('a * 'b) list |
|
5363 |
val find: ('a * 'b -> bool) -> ('c * 'b) list -> 'a -> 'c list |
|
5364 |
||
5365 |
replacing make_keylist and keyfilter (occassionally used) |
|
5366 |
Naive rewrites: |
|
5367 |
||
5368 |
make_keylist = AList.make |
|
5369 |
keyfilter = AList.find (op =) |
|
5370 |
||
5371 |
* eq_fst and eq_snd now take explicit equality parameter, thus |
|
5372 |
avoiding eqtypes. Naive rewrites: |
|
5373 |
||
5374 |
eq_fst = eq_fst (op =) |
|
5375 |
eq_snd = eq_snd (op =) |
|
5376 |
||
5377 |
* Removed deprecated apl and apr (rarely used). |
|
5378 |
Naive rewrites: |
|
5379 |
||
5380 |
apl (n, op) =>>= curry op n |
|
5381 |
apr (op, m) =>>= fn n => op (n, m) |
|
5382 |
||
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5383 |
* Pure/General: structure OrdList (cf. Pure/General/ord_list.ML) |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5384 |
provides a reasonably efficient light-weight implementation of sets as |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5385 |
lists. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5386 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5387 |
* Pure/General: generic tables (cf. Pure/General/table.ML) provide a |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5388 |
few new operations; existing lookup and update are now curried to |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5389 |
follow natural argument order (for use with fold etc.); |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5390 |
INCOMPATIBILITY, use (uncurry Symtab.lookup) etc. as last resort. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5391 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5392 |
* Pure/General: output via the Isabelle channels of |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5393 |
writeln/warning/error etc. is now passed through Output.output, with a |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5394 |
hook for arbitrary transformations depending on the print_mode |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5395 |
(cf. Output.add_mode -- the first active mode that provides a output |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5396 |
function wins). Already formatted output may be embedded into further |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5397 |
text via Output.raw; the result of Pretty.string_of/str_of and derived |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5398 |
functions (string_of_term/cterm/thm etc.) is already marked raw to |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5399 |
accommodate easy composition of diagnostic messages etc. Programmers |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5400 |
rarely need to care about Output.output or Output.raw at all, with |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5401 |
some notable exceptions: Output.output is required when bypassing the |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5402 |
standard channels (writeln etc.), or in token translations to produce |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5403 |
properly formatted results; Output.raw is required when capturing |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5404 |
already output material that will eventually be presented to the user |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5405 |
a second time. For the default print mode, both Output.output and |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5406 |
Output.raw have no effect. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5407 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5408 |
* Pure/General: Output.time_accumulator NAME creates an operator ('a |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5409 |
-> 'b) -> 'a -> 'b to measure runtime and count invocations; the |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5410 |
cumulative results are displayed at the end of a batch session. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5411 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5412 |
* Pure/General: File.sysify_path and File.quote_sysify path have been |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5413 |
replaced by File.platform_path and File.shell_path (with appropriate |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5414 |
hooks). This provides a clean interface for unusual systems where the |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5415 |
internal and external process view of file names are different. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5416 |
|
16689
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5417 |
* Pure: more efficient orders for basic syntactic entities: added |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5418 |
fast_string_ord, fast_indexname_ord, fast_term_ord; changed sort_ord |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5419 |
and typ_ord to use fast_string_ord and fast_indexname_ord (term_ord is |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5420 |
NOT affected); structures Symtab, Vartab, Typtab, Termtab use the fast |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5421 |
orders now -- potential INCOMPATIBILITY for code that depends on a |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5422 |
particular order for Symtab.keys, Symtab.dest, etc. (consider using |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5423 |
Library.sort_strings on result). |
05b986733a59
* Pure: structure OrdList (cf. Pure/General/ord_list.ML);
wenzelm
parents:
16662
diff
changeset
|
5424 |
|
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5425 |
* Pure/term.ML: combinators fold_atyps, fold_aterms, fold_term_types, |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5426 |
fold_types traverse types/terms from left to right, observing natural |
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
5427 |
argument order. Supercedes previous foldl_XXX versions, add_frees, |
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5428 |
add_vars etc. have been adapted as well: INCOMPATIBILITY. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5429 |
|
16151 | 5430 |
* Pure: name spaces have been refined, with significant changes of the |
16234 | 5431 |
internal interfaces -- INCOMPATIBILITY. Renamed cond_extern(_table) |
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
5432 |
to extern(_table). The plain name entry path is superceded by a |
16234 | 5433 |
general 'naming' context, which also includes the 'policy' to produce |
5434 |
a fully qualified name and external accesses of a fully qualified |
|
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
5435 |
name; NameSpace.extend is superceded by context dependent |
16234 | 5436 |
Sign.declare_name. Several theory and proof context operations modify |
5437 |
the naming context. Especially note Theory.restore_naming and |
|
5438 |
ProofContext.restore_naming to get back to a sane state; note that |
|
5439 |
Theory.add_path is no longer sufficient to recover from |
|
5440 |
Theory.absolute_path in particular. |
|
5441 |
||
5442 |
* Pure: new flags short_names (default false) and unique_names |
|
5443 |
(default true) for controlling output of qualified names. If |
|
5444 |
short_names is set, names are printed unqualified. If unique_names is |
|
5445 |
reset, the name prefix is reduced to the minimum required to achieve |
|
5446 |
the original result when interning again, even if there is an overlap |
|
5447 |
with earlier declarations. |
|
16151 | 5448 |
|
16456
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5449 |
* Pure/TheoryDataFun: change of the argument structure; 'prep_ext' is |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5450 |
now 'extend', and 'merge' gets an additional Pretty.pp argument |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5451 |
(useful for printing error messages). INCOMPATIBILITY. |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5452 |
|
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5453 |
* Pure: major reorganization of the theory context. Type Sign.sg and |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5454 |
Theory.theory are now identified, referring to the universal |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5455 |
Context.theory (see Pure/context.ML). Actual signature and theory |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5456 |
content is managed as theory data. The old code and interfaces were |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5457 |
spread over many files and structures; the new arrangement introduces |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5458 |
considerable INCOMPATIBILITY to gain more clarity: |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5459 |
|
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5460 |
Context -- theory management operations (name, identity, inclusion, |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5461 |
parents, ancestors, merge, etc.), plus generic theory data; |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5462 |
|
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5463 |
Sign -- logical signature and syntax operations (declaring consts, |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5464 |
types, etc.), plus certify/read for common entities; |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5465 |
|
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5466 |
Theory -- logical theory operations (stating axioms, definitions, |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5467 |
oracles), plus a copy of logical signature operations (consts, |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5468 |
types, etc.); also a few basic management operations (Theory.copy, |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5469 |
Theory.merge, etc.) |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5470 |
|
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5471 |
The most basic sign_of operations (Theory.sign_of, Thm.sign_of_thm |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5472 |
etc.) as well as the sign field in Thm.rep_thm etc. have been retained |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5473 |
for convenience -- they merely return the theory. |
451f1c46d4ca
* Pure/TheoryDataFun: change of the argument structure;
wenzelm
parents:
16373
diff
changeset
|
5474 |
|
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
5475 |
* Pure: type Type.tsig is superceded by theory in most interfaces. |
17193
83708f724822
* Delimiters of outer tokens now produce separate LaTeX macros;
wenzelm
parents:
17189
diff
changeset
|
5476 |
|
16547
09f7a953d2d6
* Pure: the Isar proof context type is already defined early in Pure
wenzelm
parents:
16506
diff
changeset
|
5477 |
* Pure: the Isar proof context type is already defined early in Pure |
09f7a953d2d6
* Pure: the Isar proof context type is already defined early in Pure
wenzelm
parents:
16506
diff
changeset
|
5478 |
as Context.proof (note that ProofContext.context and Proof.context are |
09f7a953d2d6
* Pure: the Isar proof context type is already defined early in Pure
wenzelm
parents:
16506
diff
changeset
|
5479 |
aliases, where the latter is the preferred name). This enables other |
09f7a953d2d6
* Pure: the Isar proof context type is already defined early in Pure
wenzelm
parents:
16506
diff
changeset
|
5480 |
Isabelle components to refer to that type even before Isar is present. |
09f7a953d2d6
* Pure: the Isar proof context type is already defined early in Pure
wenzelm
parents:
16506
diff
changeset
|
5481 |
|
16373
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5482 |
* Pure/sign/theory: discontinued named name spaces (i.e. classK, |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5483 |
typeK, constK, axiomK, oracleK), but provide explicit operations for |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5484 |
any of these kinds. For example, Sign.intern typeK is now |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5485 |
Sign.intern_type, Theory.hide_space Sign.typeK is now |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5486 |
Theory.hide_types. Also note that former |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5487 |
Theory.hide_classes/types/consts are now |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5488 |
Theory.hide_classes_i/types_i/consts_i, while the non '_i' versions |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5489 |
internalize their arguments! INCOMPATIBILITY. |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5490 |
|
16506
b2687ce38433
* Pure: get_thm interface expects datatype thmref;
wenzelm
parents:
16456
diff
changeset
|
5491 |
* Pure: get_thm interface (of PureThy and ProofContext) expects |
b2687ce38433
* Pure: get_thm interface expects datatype thmref;
wenzelm
parents:
16456
diff
changeset
|
5492 |
datatype thmref (with constructors Name and NameSelection) instead of |
b2687ce38433
* Pure: get_thm interface expects datatype thmref;
wenzelm
parents:
16456
diff
changeset
|
5493 |
plain string -- INCOMPATIBILITY; |
b2687ce38433
* Pure: get_thm interface expects datatype thmref;
wenzelm
parents:
16456
diff
changeset
|
5494 |
|
16151 | 5495 |
* Pure: cases produced by proof methods specify options, where NONE |
16234 | 5496 |
means to remove case bindings -- INCOMPATIBILITY in |
5497 |
(RAW_)METHOD_CASES. |
|
16151 | 5498 |
|
16373
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5499 |
* Pure: the following operations retrieve axioms or theorems from a |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5500 |
theory node or theory hierarchy, respectively: |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5501 |
|
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5502 |
Theory.axioms_of: theory -> (string * term) list |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5503 |
Theory.all_axioms_of: theory -> (string * term) list |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5504 |
PureThy.thms_of: theory -> (string * thm) list |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5505 |
PureThy.all_thms_of: theory -> (string * thm) list |
9d020423093b
* Pure/sign/theory: discontinued named name spaces;
wenzelm
parents:
16251
diff
changeset
|
5506 |
|
16718 | 5507 |
* Pure: print_tac now outputs the goal through the trace channel. |
5508 |
||
17408
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5509 |
* Isar toplevel: improved diagnostics, mostly for Poly/ML only. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5510 |
Reference Toplevel.debug (default false) controls detailed printing |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5511 |
and tracing of low-level exceptions; Toplevel.profiling (default 0) |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5512 |
controls execution profiling -- set to 1 for time and 2 for space |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5513 |
(both increase the runtime). |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5514 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5515 |
* Isar session: The initial use of ROOT.ML is now always timed, |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5516 |
i.e. the log will show the actual process times, in contrast to the |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5517 |
elapsed wall-clock time that the outer shell wrapper produces. |
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5518 |
|
551c9a4dd693
command 'thms_containing' has been discontinued in favour of 'find_theorems';
wenzelm
parents:
17402
diff
changeset
|
5519 |
* Simplifier: improved handling of bound variables (nameless |
16997
7dfc99f62dd9
* Pure/Simplifier: improved handling of bound variables;
wenzelm
parents:
16962
diff
changeset
|
5520 |
representation, avoid allocating new strings). Simprocs that invoke |
7dfc99f62dd9
* Pure/Simplifier: improved handling of bound variables;
wenzelm
parents:
16962
diff
changeset
|
5521 |
the Simplifier recursively should use Simplifier.inherit_bounds to |
17720 | 5522 |
avoid local name clashes. Failure to do so produces warnings |
5523 |
"Simplifier: renamed bound variable ..."; set Simplifier.debug_bounds |
|
5524 |
for further details. |
|
16234 | 5525 |
|
17166 | 5526 |
* ML functions legacy_bindings and use_legacy_bindings produce ML fact |
5527 |
bindings for all theorems stored within a given theory; this may help |
|
5528 |
in porting non-Isar theories to Isar ones, while keeping ML proof |
|
5529 |
scripts for the time being. |
|
5530 |
||
17457 | 5531 |
* ML operator HTML.with_charset specifies the charset begin used for |
5532 |
generated HTML files. For example: |
|
5533 |
||
5534 |
HTML.with_charset "utf-8" use_thy "Hebrew"; |
|
17538 | 5535 |
HTML.with_charset "utf-8" use_thy "Chinese"; |
17457 | 5536 |
|
16234 | 5537 |
|
5538 |
*** System *** |
|
5539 |
||
5540 |
* Allow symlinks to all proper Isabelle executables (Isabelle, |
|
5541 |
isabelle, isatool etc.). |
|
5542 |
||
5543 |
* ISABELLE_DOC_FORMAT setting specifies preferred document format (for |
|
5544 |
isatool doc, isatool mkdir, display_drafts etc.). |
|
5545 |
||
5546 |
* isatool usedir: option -f allows specification of the ML file to be |
|
5547 |
used by Isabelle; default is ROOT.ML. |
|
5548 |
||
16251
121dc80d120a
* ML: replaced File.sysify_path/quote_sysify_path by File.platform_path/shell_path;
wenzelm
parents:
16234
diff
changeset
|
5549 |
* New isatool version outputs the version identifier of the Isabelle |
121dc80d120a
* ML: replaced File.sysify_path/quote_sysify_path by File.platform_path/shell_path;
wenzelm
parents:
16234
diff
changeset
|
5550 |
distribution being used. |
121dc80d120a
* ML: replaced File.sysify_path/quote_sysify_path by File.platform_path/shell_path;
wenzelm
parents:
16234
diff
changeset
|
5551 |
|
121dc80d120a
* ML: replaced File.sysify_path/quote_sysify_path by File.platform_path/shell_path;
wenzelm
parents:
16234
diff
changeset
|
5552 |
* HOL: new isatool dimacs2hol converts files in DIMACS CNF format |
16234 | 5553 |
(containing Boolean satisfiability problems) into Isabelle/HOL |
5554 |
theories. |
|
15703 | 5555 |
|
5556 |
||
14655
8a95abf87dd3
Pure: considerably improved version of 'constdefs' command;
wenzelm
parents:
14624
diff
changeset
|
5557 |
|
14606 | 5558 |
New in Isabelle2004 (April 2004) |
5559 |
-------------------------------- |
|
13280
306ef3aef61b
* improved thms_containing: proper indexing of facts instead of raw
wenzelm
parents:
13190
diff
changeset
|
5560 |
|
14171
0cab06e3bbd0
Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents:
14136
diff
changeset
|
5561 |
*** General *** |
0cab06e3bbd0
Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents:
14136
diff
changeset
|
5562 |
|
14398
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5563 |
* Provers/order.ML: new efficient reasoner for partial and linear orders. |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5564 |
Replaces linorder.ML. |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5565 |
|
14606 | 5566 |
* Pure: Greek letters (except small lambda, \<lambda>), as well as Gothic |
5567 |
(\<aa>...\<zz>\<AA>...\<ZZ>), calligraphic (\<A>...\<Z>), and Euler |
|
14173 | 5568 |
(\<a>...\<z>), are now considered normal letters, and can therefore |
5569 |
be used anywhere where an ASCII letter (a...zA...Z) has until |
|
5570 |
now. COMPATIBILITY: This obviously changes the parsing of some |
|
5571 |
terms, especially where a symbol has been used as a binder, say |
|
5572 |
'\<Pi>x. ...', which is now a type error since \<Pi>x will be parsed |
|
5573 |
as an identifier. Fix it by inserting a space around former |
|
5574 |
symbols. Call 'isatool fixgreek' to try to fix parsing errors in |
|
5575 |
existing theory and ML files. |
|
14171
0cab06e3bbd0
Extended the notion of letter and digit, such that now one may use greek,
skalberg
parents:
14136
diff
changeset
|
5576 |
|
14237 | 5577 |
* Pure: Macintosh and Windows line-breaks are now allowed in theory files. |
5578 |
||
14731 | 5579 |
* Pure: single letter sub/superscripts (\<^isub> and \<^isup>) are now |
5580 |
allowed in identifiers. Similar to Greek letters \<^isub> is now considered |
|
5581 |
a normal (but invisible) letter. For multiple letter subscripts repeat |
|
5582 |
\<^isub> like this: x\<^isub>1\<^isub>2. |
|
14233 | 5583 |
|
14333 | 5584 |
* Pure: There are now sub-/superscripts that can span more than one |
5585 |
character. Text between \<^bsub> and \<^esub> is set in subscript in |
|
14606 | 5586 |
ProofGeneral and LaTeX, text between \<^bsup> and \<^esup> in |
5587 |
superscript. The new control characters are not identifier parts. |
|
14333 | 5588 |
|
14561
c53396af770e
* raw control symbols are of the form \<^raw:...> now.
schirmer
parents:
14556
diff
changeset
|
5589 |
* Pure: Control-symbols of the form \<^raw:...> will literally print the |
14606 | 5590 |
content of "..." to the latex file instead of \isacntrl... . The "..." |
5591 |
may consist of any printable characters excluding the end bracket >. |
|
14361
ad2f5da643b4
* Support for raw latex output in control symbols: \<^raw...>
schirmer
parents:
14333
diff
changeset
|
5592 |
|
14237 | 5593 |
* Pure: Using new Isar command "finalconsts" (or the ML functions |
5594 |
Theory.add_finals or Theory.add_finals_i) it is now possible to |
|
5595 |
declare constants "final", which prevents their being given a definition |
|
5596 |
later. It is useful for constants whose behaviour is fixed axiomatically |
|
14224 | 5597 |
rather than definitionally, such as the meta-logic connectives. |
5598 |
||
14606 | 5599 |
* Pure: 'instance' now handles general arities with general sorts |
5600 |
(i.e. intersections of classes), |
|
14503
255ad604e08e
Added check that Theory.ML does not occur in the files section of the theory
skalberg
parents:
14480
diff
changeset
|
5601 |
|
14547 | 5602 |
* Presentation: generated HTML now uses a CSS style sheet to make layout |
14731 | 5603 |
(somewhat) independent of content. It is copied from lib/html/isabelle.css. |
14547 | 5604 |
It can be changed to alter the colors/layout of generated pages. |
5605 |
||
14556
c5078f6c99a9
* Calculation commands "moreover" and "also" no longer interfere with
wenzelm
parents:
14551
diff
changeset
|
5606 |
|
14175
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5607 |
*** Isar *** |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5608 |
|
14508
859b11514537
Experimental command for instantiation of locales in proof contexts:
ballarin
parents:
14503
diff
changeset
|
5609 |
* Tactic emulation methods rule_tac, erule_tac, drule_tac, frule_tac, |
859b11514537
Experimental command for instantiation of locales in proof contexts:
ballarin
parents:
14503
diff
changeset
|
5610 |
cut_tac, subgoal_tac and thin_tac: |
14175
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5611 |
- Now understand static (Isar) contexts. As a consequence, users of Isar |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5612 |
locales are no longer forced to write Isar proof scripts. |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5613 |
For details see Isar Reference Manual, paragraph 4.3.2: Further tactic |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5614 |
emulations. |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5615 |
- INCOMPATIBILITY: names of variables to be instantiated may no |
14211
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5616 |
longer be enclosed in quotes. Instead, precede variable name with `?'. |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5617 |
This is consistent with the instantiation attribute "where". |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5618 |
|
14257
a7ef3f7588c5
Type inference bug in Isar attributes "where" and "of" fixed.
ballarin
parents:
14255
diff
changeset
|
5619 |
* Attributes "where" and "of": |
14285
92ed032e83a1
Isar: where attribute supports instantiation of type vars.
ballarin
parents:
14283
diff
changeset
|
5620 |
- Now take type variables of instantiated theorem into account when reading |
92ed032e83a1
Isar: where attribute supports instantiation of type vars.
ballarin
parents:
14283
diff
changeset
|
5621 |
the instantiation string. This fixes a bug that caused instantiated |
92ed032e83a1
Isar: where attribute supports instantiation of type vars.
ballarin
parents:
14283
diff
changeset
|
5622 |
theorems to have too special types in some circumstances. |
92ed032e83a1
Isar: where attribute supports instantiation of type vars.
ballarin
parents:
14283
diff
changeset
|
5623 |
- "where" permits explicit instantiations of type variables. |
14257
a7ef3f7588c5
Type inference bug in Isar attributes "where" and "of" fixed.
ballarin
parents:
14255
diff
changeset
|
5624 |
|
14556
c5078f6c99a9
* Calculation commands "moreover" and "also" no longer interfere with
wenzelm
parents:
14551
diff
changeset
|
5625 |
* Calculation commands "moreover" and "also" no longer interfere with |
c5078f6c99a9
* Calculation commands "moreover" and "also" no longer interfere with
wenzelm
parents:
14551
diff
changeset
|
5626 |
current facts ("this"), admitting arbitrary combinations with "then" |
c5078f6c99a9
* Calculation commands "moreover" and "also" no longer interfere with
wenzelm
parents:
14551
diff
changeset
|
5627 |
and derived forms. |
14283 | 5628 |
|
14211
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5629 |
* Locales: |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5630 |
- Goal statements involving the context element "includes" no longer |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5631 |
generate theorems with internal delta predicates (those ending on |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5632 |
"_axioms") in the premise. |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5633 |
Resolve particular premise with <locale>.intro to obtain old form. |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5634 |
- Fixed bug in type inference ("unify_frozen") that prevented mix of target |
7286c187596d
Improvements to Isar/Locales: premises generated by "includes" elements
ballarin
parents:
14199
diff
changeset
|
5635 |
specification and "includes" elements in goal statement. |
14254
342634f38451
Isar/Locales: <loc>.intro and <loc>.axioms no longer intro? and elim? by
ballarin
parents:
14243
diff
changeset
|
5636 |
- Rule sets <locale>.intro and <locale>.axioms no longer declared as |
342634f38451
Isar/Locales: <loc>.intro and <loc>.axioms no longer intro? and elim? by
ballarin
parents:
14243
diff
changeset
|
5637 |
[intro?] and [elim?] (respectively) by default. |
14508
859b11514537
Experimental command for instantiation of locales in proof contexts:
ballarin
parents:
14503
diff
changeset
|
5638 |
- Experimental command for instantiation of locales in proof contexts: |
14551 | 5639 |
instantiate <label>[<attrs>]: <loc> |
14508
859b11514537
Experimental command for instantiation of locales in proof contexts:
ballarin
parents:
14503
diff
changeset
|
5640 |
Instantiates locale <loc> and adds all its theorems to the current context |
14551 | 5641 |
taking into account their attributes. Label and attrs are optional |
5642 |
modifiers, like in theorem declarations. If present, names of |
|
5643 |
instantiated theorems are qualified with <label>, and the attributes |
|
5644 |
<attrs> are applied after any attributes these theorems might have already. |
|
5645 |
If the locale has assumptions, a chained fact of the form |
|
14508
859b11514537
Experimental command for instantiation of locales in proof contexts:
ballarin
parents:
14503
diff
changeset
|
5646 |
"<loc> t1 ... tn" is expected from which instantiations of the parameters |
14551 | 5647 |
are derived. The command does not support old-style locales declared |
5648 |
with "locale (open)". |
|
5649 |
A few (very simple) examples can be found in FOL/ex/LocaleInst.thy. |
|
14175
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5650 |
|
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5651 |
* HOL: Tactic emulation methods induct_tac and case_tac understand static |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5652 |
(Isar) contexts. |
dbd16ebaf907
Method rule_tac understands Isar contexts: documentation.
ballarin
parents:
14173
diff
changeset
|
5653 |
|
14556
c5078f6c99a9
* Calculation commands "moreover" and "also" no longer interfere with
wenzelm
parents:
14551
diff
changeset
|
5654 |
|
14136 | 5655 |
*** HOL *** |
5656 |
||
14624 | 5657 |
* Proof import: new image HOL4 contains the imported library from |
5658 |
the HOL4 system with about 2500 theorems. It is imported by |
|
5659 |
replaying proof terms produced by HOL4 in Isabelle. The HOL4 image |
|
5660 |
can be used like any other Isabelle image. See |
|
5661 |
HOL/Import/HOL/README for more information. |
|
5662 |
||
14398
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5663 |
* Simplifier: |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5664 |
- Much improved handling of linear and partial orders. |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5665 |
Reasoners for linear and partial orders are set up for type classes |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5666 |
"linorder" and "order" respectively, and are added to the default simpset |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5667 |
as solvers. This means that the simplifier can build transitivity chains |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5668 |
to solve goals from the assumptions. |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5669 |
- INCOMPATIBILITY: old proofs break occasionally. Typically, applications |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5670 |
of blast or auto after simplification become unnecessary because the goal |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5671 |
is solved by simplification already. |
c5c47703f763
Efficient, graph-based reasoner for linear and partial orders.
ballarin
parents:
14389
diff
changeset
|
5672 |
|
14731 | 5673 |
* Numerics: new theory Ring_and_Field contains over 250 basic numerical laws, |
14389 | 5674 |
all proved in axiomatic type classes for semirings, rings and fields. |
5675 |
||
5676 |
* Numerics: |
|
5677 |
- Numeric types (nat, int, and in HOL-Complex rat, real, complex, etc.) are |
|
14731 | 5678 |
now formalized using the Ring_and_Field theory mentioned above. |
14389 | 5679 |
- INCOMPATIBILITY: simplification and arithmetic behaves somewhat differently |
5680 |
than before, because now they are set up once in a generic manner. |
|
14731 | 5681 |
- INCOMPATIBILITY: many type-specific arithmetic laws have gone. |
14480 | 5682 |
Look for the general versions in Ring_and_Field (and Power if they concern |
5683 |
exponentiation). |
|
14389 | 5684 |
|
14401 | 5685 |
* Type "rat" of the rational numbers is now available in HOL-Complex. |
14389 | 5686 |
|
14255 | 5687 |
* Records: |
5688 |
- Record types are now by default printed with their type abbreviation |
|
5689 |
instead of the list of all field types. This can be configured via |
|
5690 |
the reference "print_record_type_abbr". |
|
14731 | 5691 |
- Simproc "record_upd_simproc" for simplification of multiple updates added |
14255 | 5692 |
(not enabled by default). |
14427 | 5693 |
- Simproc "record_ex_sel_eq_simproc" to simplify EX x. sel r = x resp. |
5694 |
EX x. x = sel r to True (not enabled by default). |
|
14255 | 5695 |
- Tactic "record_split_simp_tac" to split and simplify records added. |
14731 | 5696 |
|
14136 | 5697 |
* 'specification' command added, allowing for definition by |
14224 | 5698 |
specification. There is also an 'ax_specification' command that |
5699 |
introduces the new constants axiomatically. |
|
14136 | 5700 |
|
14375 | 5701 |
* arith(_tac) is now able to generate counterexamples for reals as well. |
5702 |
||
14399
dc677b35e54f
New lemmas about inversion of restricted functions.
ballarin
parents:
14398
diff
changeset
|
5703 |
* HOL-Algebra: new locale "ring" for non-commutative rings. |
dc677b35e54f
New lemmas about inversion of restricted functions.
ballarin
parents:
14398
diff
changeset
|
5704 |
|
14243 | 5705 |
* HOL-ex: InductiveInvariant_examples illustrates advanced recursive function |
14610 | 5706 |
definitions, thanks to Sava Krsti\'{c} and John Matthews. |
5707 |
||
14731 | 5708 |
* HOL-Matrix: a first theory for matrices in HOL with an application of |
14610 | 5709 |
matrix theory to linear programming. |
14136 | 5710 |
|
14380 | 5711 |
* Unions and Intersections: |
15119 | 5712 |
The latex output syntax of UN and INT has been changed |
5713 |
from "\Union x \in A. B" to "\Union_{x \in A} B" |
|
5714 |
i.e. the index formulae has become a subscript. |
|
5715 |
Similarly for "\Union x. B", and for \Inter instead of \Union. |
|
14380 | 5716 |
|
14418 | 5717 |
* Unions and Intersections over Intervals: |
14731 | 5718 |
There is new short syntax "UN i<=n. A" for "UN i:{0..n}. A". There is |
5719 |
also an x-symbol version with subscripts "\<Union>\<^bsub>i <= n\<^esub>. A" |
|
14418 | 5720 |
like in normal math, and corresponding versions for < and for intersection. |
5721 |
||
15677 | 5722 |
* HOL/List: Ordering "lexico" is renamed "lenlex" and the standard |
5723 |
lexicographic dictonary ordering has been added as "lexord". |
|
5724 |
||
14401 | 5725 |
* ML: the legacy theory structures Int and List have been removed. They had |
5726 |
conflicted with ML Basis Library structures having the same names. |
|
14380 | 5727 |
|
14464 | 5728 |
* 'refute' command added to search for (finite) countermodels. Only works |
5729 |
for a fragment of HOL. The installation of an external SAT solver is |
|
5730 |
highly recommended. See "HOL/Refute.thy" for details. |
|
5731 |
||
14602 | 5732 |
* 'quickcheck' command: Allows to find counterexamples by evaluating |
5733 |
formulae under an assignment of free variables to random values. |
|
5734 |
In contrast to 'refute', it can deal with inductive datatypes, |
|
5735 |
but cannot handle quantifiers. See "HOL/ex/Quickcheck_Examples.thy" |
|
5736 |
for examples. |
|
14464 | 5737 |
|
14606 | 5738 |
|
14536 | 5739 |
*** HOLCF *** |
5740 |
||
5741 |
* Streams now come with concatenation and are part of the HOLCF image |
|
5742 |
||
14572 | 5743 |
|
5744 |
||
14136 | 5745 |
New in Isabelle2003 (May 2003) |
14606 | 5746 |
------------------------------ |
14136 | 5747 |
|
13280
306ef3aef61b
* improved thms_containing: proper indexing of facts instead of raw
wenzelm
parents:
13190
diff
changeset
|
5748 |
*** General *** |
306ef3aef61b
* improved thms_containing: proper indexing of facts instead of raw
wenzelm
parents:
13190
diff
changeset
|
5749 |
|
13618 | 5750 |
* Provers/simplifier: |
5751 |
||
13781 | 5752 |
- Completely reimplemented method simp (ML: Asm_full_simp_tac): |
13618 | 5753 |
Assumptions are now subject to complete mutual simplification, |
5754 |
not just from left to right. The simplifier now preserves |
|
5755 |
the order of assumptions. |
|
5756 |
||
5757 |
Potential INCOMPATIBILITY: |
|
5758 |
||
13781 | 5759 |
-- simp sometimes diverges where the old version did |
5760 |
not, e.g. invoking simp on the goal |
|
13618 | 5761 |
|
5762 |
[| P (f x); y = x; f x = f y |] ==> Q |
|
5763 |
||
13781 | 5764 |
now gives rise to the infinite reduction sequence |
5765 |
||
5766 |
P(f x) --(f x = f y)--> P(f y) --(y = x)--> P(f x) --(f x = f y)--> ... |
|
5767 |
||
5768 |
Using "simp (asm_lr)" (ML: Asm_lr_simp_tac) instead often solves this |
|
5769 |
kind of problem. |
|
5770 |
||
5771 |
-- Tactics combining classical reasoner and simplification (such as auto) |
|
5772 |
are also affected by this change, because many of them rely on |
|
5773 |
simp. They may sometimes diverge as well or yield a different numbers |
|
5774 |
of subgoals. Try to use e.g. force, fastsimp, or safe instead of auto |
|
5775 |
in case of problems. Sometimes subsequent calls to the classical |
|
5776 |
reasoner will fail because a preceeding call to the simplifier too |
|
5777 |
eagerly simplified the goal, e.g. deleted redundant premises. |
|
13618 | 5778 |
|
5779 |
- The simplifier trace now shows the names of the applied rewrite rules |
|
5780 |
||
13829 | 5781 |
- You can limit the number of recursive invocations of the simplifier |
5782 |
during conditional rewriting (where the simplifie tries to solve the |
|
5783 |
conditions before applying the rewrite rule): |
|
5784 |
ML "simp_depth_limit := n" |
|
5785 |
where n is an integer. Thus you can force termination where previously |
|
5786 |
the simplifier would diverge. |
|
5787 |
||
13835
12b2ffbe543a
Change to meta simplifier: congruence rules may now have frees as head of term.
ballarin
parents:
13829
diff
changeset
|
5788 |
- Accepts free variables as head terms in congruence rules. Useful in Isar. |
13829 | 5789 |
|
13938 | 5790 |
- No longer aborts on failed congruence proof. Instead, the |
5791 |
congruence is ignored. |
|
5792 |
||
14008 | 5793 |
* Pure: New generic framework for extracting programs from constructive |
5794 |
proofs. See HOL/Extraction.thy for an example instantiation, as well |
|
5795 |
as HOL/Extraction for some case studies. |
|
5796 |
||
13868 | 5797 |
* Pure: The main goal of the proof state is no longer shown by default, only |
5798 |
the subgoals. This behaviour is controlled by a new flag. |
|
13835
12b2ffbe543a
Change to meta simplifier: congruence rules may now have frees as head of term.
ballarin
parents:
13829
diff
changeset
|
5799 |
PG menu: Isabelle/Isar -> Settings -> Show Main Goal |
13815 | 5800 |
(ML: Proof.show_main_goal). |
5801 |
||
5802 |
* Pure: You can find all matching introduction rules for subgoal 1, i.e. all |
|
5803 |
rules whose conclusion matches subgoal 1: |
|
5804 |
PG menu: Isabelle/Isar -> Show me -> matching rules |
|
5805 |
The rules are ordered by how closely they match the subgoal. |
|
5806 |
In particular, rules that solve a subgoal outright are displayed first |
|
5807 |
(or rather last, the way they are printed). |
|
5808 |
(ML: ProofGeneral.print_intros()) |
|
5809 |
||
5810 |
* Pure: New flag trace_unify_fail causes unification to print |
|
13781 | 5811 |
diagnostic information (PG: in trace buffer) when it fails. This is |
5812 |
useful for figuring out why single step proofs like rule, erule or |
|
5813 |
assumption failed. |
|
5814 |
||
13815 | 5815 |
* Pure: Locale specifications now produce predicate definitions |
13410
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5816 |
according to the body of text (covering assumptions modulo local |
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5817 |
definitions); predicate "loc_axioms" covers newly introduced text, |
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5818 |
while "loc" is cumulative wrt. all included locale expressions; the |
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5819 |
latter view is presented only on export into the global theory |
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5820 |
context; potential INCOMPATIBILITY, use "(open)" option to fall back |
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5821 |
on the old view without predicates; |
f2cd09766864
* Pure: locale specifications now produce predicate definitions;
wenzelm
parents:
13344
diff
changeset
|
5822 |
|
13459
83f41b047a39
* Pure: predefined locales "var" and "struct" are useful for sharing
wenzelm
parents:
13443
diff
changeset
|
5823 |
* Pure: predefined locales "var" and "struct" are useful for sharing |
83f41b047a39
* Pure: predefined locales "var" and "struct" are useful for sharing
wenzelm
parents:
13443
diff
changeset
|
5824 |
parameters (as in CASL, for example); just specify something like |
83f41b047a39
* Pure: predefined locales "var" and "struct" are useful for sharing
wenzelm
parents:
13443
diff
changeset
|
5825 |
``var x + var y + struct M'' as import; |
83f41b047a39
* Pure: predefined locales "var" and "struct" are useful for sharing
wenzelm
parents:
13443
diff
changeset
|
5826 |
|
13463
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5827 |
* Pure: improved thms_containing: proper indexing of facts instead of |
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5828 |
raw theorems; check validity of results wrt. current name space; |
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5829 |
include local facts of proof configuration (also covers active |
13541 | 5830 |
locales), cover fixed variables in index; may use "_" in term |
5831 |
specification; an optional limit for the number of printed facts may |
|
5832 |
be given (the default is 40); |
|
5833 |
||
5834 |
* Pure: disallow duplicate fact bindings within new-style theory files |
|
5835 |
(batch-mode only); |
|
13540
aede0306e214
* Pure: disallow duplicate fact bindings within new-style theory files;
wenzelm
parents:
13522
diff
changeset
|
5836 |
|
13463
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5837 |
* Provers: improved induct method: assumptions introduced by case |
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5838 |
"foo" are split into "foo.hyps" (from the rule) and "foo.prems" (from |
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5839 |
the goal statement); "foo" still refers to all facts collectively; |
07747943c626
* Provers: Simplifier.simproc(_i) now provide sane interface for
wenzelm
parents:
13459
diff
changeset
|
5840 |
|
13550 | 5841 |
* Provers: the function blast.overloaded has been removed: all constants |
5842 |
are regarded as potentially overloaded, which improves robustness in exchange |
|
5843 |
for slight decrease in efficiency; |
|
5844 |
||
13781 | 5845 |
* Provers/linorder: New generic prover for transitivity reasoning over |
5846 |
linear orders. Note: this prover is not efficient! |
|
5847 |
||
13522
934fffeb6f38
* Isar: preview of problems to finish 'show' now produce an error
wenzelm
parents:
13518
diff
changeset
|
5848 |
* Isar: preview of problems to finish 'show' now produce an error |
934fffeb6f38
* Isar: preview of problems to finish 'show' now produce an error
wenzelm
parents:
13518
diff
changeset
|
5849 |
rather than just a warning (in interactive mode); |
934fffeb6f38
* Isar: preview of problems to finish 'show' now produce an error
wenzelm
parents:
13518
diff
changeset
|
5850 |
|
13280
306ef3aef61b
* improved thms_containing: proper indexing of facts instead of raw
wenzelm
parents:
13190
diff
changeset
|
5851 |
|
13158 | 5852 |
*** HOL *** |
5853 |
||
13899 | 5854 |
* arith(_tac) |
5855 |
||
5856 |
- Produces a counter example if it cannot prove a goal. |
|
5857 |
Note that the counter example may be spurious if the goal is not a formula |
|
5858 |
of quantifier-free linear arithmetic. |
|
5859 |
In ProofGeneral the counter example appears in the trace buffer. |
|
5860 |
||
5861 |
- Knows about div k and mod k where k is a numeral of type nat or int. |
|
5862 |
||
5863 |
- Calls full Presburger arithmetic (by Amine Chaieb) if quantifier-free |
|
5864 |
linear arithmetic fails. This takes account of quantifiers and divisibility. |
|
14731 | 5865 |
Presburger arithmetic can also be called explicitly via presburger(_tac). |
13899 | 5866 |
|
5867 |
* simp's arithmetic capabilities have been enhanced a bit: it now |
|
5868 |
takes ~= in premises into account (by performing a case split); |
|
5869 |
||
5870 |
* simp reduces "m*(n div m) + n mod m" to n, even if the two summands |
|
5871 |
are distributed over a sum of terms; |
|
5872 |
||
13735 | 5873 |
* New tactic "trans_tac" and method "trans" instantiate |
5874 |
Provers/linorder.ML for axclasses "order" and "linorder" (predicates |
|
14731 | 5875 |
"<=", "<" and "="). |
5876 |
||
5877 |
* function INCOMPATIBILITIES: Pi-sets have been redefined and moved from main |
|
13587 | 5878 |
HOL to Library/FuncSet; constant "Fun.op o" is now called "Fun.comp"; |
5879 |
||
13443 | 5880 |
* 'typedef' command has new option "open" to suppress the set |
5881 |
definition; |
|
5882 |
||
13522
934fffeb6f38
* Isar: preview of problems to finish 'show' now produce an error
wenzelm
parents:
13518
diff
changeset
|
5883 |
* functions Min and Max on finite sets have been introduced (theory |
934fffeb6f38
* Isar: preview of problems to finish 'show' now produce an error
wenzelm
parents:
13518
diff
changeset
|
5884 |
Finite_Set); |
13492 | 5885 |
|
13443 | 5886 |
* attribute [symmetric] now works for relations as well; it turns |
5887 |
(x,y) : R^-1 into (y,x) : R, and vice versa; |
|
5888 |
||
13613 | 5889 |
* induct over a !!-quantified statement (say !!x1..xn): |
5890 |
each "case" automatically performs "fix x1 .. xn" with exactly those names. |
|
5891 |
||
13899 | 5892 |
* Map: `empty' is no longer a constant but a syntactic abbreviation for |
5893 |
%x. None. Warning: empty_def now refers to the previously hidden definition |
|
5894 |
of the empty set. |
|
5895 |
||
14018 | 5896 |
* Algebra: formalization of classical algebra. Intended as base for |
5897 |
any algebraic development in Isabelle. Currently covers group theory |
|
5898 |
(up to Sylow's theorem) and ring theory (Universal Property of |
|
5899 |
Univariate Polynomials). Contributions welcome; |
|
13960 | 5900 |
|
5901 |
* GroupTheory: deleted, since its material has been moved to Algebra; |
|
5902 |
||
14731 | 5903 |
* Complex: new directory of the complex numbers with numeric constants, |
5904 |
nonstandard complex numbers, and some complex analysis, standard and |
|
13966
2160abf7cfe7
removal of the image HOL-Real and merging of HOL-Real-ex with HOL-Complex-ex
paulson
parents:
13960
diff
changeset
|
5905 |
nonstandard (Jacques Fleuriot); |
2160abf7cfe7
removal of the image HOL-Real and merging of HOL-Real-ex with HOL-Complex-ex
paulson
parents:
13960
diff
changeset
|
5906 |
|
2160abf7cfe7
removal of the image HOL-Real and merging of HOL-Real-ex with HOL-Complex-ex
paulson
parents:
13960
diff
changeset
|
5907 |
* HOL-Complex: new image for analysis, replacing HOL-Real and HOL-Hyperreal; |
2160abf7cfe7
removal of the image HOL-Real and merging of HOL-Real-ex with HOL-Complex-ex
paulson
parents:
13960
diff
changeset
|
5908 |
|
14731 | 5909 |
* Hyperreal: introduced Gauge integration and hyperreal logarithms (Jacques |
13966
2160abf7cfe7
removal of the image HOL-Real and merging of HOL-Real-ex with HOL-Complex-ex
paulson
parents:
13960
diff
changeset
|
5910 |
Fleuriot); |
13960 | 5911 |
|
13549 | 5912 |
* Real/HahnBanach: updated and adapted to locales; |
5913 |
||
13995 | 5914 |
* NumberTheory: added Gauss's law of quadratic reciprocity (by Avigad, |
5915 |
Gray and Kramer); |
|
13872 | 5916 |
|
5917 |
* UNITY: added the Meier-Sanders theory of progress sets; |
|
5918 |
||
14011 | 5919 |
* MicroJava: bytecode verifier and lightweight bytecode verifier |
5920 |
as abstract algorithms, instantiated to the JVM; |
|
5921 |
||
14010 | 5922 |
* Bali: Java source language formalization. Type system, operational |
5923 |
semantics, axiomatic semantics. Supported language features: |
|
5924 |
classes, interfaces, objects,virtual methods, static methods, |
|
5925 |
static/instance fields, arrays, access modifiers, definite |
|
5926 |
assignment, exceptions. |
|
13549 | 5927 |
|
14011 | 5928 |
|
13549 | 5929 |
*** ZF *** |
5930 |
||
15154 | 5931 |
* ZF/Constructible: consistency proof for AC (Gdel's constructible |
13549 | 5932 |
universe, etc.); |
5933 |
||
13872 | 5934 |
* Main ZF: virtually all theories converted to new-style format; |
13518 | 5935 |
|
13280
306ef3aef61b
* improved thms_containing: proper indexing of facts instead of raw
wenzelm
parents:
13190
diff
changeset
|
5936 |
|
13478 | 5937 |
*** ML *** |
5938 |
||
5939 |
* Pure: Tactic.prove provides sane interface for internal proofs; |
|
5940 |
omits the infamous "standard" operation, so this is more appropriate |
|
5941 |
than prove_goalw_cterm in many situations (e.g. in simprocs); |
|
5942 |
||
5943 |
* Pure: improved error reporting of simprocs; |
|
5944 |
||
5945 |
* Provers: Simplifier.simproc(_i) provides sane interface for setting |
|
5946 |
up simprocs; |
|
5947 |
||
5948 |
||
13953 | 5949 |
*** Document preparation *** |
5950 |
||
5951 |
* uses \par instead of \\ for line breaks in theory text. This may |
|
5952 |
shift some page breaks in large documents. To get the old behaviour |
|
5953 |
use \renewcommand{\isanewline}{\mbox{}\\\mbox{}} in root.tex. |
|
5954 |
||
14731 | 5955 |
* minimized dependencies of isabelle.sty and isabellesym.sty on |
13953 | 5956 |
other packages |
5957 |
||
5958 |
* \<euro> now needs package babel/greek instead of marvosym (which |
|
5959 |
broke \Rightarrow) |
|
5960 |
||
14731 | 5961 |
* normal size for \<zero>...\<nine> (uses \mathbf instead of |
13954 | 5962 |
textcomp package) |
13953 | 5963 |
|
13280
306ef3aef61b
* improved thms_containing: proper indexing of facts instead of raw
wenzelm
parents:
13190
diff
changeset
|
5964 |
|
14572 | 5965 |
|
12984 | 5966 |
New in Isabelle2002 (March 2002) |
5967 |
-------------------------------- |
|
11474 | 5968 |
|
11572 | 5969 |
*** Document preparation *** |
5970 |
||
11842
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5971 |
* greatly simplified document preparation setup, including more |
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5972 |
graceful interpretation of isatool usedir -i/-d/-D options, and more |
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5973 |
instructive isatool mkdir; users should basically be able to get |
12899
7d5b690253ee
"isatool usedir -D output HOL Test && isatool document Test/output";
wenzelm
parents:
12889
diff
changeset
|
5974 |
started with "isatool mkdir HOL Test && isatool make"; alternatively, |
7d5b690253ee
"isatool usedir -D output HOL Test && isatool document Test/output";
wenzelm
parents:
12889
diff
changeset
|
5975 |
users may run a separate document processing stage manually like this: |
7d5b690253ee
"isatool usedir -D output HOL Test && isatool document Test/output";
wenzelm
parents:
12889
diff
changeset
|
5976 |
"isatool usedir -D output HOL Test && isatool document Test/output"; |
11842
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5977 |
|
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5978 |
* theory dependency graph may now be incorporated into documents; |
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5979 |
isatool usedir -g true will produce session_graph.eps/.pdf for use |
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5980 |
with \includegraphics of LaTeX; |
b903d3dabbe2
* greatly simplified document preparation setup, including more
wenzelm
parents:
11817
diff
changeset
|
5981 |
|
11864
371ce685b0ec
* proper spacing of consecutive markup elements, especially text
wenzelm
parents:
11842
diff
changeset
|
5982 |
* proper spacing of consecutive markup elements, especially text |
371ce685b0ec
* proper spacing of consecutive markup elements, especially text
wenzelm
parents:
11842
diff
changeset
|
5983 |
blocks after section headings; |
371ce685b0ec
* proper spacing of consecutive markup elements, especially text
wenzelm
parents:
11842
diff
changeset
|
5984 |
|
11572 | 5985 |
* support bold style (for single symbols only), input syntax is like |
5986 |
this: "\<^bold>\<alpha>" or "\<^bold>A"; |
|
5987 |
||
11814 | 5988 |
* \<bullet> is now output as bold \cdot by default, which looks much |
11572 | 5989 |
better in printed text; |
5990 |
||
11712
deb8cac87063
* added default LaTeX bindings for \<tturnstile> and \<TTurnstile>;
wenzelm
parents:
11702
diff
changeset
|
5991 |
* added default LaTeX bindings for \<tturnstile> and \<TTurnstile>; |
deb8cac87063
* added default LaTeX bindings for \<tturnstile> and \<TTurnstile>;
wenzelm
parents:
11702
diff
changeset
|
5992 |
note that these symbols are currently unavailable in Proof General / |
12769 | 5993 |
X-Symbol; new symbols \<zero>, \<one>, ..., \<nine>, and \<euro>; |
12690 | 5994 |
|
5995 |
* isatool latex no longer depends on changed TEXINPUTS, instead |
|
5996 |
isatool document copies the Isabelle style files to the target |
|
5997 |
location; |
|
11712
deb8cac87063
* added default LaTeX bindings for \<tturnstile> and \<TTurnstile>;
wenzelm
parents:
11702
diff
changeset
|
5998 |
|
11572 | 5999 |
|
11633 | 6000 |
*** Isar *** |
6001 |
||
12312
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6002 |
* Pure/Provers: improved proof by cases and induction; |
12280 | 6003 |
- 'case' command admits impromptu naming of parameters (such as |
6004 |
"case (Suc n)"); |
|
6005 |
- 'induct' method divinates rule instantiation from the inductive |
|
6006 |
claim; no longer requires excessive ?P bindings for proper |
|
6007 |
instantiation of cases; |
|
6008 |
- 'induct' method properly enumerates all possibilities of set/type |
|
6009 |
rules; as a consequence facts may be also passed through *type* |
|
6010 |
rules without further ado; |
|
6011 |
- 'induct' method now derives symbolic cases from the *rulified* |
|
6012 |
rule (before it used to rulify cases stemming from the internal |
|
6013 |
atomized version); this means that the context of a non-atomic |
|
6014 |
statement becomes is included in the hypothesis, avoiding the |
|
6015 |
slightly cumbersome show "PROP ?case" form; |
|
6016 |
- 'induct' may now use elim-style induction rules without chaining |
|
6017 |
facts, using ``missing'' premises from the goal state; this allows |
|
6018 |
rules stemming from inductive sets to be applied in unstructured |
|
6019 |
scripts, while still benefitting from proper handling of non-atomic |
|
6020 |
statements; NB: major inductive premises need to be put first, all |
|
6021 |
the rest of the goal is passed through the induction; |
|
6022 |
- 'induct' proper support for mutual induction involving non-atomic |
|
6023 |
rule statements (uses the new concept of simultaneous goals, see |
|
6024 |
below); |
|
12853 | 6025 |
- append all possible rule selections, but only use the first |
6026 |
success (no backtracking); |
|
11995
4a622f5fb164
- 'induct' may now use elim-style induction rules without chaining
wenzelm
parents:
11986
diff
changeset
|
6027 |
- removed obsolete "(simplified)" and "(stripped)" options of methods; |
12754
044a59921f3b
Isar: undeclared rule case names default to numbers 1, 2, 3, ...;
wenzelm
parents:
12753
diff
changeset
|
6028 |
- undeclared rule case names default to numbers 1, 2, 3, ...; |
044a59921f3b
Isar: undeclared rule case names default to numbers 1, 2, 3, ...;
wenzelm
parents:
12753
diff
changeset
|
6029 |
- added 'print_induct_rules' (covered by help item in recent Proof |
044a59921f3b
Isar: undeclared rule case names default to numbers 1, 2, 3, ...;
wenzelm
parents:
12753
diff
changeset
|
6030 |
General versions); |
11995
4a622f5fb164
- 'induct' may now use elim-style induction rules without chaining
wenzelm
parents:
11986
diff
changeset
|
6031 |
- moved induct/cases attributes to Pure, methods to Provers; |
4a622f5fb164
- 'induct' may now use elim-style induction rules without chaining
wenzelm
parents:
11986
diff
changeset
|
6032 |
- generic method setup instantiated for FOL and HOL; |
11986
26b95a6f3f79
- 'induct' method now derives symbolic cases from the *rulified* rule
wenzelm
parents:
11965
diff
changeset
|
6033 |
|
12163
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6034 |
* Pure: support multiple simultaneous goal statements, for example |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6035 |
"have a: A and b: B" (same for 'theorem' etc.); being a pure |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6036 |
meta-level mechanism, this acts as if several individual goals had |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6037 |
been stated separately; in particular common proof methods need to be |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6038 |
repeated in order to cover all claims; note that a single elimination |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6039 |
step is *not* sufficient to establish the two conjunctions, so this |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6040 |
fails: |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6041 |
|
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6042 |
assume "A & B" then have A and B .. (*".." fails*) |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6043 |
|
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6044 |
better use "obtain" in situations as above; alternative refer to |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6045 |
multi-step methods like 'auto', 'simp_all', 'blast+' etc.; |
04c98351f9af
Isar: 'induct' proper support for mutual induction involving
wenzelm
parents:
12159
diff
changeset
|
6046 |
|
12078
4eb8061286e5
* Isar/Pure: proper integration with ``locales''; unlike the original
wenzelm
parents:
12034
diff
changeset
|
6047 |
* Pure: proper integration with ``locales''; unlike the original |
15154 | 6048 |
version by Florian Kammller, Isar locales package high-level proof |
12078
4eb8061286e5
* Isar/Pure: proper integration with ``locales''; unlike the original
wenzelm
parents:
12034
diff
changeset
|
6049 |
contexts rather than raw logical ones (e.g. we admit to include |
12280 | 6050 |
attributes everywhere); operations on locales include merge and |
12964 | 6051 |
rename; support for implicit arguments (``structures''); simultaneous |
6052 |
type-inference over imports and text; see also HOL/ex/Locales.thy for |
|
6053 |
some examples; |
|
12078
4eb8061286e5
* Isar/Pure: proper integration with ``locales''; unlike the original
wenzelm
parents:
12034
diff
changeset
|
6054 |
|
12707
4013be8572c5
* Pure: localized 'lemmas', 'theorems', 'declare';
wenzelm
parents:
12690
diff
changeset
|
6055 |
* Pure: the following commands have been ``localized'', supporting a |
4013be8572c5
* Pure: localized 'lemmas', 'theorems', 'declare';
wenzelm
parents:
12690
diff
changeset
|
6056 |
target locale specification "(in name)": 'lemma', 'theorem', |
4013be8572c5
* Pure: localized 'lemmas', 'theorems', 'declare';
wenzelm
parents:
12690
diff
changeset
|
6057 |
'corollary', 'lemmas', 'theorems', 'declare'; the results will be |
4013be8572c5
* Pure: localized 'lemmas', 'theorems', 'declare';
wenzelm
parents:
12690
diff
changeset
|
6058 |
stored both within the locale and at the theory level (exported and |
4013be8572c5
* Pure: localized 'lemmas', 'theorems', 'declare';
wenzelm
parents:
12690
diff
changeset
|
6059 |
qualified by the locale name); |
4013be8572c5
* Pure: localized 'lemmas', 'theorems', 'declare';
wenzelm
parents:
12690
diff
changeset
|
6060 |
|
12964 | 6061 |
* Pure: theory goals may now be specified in ``long'' form, with |
6062 |
ad-hoc contexts consisting of arbitrary locale elements. for example |
|
6063 |
``lemma foo: fixes x assumes "A x" shows "B x"'' (local syntax and |
|
6064 |
definitions may be given, too); the result is a meta-level rule with |
|
6065 |
the context elements being discharged in the obvious way; |
|
6066 |
||
6067 |
* Pure: new proof command 'using' allows to augment currently used |
|
6068 |
facts after a goal statement ('using' is syntactically analogous to |
|
6069 |
'apply', but acts on the goal's facts only); this allows chained facts |
|
6070 |
to be separated into parts given before and after a claim, as in |
|
6071 |
``from a and b have C using d and e <proof>''; |
|
12078
4eb8061286e5
* Isar/Pure: proper integration with ``locales''; unlike the original
wenzelm
parents:
12034
diff
changeset
|
6072 |
|
11722 | 6073 |
* Pure: renamed "antecedent" case to "rule_context"; |
6074 |
||
12964 | 6075 |
* Pure: new 'judgment' command records explicit information about the |
6076 |
object-logic embedding (used by several tools internally); no longer |
|
6077 |
use hard-wired "Trueprop"; |
|
6078 |
||
11738 | 6079 |
* Pure: added 'corollary' command; |
6080 |
||
11722 | 6081 |
* Pure: fixed 'token_translation' command; |
6082 |
||
11899 | 6083 |
* Pure: removed obsolete 'exported' attribute; |
6084 |
||
11933 | 6085 |
* Pure: dummy pattern "_" in is/let is now automatically lifted over |
6086 |
bound variables: "ALL x. P x --> Q x" (is "ALL x. _ --> ?C x") |
|
11899 | 6087 |
supersedes more cumbersome ... (is "ALL x. _ x --> ?C x"); |
6088 |
||
11952
b10f1e8862f4
* Pure: method 'atomize' presents local goal premises as object-level
wenzelm
parents:
11937
diff
changeset
|
6089 |
* Pure: method 'atomize' presents local goal premises as object-level |
b10f1e8862f4
* Pure: method 'atomize' presents local goal premises as object-level
wenzelm
parents:
11937
diff
changeset
|
6090 |
statements (atomic meta-level propositions); setup controlled via |
b10f1e8862f4
* Pure: method 'atomize' presents local goal premises as object-level
wenzelm
parents:
11937
diff
changeset
|
6091 |
rewrite rules declarations of 'atomize' attribute; example |
b10f1e8862f4
* Pure: method 'atomize' presents local goal premises as object-level
wenzelm
parents:
11937
diff
changeset
|
6092 |
application: 'induct' method with proper rule statements in improper |
b10f1e8862f4
* Pure: method 'atomize' presents local goal premises as object-level
wenzelm
parents:
11937
diff
changeset
|
6093 |
proof *scripts*; |
b10f1e8862f4
* Pure: method 'atomize' presents local goal premises as object-level
wenzelm
parents:
11937
diff
changeset
|
6094 |
|
12106
4a8558dbb6a0
* Isar/Pure: emulation of instantiation tactics (rule_tac, cut_tac,
wenzelm
parents:
12078
diff
changeset
|
6095 |
* Pure: emulation of instantiation tactics (rule_tac, cut_tac, etc.) |
4a8558dbb6a0
* Isar/Pure: emulation of instantiation tactics (rule_tac, cut_tac,
wenzelm
parents:
12078
diff
changeset
|
6096 |
now consider the syntactic context of assumptions, giving a better |
4a8558dbb6a0
* Isar/Pure: emulation of instantiation tactics (rule_tac, cut_tac,
wenzelm
parents:
12078
diff
changeset
|
6097 |
chance to get type-inference of the arguments right (this is |
4a8558dbb6a0
* Isar/Pure: emulation of instantiation tactics (rule_tac, cut_tac,
wenzelm
parents:
12078
diff
changeset
|
6098 |
especially important for locales); |
4a8558dbb6a0
* Isar/Pure: emulation of instantiation tactics (rule_tac, cut_tac,
wenzelm
parents:
12078
diff
changeset
|
6099 |
|
12312
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6100 |
* Pure: "sorry" no longer requires quick_and_dirty in interactive |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6101 |
mode; |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6102 |
|
12405
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6103 |
* Pure/obtain: the formal conclusion "thesis", being marked as |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6104 |
``internal'', may no longer be reference directly in the text; |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6105 |
potential INCOMPATIBILITY, may need to use "?thesis" in rare |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6106 |
situations; |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6107 |
|
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6108 |
* Pure: generic 'sym' attribute which declares a rule both as pure |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6109 |
'elim?' and for the 'symmetric' operation; |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6110 |
|
12877
b9635eb8a448
* Isar/Pure: marginal comments ``--'' may now occur just anywhere in the text;
wenzelm
parents:
12853
diff
changeset
|
6111 |
* Pure: marginal comments ``--'' may now occur just anywhere in the |
b9635eb8a448
* Isar/Pure: marginal comments ``--'' may now occur just anywhere in the text;
wenzelm
parents:
12853
diff
changeset
|
6112 |
text; the fixed correlation with particular command syntax has been |
b9635eb8a448
* Isar/Pure: marginal comments ``--'' may now occur just anywhere in the text;
wenzelm
parents:
12853
diff
changeset
|
6113 |
discontinued; |
b9635eb8a448
* Isar/Pure: marginal comments ``--'' may now occur just anywhere in the text;
wenzelm
parents:
12853
diff
changeset
|
6114 |
|
13023
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6115 |
* Pure: new method 'rules' is particularly well-suited for proof |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6116 |
search in intuitionistic logic; a bit slower than 'blast' or 'fast', |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6117 |
but often produces more compact proof terms with less detours; |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6118 |
|
12364
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6119 |
* Pure/Provers/classical: simplified integration with pure rule |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6120 |
attributes and methods; the classical "intro?/elim?/dest?" |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6121 |
declarations coincide with the pure ones; the "rule" method no longer |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6122 |
includes classically swapped intros; "intro" and "elim" methods no |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6123 |
longer pick rules from the context; also got rid of ML declarations |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6124 |
AddXIs/AddXEs/AddXDs; all of this has some potential for |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6125 |
INCOMPATIBILITY; |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6126 |
|
12405
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6127 |
* Provers/classical: attribute 'swapped' produces classical inversions |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6128 |
of introduction rules; |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6129 |
|
12364
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6130 |
* Provers/simplifier: 'simplified' attribute may refer to explicit |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6131 |
rules instead of full simplifier context; 'iff' attribute handles |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6132 |
conditional rules; |
11936
fef099613354
* Provers: 'simplified' attribute may refer to explicit rules instead
wenzelm
parents:
11933
diff
changeset
|
6133 |
|
11745
06cd8c3b5487
* HOL: 'typedef' now allows alternative names for Rep/Abs morphisms;
wenzelm
parents:
11738
diff
changeset
|
6134 |
* HOL: 'typedef' now allows alternative names for Rep/Abs morphisms; |
06cd8c3b5487
* HOL: 'typedef' now allows alternative names for Rep/Abs morphisms;
wenzelm
parents:
11738
diff
changeset
|
6135 |
|
11690 | 6136 |
* HOL: 'recdef' now fails on unfinished automated proofs, use |
11633 | 6137 |
"(permissive)" option to recover old behavior; |
6138 |
||
11933 | 6139 |
* HOL: 'inductive' no longer features separate (collective) attributes |
6140 |
for 'intros' (was found too confusing); |
|
6141 |
||
12405
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6142 |
* HOL: properly declared induction rules less_induct and |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6143 |
wf_induct_rule; |
9b16f99fd7b9
* Pure/obtain: "thesis" now internal (use ?thesis);
wenzelm
parents:
12364
diff
changeset
|
6144 |
|
11788
60054fee3c16
canonical 'cases'/'induct' rules for n-tuples (n=3..7)
kleing
parents:
11745
diff
changeset
|
6145 |
|
11474 | 6146 |
*** HOL *** |
6147 |
||
11702 | 6148 |
* HOL: moved over to sane numeral syntax; the new policy is as |
6149 |
follows: |
|
6150 |
||
6151 |
- 0 and 1 are polymorphic constants, which are defined on any |
|
6152 |
numeric type (nat, int, real etc.); |
|
6153 |
||
6154 |
- 2, 3, 4, ... and -1, -2, -3, ... are polymorphic numerals, based |
|
6155 |
binary representation internally; |
|
6156 |
||
6157 |
- type nat has special constructor Suc, and generally prefers Suc 0 |
|
6158 |
over 1::nat and Suc (Suc 0) over 2::nat; |
|
6159 |
||
12364
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6160 |
This change may cause significant problems of INCOMPATIBILITY; here |
108cdda23ab3
* Pure/Provers/classical: simplified integration with pure rule
wenzelm
parents:
12335
diff
changeset
|
6161 |
are some hints on converting existing sources: |
11702 | 6162 |
|
6163 |
- due to the new "num" token, "-0" and "-1" etc. are now atomic |
|
6164 |
entities, so expressions involving "-" (unary or binary minus) need |
|
6165 |
to be spaced properly; |
|
6166 |
||
6167 |
- existing occurrences of "1" may need to be constraint "1::nat" or |
|
6168 |
even replaced by Suc 0; similar for old "2"; |
|
6169 |
||
6170 |
- replace "#nnn" by "nnn", and "#-nnn" by "-nnn"; |
|
6171 |
||
6172 |
- remove all special provisions on numerals in proofs; |
|
6173 |
||
13042 | 6174 |
* HOL: simp rules nat_number expand numerals on nat to Suc/0 |
12837 | 6175 |
representation (depends on bin_arith_simps in the default context); |
6176 |
||
12736 | 6177 |
* HOL: symbolic syntax for x^2 (numeral 2); |
6178 |
||
12335
db4d5f498742
* HOL: the class of all HOL types is now called "type" rather than
wenzelm
parents:
12312
diff
changeset
|
6179 |
* HOL: the class of all HOL types is now called "type" rather than |
db4d5f498742
* HOL: the class of all HOL types is now called "type" rather than
wenzelm
parents:
12312
diff
changeset
|
6180 |
"term"; INCOMPATIBILITY, need to adapt references to this type class |
db4d5f498742
* HOL: the class of all HOL types is now called "type" rather than
wenzelm
parents:
12312
diff
changeset
|
6181 |
in axclass/classes, instance/arities, and (usually rare) occurrences |
db4d5f498742
* HOL: the class of all HOL types is now called "type" rather than
wenzelm
parents:
12312
diff
changeset
|
6182 |
in typings (of consts etc.); internally the class is called |
db4d5f498742
* HOL: the class of all HOL types is now called "type" rather than
wenzelm
parents:
12312
diff
changeset
|
6183 |
"HOL.type", ML programs should refer to HOLogic.typeS; |
db4d5f498742
* HOL: the class of all HOL types is now called "type" rather than
wenzelm
parents:
12312
diff
changeset
|
6184 |
|
12280 | 6185 |
* HOL/record package improvements: |
6186 |
- new derived operations "fields" to build a partial record section, |
|
6187 |
"extend" to promote a fixed record to a record scheme, and |
|
6188 |
"truncate" for the reverse; cf. theorems "xxx.defs", which are *not* |
|
6189 |
declared as simp by default; |
|
12587
3f3d2ffb5df5
HOL/record: shared operations ("more", "fields", etc.) now need to be
wenzelm
parents:
12564
diff
changeset
|
6190 |
- shared operations ("more", "fields", etc.) now need to be always |
3f3d2ffb5df5
HOL/record: shared operations ("more", "fields", etc.) now need to be
wenzelm
parents:
12564
diff
changeset
|
6191 |
qualified) --- potential INCOMPATIBILITY; |
12280 | 6192 |
- removed "make_scheme" operations (use "make" with "extend") -- |
6193 |
INCOMPATIBILITY; |
|
11937 | 6194 |
- removed "more" class (simply use "term") -- INCOMPATIBILITY; |
12253 | 6195 |
- provides cases/induct rules for use with corresponding Isar |
6196 |
methods (for concrete records, record schemes, concrete more |
|
12280 | 6197 |
parts, and schematic more parts -- in that order); |
11930 | 6198 |
- internal definitions directly based on a light-weight abstract |
6199 |
theory of product types over typedef rather than datatype; |
|
6200 |
||
13023
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6201 |
* HOL: generic code generator for generating executable ML code from |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6202 |
specifications; specific support for HOL constructs such as inductive |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6203 |
datatypes and sets, as well as recursive functions; can be invoked |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6204 |
via 'generate_code' theory section; |
f869b6822006
Added two paragraphs on "rules" method and code generator.
berghofe
parents:
12984
diff
changeset
|
6205 |
|
11933 | 6206 |
* HOL: canonical cases/induct rules for n-tuples (n = 3..7); |
6207 |
||
13824 | 6208 |
* HOL: consolidated and renamed several theories. In particular: |
14731 | 6209 |
Ord.thy has been absorbed into HOL.thy |
6210 |
String.thy has been absorbed into List.thy |
|
6211 |
||
11802
1d5f5d2427d2
* HOL: concrete setsum syntax "\<Sum>i:A. b" == "setsum (%i. b) A"
wenzelm
parents:
11797
diff
changeset
|
6212 |
* HOL: concrete setsum syntax "\<Sum>i:A. b" == "setsum (%i. b) A" |
1d5f5d2427d2
* HOL: concrete setsum syntax "\<Sum>i:A. b" == "setsum (%i. b) A"
wenzelm
parents:
11797
diff
changeset
|
6213 |
(beware of argument permutation!); |
1d5f5d2427d2
* HOL: concrete setsum syntax "\<Sum>i:A. b" == "setsum (%i. b) A"
wenzelm
parents:
11797
diff
changeset
|
6214 |
|
11657 | 6215 |
* HOL: linorder_less_split superseded by linorder_cases; |
6216 |
||
12917 | 6217 |
* HOL/List: "nodups" renamed to "distinct"; |
12889 | 6218 |
|
11633 | 6219 |
* HOL: added "The" definite description operator; move Hilbert's "Eps" |
13824 | 6220 |
to peripheral theory "Hilbert_Choice"; some INCOMPATIBILITIES: |
6221 |
- Ex_def has changed, now need to use some_eq_ex |
|
11437 | 6222 |
|
11572 | 6223 |
* HOL: made split_all_tac safe; EXISTING PROOFS MAY FAIL OR LOOP, so |
6224 |
in this (rare) case use: |
|
6225 |
||
6226 |
delSWrapper "split_all_tac" |
|
6227 |
addSbefore ("unsafe_split_all_tac", unsafe_split_all_tac) |
|
6228 |
||
6229 |
* HOL: added safe wrapper "split_conv_tac" to claset; EXISTING PROOFS |
|
11474 | 6230 |
MAY FAIL; |
11361 | 6231 |
|
11572 | 6232 |
* HOL: introduced f^n = f o ... o f; warning: due to the limits of |
6233 |
Isabelle's type classes, ^ on functions and relations has too general |
|
6234 |
a domain, namely ('a * 'b) set and 'a => 'b; this means that it may be |
|
6235 |
necessary to attach explicit type constraints; |
|
11307 | 6236 |
|
12917 | 6237 |
* HOL/Relation: the prefix name of the infix "O" has been changed from |
6238 |
"comp" to "rel_comp"; INCOMPATIBILITY: a few theorems have been |
|
6239 |
renamed accordingly (eg "compI" -> "rel_compI"). |
|
12489 | 6240 |
|
11487
95071c9e85a3
* HOL: syntax translations now work properly with numerals and records
wenzelm
parents:
11475
diff
changeset
|
6241 |
* HOL: syntax translations now work properly with numerals and records |
95071c9e85a3
* HOL: syntax translations now work properly with numerals and records
wenzelm
parents:
11475
diff
changeset
|
6242 |
expressions; |
11474 | 6243 |
|
12457
cbfc53e45476
* HOL: bounded abstraction now uses syntax "%" / "\<lambda>" instead
wenzelm
parents:
12405
diff
changeset
|
6244 |
* HOL: bounded abstraction now uses syntax "%" / "\<lambda>" instead |
cbfc53e45476
* HOL: bounded abstraction now uses syntax "%" / "\<lambda>" instead
wenzelm
parents:
12405
diff
changeset
|
6245 |
of "lam" -- INCOMPATIBILITY; |
11474 | 6246 |
|
11933 | 6247 |
* HOL: got rid of some global declarations (potential INCOMPATIBILITY |
6248 |
for ML tools): const "()" renamed "Product_Type.Unity", type "unit" |
|
6249 |
renamed "Product_Type.unit"; |
|
11611 | 6250 |
|
12564 | 6251 |
* HOL: renamed rtrancl_into_rtrancl2 to converse_rtrancl_into_rtrancl |
6252 |
||
12924 | 6253 |
* HOL: removed obsolete theorem "optionE" (use "option.exhaust", or |
6254 |
the "cases" method); |
|
6255 |
||
12597
14822e4436bf
HOL/IMP and HOLCF/IMP updated and converted (Gerwin Klein);
wenzelm
parents:
12587
diff
changeset
|
6256 |
* HOL/GroupTheory: group theory examples including Sylow's theorem (by |
15154 | 6257 |
Florian Kammller); |
12597
14822e4436bf
HOL/IMP and HOLCF/IMP updated and converted (Gerwin Klein);
wenzelm
parents:
12587
diff
changeset
|
6258 |
|
12608
2df381faa787
* ZF/IMP: updated and converted to new-style theory format;
wenzelm
parents:
12597
diff
changeset
|
6259 |
* HOL/IMP: updated and converted to new-style theory format; several |
2df381faa787
* ZF/IMP: updated and converted to new-style theory format;
wenzelm
parents:
12597
diff
changeset
|
6260 |
parts turned into readable document, with proper Isar proof texts and |
2df381faa787
* ZF/IMP: updated and converted to new-style theory format;
wenzelm
parents:
12597
diff
changeset
|
6261 |
some explanations (by Gerwin Klein); |
12597
14822e4436bf
HOL/IMP and HOLCF/IMP updated and converted (Gerwin Klein);
wenzelm
parents:
12587
diff
changeset
|
6262 |
|
12734 | 6263 |
* HOL-Real: added Complex_Numbers (by Gertrud Bauer); |
6264 |
||
12690 | 6265 |
* HOL-Hyperreal is now a logic image; |
6266 |
||
11611 | 6267 |
|
12022
9c3377b133c0
HOLCF: proper rep_datatype lift (see theory Lift); use plain induct_tac
wenzelm
parents:
11995
diff
changeset
|
6268 |
*** HOLCF *** |
9c3377b133c0
HOLCF: proper rep_datatype lift (see theory Lift); use plain induct_tac
wenzelm
parents:
11995
diff
changeset
|
6269 |
|
12622 | 6270 |
* Isar: consts/constdefs supports mixfix syntax for continuous |
6271 |
operations; |
|
6272 |
||
6273 |
* Isar: domain package adapted to new-style theory format, e.g. see |
|
6274 |
HOLCF/ex/Dnat.thy; |
|
6275 |
||
6276 |
* theory Lift: proper use of rep_datatype lift instead of ML hacks -- |
|
12280 | 6277 |
potential INCOMPATIBILITY; now use plain induct_tac instead of former |
6278 |
lift.induct_tac, always use UU instead of Undef; |
|
12022
9c3377b133c0
HOLCF: proper rep_datatype lift (see theory Lift); use plain induct_tac
wenzelm
parents:
11995
diff
changeset
|
6279 |
|
12597
14822e4436bf
HOL/IMP and HOLCF/IMP updated and converted (Gerwin Klein);
wenzelm
parents:
12587
diff
changeset
|
6280 |
* HOLCF/IMP: updated and converted to new-style theory; |
14822e4436bf
HOL/IMP and HOLCF/IMP updated and converted (Gerwin Klein);
wenzelm
parents:
12587
diff
changeset
|
6281 |
|
12022
9c3377b133c0
HOLCF: proper rep_datatype lift (see theory Lift); use plain induct_tac
wenzelm
parents:
11995
diff
changeset
|
6282 |
|
11474 | 6283 |
*** ZF *** |
6284 |
||
12622 | 6285 |
* Isar: proper integration of logic-specific tools and packages, |
6286 |
including theory commands '(co)inductive', '(co)datatype', |
|
6287 |
'rep_datatype', 'inductive_cases', as well as methods 'ind_cases', |
|
6288 |
'induct_tac', 'case_tac', and 'typecheck' (with attribute 'TC'); |
|
6289 |
||
6290 |
* theory Main no longer includes AC; for the Axiom of Choice, base |
|
6291 |
your theory on Main_ZFC; |
|
6292 |
||
6293 |
* the integer library now covers quotients and remainders, with many |
|
6294 |
laws relating division to addition, multiplication, etc.; |
|
12563 | 6295 |
|
12280 | 6296 |
* ZF/UNITY: Chandy and Misra's UNITY is now available in ZF, giving a |
6297 |
typeless version of the formalism; |
|
6298 |
||
13025 | 6299 |
* ZF/AC, Coind, IMP, Resid: updated and converted to new-style theory |
6300 |
format; |
|
12608
2df381faa787
* ZF/IMP: updated and converted to new-style theory format;
wenzelm
parents:
12597
diff
changeset
|
6301 |
|
12280 | 6302 |
* ZF/Induct: new directory for examples of inductive definitions, |
12608
2df381faa787
* ZF/IMP: updated and converted to new-style theory format;
wenzelm
parents:
12597
diff
changeset
|
6303 |
including theory Multiset for multiset orderings; converted to |
2df381faa787
* ZF/IMP: updated and converted to new-style theory format;
wenzelm
parents:
12597
diff
changeset
|
6304 |
new-style theory format; |
12177
b1c16d685a99
* ZF: new-style theory commands 'inductive', 'inductive_cases', and
wenzelm
parents:
12163
diff
changeset
|
6305 |
|
13025 | 6306 |
* ZF: many new theorems about lists, ordinals, etc.; |
12850 | 6307 |
|
11474 | 6308 |
|
6309 |
*** General *** |
|
6310 |
||
12280 | 6311 |
* Pure/kernel: meta-level proof terms (by Stefan Berghofer); reference |
6312 |
variable proof controls level of detail: 0 = no proofs (only oracle |
|
6313 |
dependencies), 1 = lemma dependencies, 2 = compact proof terms; see |
|
6314 |
also ref manual for further ML interfaces; |
|
6315 |
||
6316 |
* Pure/axclass: removed obsolete ML interface |
|
6317 |
goal_subclass/goal_arity; |
|
6318 |
||
6319 |
* Pure/syntax: new token syntax "num" for plain numerals (without "#" |
|
6320 |
of "xnum"); potential INCOMPATIBILITY, since -0, -1 etc. are now |
|
6321 |
separate tokens, so expressions involving minus need to be spaced |
|
6322 |
properly; |
|
6323 |
||
12312
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6324 |
* Pure/syntax: support non-oriented infixes, using keyword "infix" |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6325 |
rather than "infixl" or "infixr"; |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6326 |
|
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6327 |
* Pure/syntax: concrete syntax for dummy type variables admits genuine |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6328 |
sort constraint specifications in type inference; e.g. "x::_::foo" |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6329 |
ensures that the type of "x" is of sort "foo" (but not necessarily a |
f0f06950820d
* Isar/Pure: "sorry" no longer requires quick_and_dirty in interactive mode;
wenzelm
parents:
12280
diff
changeset
|
6330 |
type variable); |
12280 | 6331 |
|
6332 |
* Pure/syntax: print modes "type_brackets" and "no_type_brackets" |
|
6333 |
control output of nested => (types); the default behavior is |
|
6334 |
"type_brackets"; |
|
6335 |
||
6336 |
* Pure/syntax: builtin parse translation for "_constify" turns valued |
|
11817 | 6337 |
tokens into AST constants; |
11474 | 6338 |
|
12280 | 6339 |
* Pure/syntax: prefer later declarations of translations and print |
6340 |
translation functions; potential INCOMPATIBILITY: need to reverse |
|
6341 |
multiple declarations for same syntax element constant; |
|
6342 |
||
12832
c31b44286a8a
* Pure/show_hyps reset by default (in accordance to existing Isar practice);
wenzelm
parents:
12777
diff
changeset
|
6343 |
* Pure/show_hyps reset by default (in accordance to existing Isar |
c31b44286a8a
* Pure/show_hyps reset by default (in accordance to existing Isar practice);
wenzelm
parents:
12777
diff
changeset
|
6344 |
practice); |
c31b44286a8a
* Pure/show_hyps reset by default (in accordance to existing Isar practice);
wenzelm
parents:
12777
diff
changeset
|
6345 |
|
12280 | 6346 |
* Provers/classical: renamed addaltern to addafter, addSaltern to |
6347 |
addSafter; |
|
6348 |
||
6349 |
* Provers/clasimp: ``iff'' declarations now handle conditional rules |
|
6350 |
as well; |
|
12253 | 6351 |
|
12538 | 6352 |
* system: tested support for MacOS X; should be able to get Isabelle + |
6353 |
Proof General to work in a plain Terminal after installing Poly/ML |
|
6354 |
(e.g. from the Isabelle distribution area) and GNU bash alone |
|
6355 |
(e.g. from http://www.apple.com); full X11, XEmacs and X-Symbol |
|
6356 |
support requires further installations, e.g. from |
|
6357 |
http://fink.sourceforge.net/); |
|
6358 |
||
12280 | 6359 |
* system: support Poly/ML 4.1.1 (able to manage larger heaps); |
11551 | 6360 |
|
12753
3a62df7ae926
* system: reduced base memory usage by Poly/ML (approx. 20 MB instead
wenzelm
parents:
12736
diff
changeset
|
6361 |
* system: reduced base memory usage by Poly/ML (approx. 20 MB instead |
3a62df7ae926
* system: reduced base memory usage by Poly/ML (approx. 20 MB instead
wenzelm
parents:
12736
diff
changeset
|
6362 |
of 40 MB), cf. ML_OPTIONS; |
3a62df7ae926
* system: reduced base memory usage by Poly/ML (approx. 20 MB instead
wenzelm
parents:
12736
diff
changeset
|
6363 |
|
11633 | 6364 |
* system: Proof General keywords specification is now part of the |
6365 |
Isabelle distribution (see etc/isar-keywords.el); |
|
6366 |
||
12728 | 6367 |
* system: support for persistent Proof General sessions (refrain from |
6368 |
outdating all loaded theories on startup); user may create writable |
|
6369 |
logic images like this: ``isabelle -q HOL Test''; |
|
12597
14822e4436bf
HOL/IMP and HOLCF/IMP updated and converted (Gerwin Klein);
wenzelm
parents:
12587
diff
changeset
|
6370 |
|
11551 | 6371 |
* system: smart selection of Isabelle process versus Isabelle |
11572 | 6372 |
interface, accommodates case-insensitive file systems (e.g. HFS+); may |
6373 |
run both "isabelle" and "Isabelle" even if file names are badly |
|
6374 |
damaged (executable inspects the case of the first letter of its own |
|
6375 |
name); added separate "isabelle-process" and "isabelle-interface"; |
|
11551 | 6376 |
|
12472 | 6377 |
* system: refrain from any attempt at filtering input streams; no |
6378 |
longer support ``8bit'' encoding of old isabelle font, instead proper |
|
6379 |
iso-latin characters may now be used; the related isatools |
|
6380 |
"symbolinput" and "nonascii" have disappeared as well; |
|
6381 |
||
6382 |
* system: removed old "xterm" interface (the print modes "xterm" and |
|
6383 |
"xterm_color" are still available for direct use in a suitable |
|
6384 |
terminal); |
|
6385 |
||
11314 | 6386 |
|
11169
98c2f741e32b
made split_all_tac safe introducing safe_full_simp_tac, EXISTING PROOFS MAY FAIL
oheimb
parents:
11130
diff
changeset
|
6387 |
|
11062 | 6388 |
New in Isabelle99-2 (February 2001) |
6389 |
----------------------------------- |
|
6390 |
||
10224 | 6391 |
*** Overview of INCOMPATIBILITIES *** |
6392 |
||
11241 | 6393 |
* HOL: please note that theories in the Library and elsewhere often use the |
6394 |
new-style (Isar) format; to refer to their theorems in an ML script you must |
|
12622 | 6395 |
bind them to ML identifers by e.g. val thm_name = thm "thm_name"; |
11241 | 6396 |
|
11043
2e3bbac8763b
HOL: inductive package no longer splits induction rule aggressively,
wenzelm
parents:
11016
diff
changeset
|
6397 |
* HOL: inductive package no longer splits induction rule aggressively, |
2e3bbac8763b
HOL: inductive package no longer splits induction rule aggressively,
wenzelm
parents:
11016
diff
changeset
|
6398 |
but only as far as specified by the introductions given; the old |
11130 | 6399 |
format may be recovered via ML function complete_split_rule or attribute |
11043
2e3bbac8763b
HOL: inductive package no longer splits induction rule aggressively,
wenzelm
parents:
11016
diff
changeset
|
6400 |
'split_rule (complete)'; |
2e3bbac8763b
HOL: inductive package no longer splits induction rule aggressively,
wenzelm
parents:
11016
diff
changeset
|
6401 |
|
10998 | 6402 |
* HOL: induct renamed to lfp_induct, lfp_Tarski to lfp_unfold, |
6403 |
gfp_Tarski to gfp_unfold; |
|
10224 | 6404 |
|
10288 | 6405 |
* HOL: contrapos, contrapos2 renamed to contrapos_nn, contrapos_pp; |
6406 |
||
10858 | 6407 |
* HOL: infix "dvd" now has priority 50 rather than 70 (because it is a |
6408 |
relation); infix "^^" has been renamed "``"; infix "``" has been |
|
6409 |
renamed "`"; "univalent" has been renamed "single_valued"; |
|
10793 | 6410 |
|
10998 | 6411 |
* HOL/Real: "rinv" and "hrinv" replaced by overloaded "inverse" |
6412 |
operation; |
|
6413 |
||
10868 | 6414 |
* HOLCF: infix "`" has been renamed "$"; the symbol syntax is \<cdot>; |
10856 | 6415 |
|
10391 | 6416 |
* Isar: 'obtain' no longer declares "that" fact as simp/intro; |
6417 |
||
10401
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6418 |
* Isar/HOL: method 'induct' now handles non-atomic goals; as a |
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6419 |
consequence, it is no longer monotonic wrt. the local goal context |
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6420 |
(which is now passed through the inductive cases); |
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6421 |
|
10976
0e7cf6f9fa29
* Document preparation: renamed standard symbols \<ll> to \<lless> and
wenzelm
parents:
10966
diff
changeset
|
6422 |
* Document preparation: renamed standard symbols \<ll> to \<lless> and |
0e7cf6f9fa29
* Document preparation: renamed standard symbols \<ll> to \<lless> and
wenzelm
parents:
10966
diff
changeset
|
6423 |
\<gg> to \<ggreater>; |
0e7cf6f9fa29
* Document preparation: renamed standard symbols \<ll> to \<lless> and
wenzelm
parents:
10966
diff
changeset
|
6424 |
|
10224 | 6425 |
|
10245
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6426 |
*** Document preparation *** |
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6427 |
|
10858 | 6428 |
* \isabellestyle{NAME} selects version of Isabelle output (currently |
6429 |
available: are "it" for near math-mode best-style output, "sl" for |
|
6430 |
slanted text style, and "tt" for plain type-writer; if no |
|
6431 |
\isabellestyle command is given, output is according to slanted |
|
6432 |
type-writer); |
|
6433 |
||
10322
df38c61bf541
* support sub/super scripts (for single symbols only), input syntax is
wenzelm
parents:
10306
diff
changeset
|
6434 |
* support sub/super scripts (for single symbols only), input syntax is |
df38c61bf541
* support sub/super scripts (for single symbols only), input syntax is
wenzelm
parents:
10306
diff
changeset
|
6435 |
like this: "A\<^sup>*" or "A\<^sup>\<star>"; |
df38c61bf541
* support sub/super scripts (for single symbols only), input syntax is
wenzelm
parents:
10306
diff
changeset
|
6436 |
|
10858 | 6437 |
* some more standard symbols; see Appendix A of the system manual for |
11062 | 6438 |
the complete list of symbols defined in isabellesym.sty; |
10858 | 6439 |
|
10998 | 6440 |
* improved isabelle style files; more abstract symbol implementation |
6441 |
(should now use \isamath{...} and \isatext{...} in custom symbol |
|
6442 |
definitions); |
|
6443 |
||
10634 | 6444 |
* antiquotation @{goals} and @{subgoals} for output of *dynamic* goals |
6445 |
state; Note that presentation of goal states does not conform to |
|
6446 |
actual human-readable proof documents. Please do not include goal |
|
6447 |
states into document output unless you really know what you are doing! |
|
10322
df38c61bf541
* support sub/super scripts (for single symbols only), input syntax is
wenzelm
parents:
10306
diff
changeset
|
6448 |
|
11062 | 6449 |
* proper indentation of antiquoted output with proportional LaTeX |
6450 |
fonts; |
|
10862 | 6451 |
|
11050
ac5709ac50b9
* no_document ML operator temporarily disables LaTeX document
wenzelm
parents:
11043
diff
changeset
|
6452 |
* no_document ML operator temporarily disables LaTeX document |
ac5709ac50b9
* no_document ML operator temporarily disables LaTeX document
wenzelm
parents:
11043
diff
changeset
|
6453 |
generation; |
ac5709ac50b9
* no_document ML operator temporarily disables LaTeX document
wenzelm
parents:
11043
diff
changeset
|
6454 |
|
11062 | 6455 |
* isatool unsymbolize tunes sources for plain ASCII communication; |
6456 |
||
10322
df38c61bf541
* support sub/super scripts (for single symbols only), input syntax is
wenzelm
parents:
10306
diff
changeset
|
6457 |
|
10306
b0ab988a27a9
* HOL: default proof step now includes 'intro_classes';
wenzelm
parents:
10288
diff
changeset
|
6458 |
*** Isar *** |
b0ab988a27a9
* HOL: default proof step now includes 'intro_classes';
wenzelm
parents:
10288
diff
changeset
|
6459 |
|
10547 | 6460 |
* Pure: Isar now suffers initial goal statements to contain unbound |
6461 |
schematic variables (this does not conform to actual readable proof |
|
6462 |
documents, due to unpredictable outcome and non-compositional proof |
|
6463 |
checking); users who know what they are doing may use schematic goals |
|
6464 |
for Prolog-style synthesis of proven results; |
|
6465 |
||
10391 | 6466 |
* Pure: assumption method (an implicit finishing) now handles actual |
6467 |
rules as well; |
|
6468 |
||
6469 |
* Pure: improved 'obtain' --- moved to Pure, insert "that" into |
|
6470 |
initial goal, declare "that" only as Pure intro (only for single |
|
6471 |
steps); the "that" rule assumption may now be involved in implicit |
|
6472 |
finishing, thus ".." becomes a feasible for trivial obtains; |
|
6473 |
||
6474 |
* Pure: default proof step now includes 'intro_classes'; thus trivial |
|
6475 |
instance proofs may be performed by ".."; |
|
6476 |
||
6477 |
* Pure: ?thesis / ?this / "..." now work for pure meta-level |
|
6478 |
statements as well; |
|
10306
b0ab988a27a9
* HOL: default proof step now includes 'intro_classes';
wenzelm
parents:
10288
diff
changeset
|
6479 |
|
11097 | 6480 |
* Pure: more robust selection of calculational rules; |
6481 |
||
10858 | 6482 |
* Pure: the builtin notion of 'finished' goal now includes the ==-refl |
6483 |
rule (as well as the assumption rule); |
|
6484 |
||
6485 |
* Pure: 'thm_deps' command visualizes dependencies of theorems and |
|
6486 |
lemmas, using the graph browser tool; |
|
6487 |
||
10944 | 6488 |
* Pure: predict failure of "show" in interactive mode; |
6489 |
||
11016
8f8ba41a5e7a
* Pure: 'thms_containing' now takes actual terms as arguments;
wenzelm
parents:
10998
diff
changeset
|
6490 |
* Pure: 'thms_containing' now takes actual terms as arguments; |
8f8ba41a5e7a
* Pure: 'thms_containing' now takes actual terms as arguments;
wenzelm
parents:
10998
diff
changeset
|
6491 |
|
10401
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6492 |
* HOL: improved method 'induct' --- now handles non-atomic goals |
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6493 |
(potential INCOMPATIBILITY); tuned error handling; |
58bb50f69497
* Isar/HOL: method 'induct' now handles non-atomic goals; as a
wenzelm
parents:
10391
diff
changeset
|
6494 |
|
10557 | 6495 |
* HOL: cases and induct rules now provide explicit hints about the |
10547 | 6496 |
number of facts to be consumed (0 for "type" and 1 for "set" rules); |
6497 |
any remaining facts are inserted into the goal verbatim; |
|
6498 |
||
10858 | 6499 |
* HOL: local contexts (aka cases) may now contain term bindings as |
6500 |
well; the 'cases' and 'induct' methods new provide a ?case binding for |
|
6501 |
the result to be shown in each case; |
|
6502 |
||
10770 | 6503 |
* HOL: added 'recdef_tc' command; |
6504 |
||
11016
8f8ba41a5e7a
* Pure: 'thms_containing' now takes actual terms as arguments;
wenzelm
parents:
10998
diff
changeset
|
6505 |
* isatool convert assists in eliminating legacy ML scripts; |
8f8ba41a5e7a
* Pure: 'thms_containing' now takes actual terms as arguments;
wenzelm
parents:
10998
diff
changeset
|
6506 |
|
10306
b0ab988a27a9
* HOL: default proof step now includes 'intro_classes';
wenzelm
parents:
10288
diff
changeset
|
6507 |
|
10245
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6508 |
*** HOL *** |
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6509 |
|
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6510 |
* HOL/Library: a collection of generic theories to be used together |
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6511 |
with main HOL; the theory loader path already includes this directory |
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6512 |
by default; the following existing theories have been moved here: |
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6513 |
HOL/Induct/Multiset, HOL/Induct/Acc (as Accessible_Part), HOL/While |
10337 | 6514 |
(as While_Combinator), HOL/Lex/Prefix (as List_Prefix); |
10245
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6515 |
|
10966 | 6516 |
* HOL/Unix: "Some aspects of Unix file-system security", a typical |
6517 |
modelling and verification task performed in Isabelle/HOL + |
|
6518 |
Isabelle/Isar + Isabelle document preparation (by Markus Wenzel). |
|
6519 |
||
11094 | 6520 |
* HOL/Algebra: special summation operator SUM no longer exists, it has |
6521 |
been replaced by setsum; infix 'assoc' now has priority 50 (like |
|
6522 |
'dvd'); axiom 'one_not_zero' has been moved from axclass 'ring' to |
|
6523 |
'domain', this makes the theory consistent with mathematical |
|
6524 |
literature; |
|
6525 |
||
10514 | 6526 |
* HOL basics: added overloaded operations "inverse" and "divide" |
10726 | 6527 |
(infix "/"), syntax for generic "abs" operation, generic summation |
11094 | 6528 |
operator \<Sum>; |
10452
abeefb0a79ae
* added overloaded operations "inverse" and "divide" (infix "/");
wenzelm
parents:
10428
diff
changeset
|
6529 |
|
10391 | 6530 |
* HOL/typedef: simplified package, provide more useful rules (see also |
6531 |
HOL/subset.thy); |
|
6532 |
||
10915
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6533 |
* HOL/datatype: induction rule for arbitrarily branching datatypes is |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6534 |
now expressed as a proper nested rule (old-style tactic scripts may |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6535 |
require atomize_strip_tac to cope with non-atomic premises); |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6536 |
|
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6537 |
* HOL: renamed theory "Prod" to "Product_Type", renamed "split" rule |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6538 |
to "split_conv" (old name still available for compatibility); |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6539 |
|
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6540 |
* HOL: improved concrete syntax for strings (e.g. allows translation |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6541 |
rules with string literals); |
6b66a8a530ce
* HOL/datatype: induction rule for arbitrarily branching datatypes is
wenzelm
parents:
10868
diff
changeset
|
6542 |
|
12245 | 6543 |
* HOL-Real-Hyperreal: this extends HOL-Real with the hyperreals |
6544 |
and Fleuriot's mechanization of analysis, including the transcendental |
|
6545 |
functions for the reals; |
|
10756 | 6546 |
|
11094 | 6547 |
* HOL/Real, HOL/Hyperreal: improved arithmetic simplification; |
10391 | 6548 |
|
10858 | 6549 |
|
10474 | 6550 |
*** CTT *** |
6551 |
||
10547 | 6552 |
* CTT: x-symbol support for Pi, Sigma, -->, : (membership); note that |
6553 |
"lam" is displayed as TWO lambda-symbols |
|
10474 | 6554 |
|
10547 | 6555 |
* CTT: theory Main now available, containing everything (that is, Bool |
6556 |
and Arith); |
|
6557 |
||
10474 | 6558 |
|
10391 | 6559 |
*** General *** |
6560 |
||
10547 | 6561 |
* Pure: the Simplifier has been implemented properly as a derived rule |
6562 |
outside of the actual kernel (at last!); the overall performance |
|
6563 |
penalty in practical applications is about 50%, while reliability of |
|
6564 |
the Isabelle inference kernel has been greatly improved; |
|
6565 |
||
11112 | 6566 |
* print modes "brackets" and "no_brackets" control output of nested => |
6567 |
(types) and ==> (props); the default behaviour is "brackets"; |
|
6568 |
||
10391 | 6569 |
* Provers: fast_tac (and friends) now handle actual object-logic rules |
6570 |
as assumptions as well; |
|
6571 |
||
11124 | 6572 |
* system: support Poly/ML 4.0; |
6573 |
||
6574 |
* system: isatool install handles KDE version 1 or 2; |
|
6575 |
||
10391 | 6576 |
|
10245
87771e2f49fe
* HOL/Library: a collection of generic theories to be used together
wenzelm
parents:
10224
diff
changeset
|
6577 |
|
10103 | 6578 |
New in Isabelle99-1 (October 2000) |
6579 |
---------------------------------- |
|
8015 | 6580 |
|
10003 | 6581 |
*** Overview of INCOMPATIBILITIES *** |
8014 | 6582 |
|
8848 | 6583 |
* HOL: simplification of natural numbers is much changed; to partly |
6584 |
recover the old behaviour (e.g. to prevent n+n rewriting to #2*n) |
|
6585 |
issue the following ML commands: |
|
6586 |
||
6587 |
Delsimprocs Nat_Numeral_Simprocs.cancel_numerals; |
|
6588 |
Delsimprocs [Nat_Numeral_Simprocs.combine_numerals]; |
|
8788 | 6589 |
|
10129 | 6590 |
* HOL: simplification no longer dives into case-expressions; this is |
6591 |
controlled by "t.weak_case_cong" for each datatype t; |
|
10003 | 6592 |
|
6593 |
* HOL: nat_less_induct renamed to less_induct; |
|
6594 |
||
6595 |
* HOL: systematic renaming of the SOME (Eps) rules, may use isatool |
|
6596 |
fixsome to patch .thy and .ML sources automatically; |
|
8967 | 6597 |
|
10003 | 6598 |
select_equality -> some_equality |
6599 |
select_eq_Ex -> some_eq_ex |
|
6600 |
selectI2EX -> someI2_ex |
|
6601 |
selectI2 -> someI2 |
|
6602 |
selectI -> someI |
|
6603 |
select1_equality -> some1_equality |
|
6604 |
Eps_sym_eq -> some_sym_eq_trivial |
|
6605 |
Eps_eq -> some_eq_trivial |
|
6606 |
||
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
6607 |
* HOL: exhaust_tac on datatypes superceded by new generic case_tac; |
10003 | 6608 |
|
6609 |
* HOL: removed obsolete theorem binding expand_if (refer to split_if |
|
6610 |
instead); |
|
6611 |
||
6612 |
* HOL: the recursion equations generated by 'recdef' are now called |
|
6613 |
f.simps instead of f.rules; |
|
6614 |
||
6615 |
* HOL: qed_spec_mp now also handles bounded ALL as well; |
|
6616 |
||
6617 |
* HOL: 0 is now overloaded, so the type constraint ":: nat" may |
|
6618 |
sometimes be needed; |
|
6619 |
||
6620 |
* HOL: the constant for "f``x" is now "image" rather than "op ``"; |
|
8014 | 6621 |
|
10065 | 6622 |
* HOL: the constant for "f-``x" is now "vimage" rather than "op -``"; |
6623 |
||
9330
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6624 |
* HOL: the disjoint sum is now "<+>" instead of "Plus"; the cartesian |
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6625 |
product is now "<*>" instead of "Times"; the lexicographic product is |
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6626 |
now "<*lex*>" instead of "**"; |
8705 | 6627 |
|
10003 | 6628 |
* HOL: theory Sexp is now in HOL/Induct examples (it used to be part |
6629 |
of main HOL, but was unused); better use HOL's datatype package; |
|
9971 | 6630 |
|
10137
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6631 |
* HOL: removed "symbols" syntax for constant "override" of theory Map; |
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6632 |
the old syntax may be recovered as follows: |
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6633 |
|
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6634 |
syntax (symbols) |
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6635 |
override :: "('a ~=> 'b) => ('a ~=> 'b) => ('a ~=> 'b)" |
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6636 |
(infixl "\\<oplus>" 100) |
d1c2bef01e2f
removed "symbols" syntax for constant "override";
wenzelm
parents:
10129
diff
changeset
|
6637 |
|
8848 | 6638 |
* HOL/Real: "rabs" replaced by overloaded "abs" function; |
6639 |
||
8887
c0c583ce0b0b
* HOL/ML: even fewer consts are declared as global (see theories Ord,
wenzelm
parents:
8848
diff
changeset
|
6640 |
* HOL/ML: even fewer consts are declared as global (see theories Ord, |
c0c583ce0b0b
* HOL/ML: even fewer consts are declared as global (see theories Ord,
wenzelm
parents:
8848
diff
changeset
|
6641 |
Lfp, Gfp, WF); this only affects ML packages that refer to const names |
c0c583ce0b0b
* HOL/ML: even fewer consts are declared as global (see theories Ord,
wenzelm
parents:
8848
diff
changeset
|
6642 |
internally; |
c0c583ce0b0b
* HOL/ML: even fewer consts are declared as global (see theories Ord,
wenzelm
parents:
8848
diff
changeset
|
6643 |
|
10003 | 6644 |
* HOL and ZF: syntax for quotienting wrt an equivalence relation |
6645 |
changed from A/r to A//r; |
|
9908 | 6646 |
|
10003 | 6647 |
* ZF: new treatment of arithmetic (nat & int) may break some old |
6648 |
proofs; |
|
8921
7c04c98132c4
* Pure: changed syntax of local blocks from {{ }} to { };
wenzelm
parents:
8887
diff
changeset
|
6649 |
|
10003 | 6650 |
* Isar: renamed some attributes (RS -> THEN, simplify -> simplified, |
6651 |
rulify -> rule_format, elimify -> elim_format, ...); |
|
9542 | 6652 |
|
9941
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6653 |
* Isar/Provers: intro/elim/dest attributes changed; renamed |
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6654 |
intro/intro!/intro!! flags to intro!/intro/intro? (in most cases, one |
9937 | 6655 |
should have to change intro!! to intro? only); replaced "delrule" by |
6656 |
"rule del"; |
|
9437
93e91040c286
* Isar/Provers: intro/elim/dest attributes: changed
wenzelm
parents:
9402
diff
changeset
|
6657 |
|
9612 | 6658 |
* Isar/HOL: renamed "intrs" to "intros" in inductive definitions; |
6659 |
||
9437
93e91040c286
* Isar/Provers: intro/elim/dest attributes: changed
wenzelm
parents:
9402
diff
changeset
|
6660 |
* Provers: strengthened force_tac by using new first_best_tac; |
9402 | 6661 |
|
10003 | 6662 |
* LaTeX document preparation: several changes of isabelle.sty (see |
6663 |
lib/texinputs); |
|
8729
094dbd0fad0c
* improved name spaces: ambiguous output is qualified; support for
wenzelm
parents:
8705
diff
changeset
|
6664 |
|
8014 | 6665 |
|
8487 | 6666 |
*** Document preparation *** |
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6667 |
|
9198
0ab3c81e9425
* formal comments (text blocks etc.) in new-style theories may now
wenzelm
parents:
9185
diff
changeset
|
6668 |
* formal comments (text blocks etc.) in new-style theories may now |
9753 | 6669 |
contain antiquotations of thm/prop/term/typ/text to be presented |
6670 |
according to latex print mode; concrete syntax is like this: |
|
6671 |
@{term[show_types] "f(x) = a + x"}; |
|
9198
0ab3c81e9425
* formal comments (text blocks etc.) in new-style theories may now
wenzelm
parents:
9185
diff
changeset
|
6672 |
|
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6673 |
* isatool mkdir provides easy setup of Isabelle session directories, |
8518 | 6674 |
including proper document sources; |
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6675 |
|
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6676 |
* generated LaTeX sources are now deleted after successful run |
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6677 |
(isatool document -c); may retain a copy somewhere else via -D option |
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6678 |
of isatool usedir; |
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6679 |
|
8566 | 6680 |
* isatool usedir -D now lets isatool latex -o sty update the Isabelle |
10003 | 6681 |
style files, achieving self-contained LaTeX sources and simplifying |
6682 |
LaTeX debugging; |
|
8566 | 6683 |
|
8518 | 6684 |
* old-style theories now produce (crude) LaTeX output as well; |
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6685 |
|
9057
af1ca1acf292
* browser info session directories are now self-contained (may be put
wenzelm
parents:
9052
diff
changeset
|
6686 |
* browser info session directories are now self-contained (may be put |
9437
93e91040c286
* Isar/Provers: intro/elim/dest attributes: changed
wenzelm
parents:
9402
diff
changeset
|
6687 |
on WWW server seperately); improved graphs of nested sessions; removed |
93e91040c286
* Isar/Provers: intro/elim/dest attributes: changed
wenzelm
parents:
9402
diff
changeset
|
6688 |
graph for 'all sessions'; |
9057
af1ca1acf292
* browser info session directories are now self-contained (may be put
wenzelm
parents:
9052
diff
changeset
|
6689 |
|
10003 | 6690 |
* several improvements in isabelle style files; \isabellestyle{it} |
6691 |
produces fake math mode output; \isamarkupheader is now \section by |
|
6692 |
default; see lib/texinputs/isabelle.sty etc.; |
|
9489
aa757b35b129
* blast(_tac) now handles actual object-logic rules as assumptions;
wenzelm
parents:
9457
diff
changeset
|
6693 |
|
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6694 |
|
8184 | 6695 |
*** Isar *** |
6696 |
||
10003 | 6697 |
* Isar/Pure: local results and corresponding term bindings are now |
6698 |
subject to Hindley-Milner polymorphism (similar to ML); this |
|
6699 |
accommodates incremental type-inference very nicely; |
|
8283
0a319c5746eb
* Pure now provides its own version of intro/elim/dest attributes;
wenzelm
parents:
8271
diff
changeset
|
6700 |
|
10003 | 6701 |
* Isar/Pure: new derived language element 'obtain' supports |
6702 |
generalized existence reasoning; |
|
8621
8ba0f90f6f35
* Isar/Pure: local results and corresponding term bindings are now
wenzelm
parents:
8603
diff
changeset
|
6703 |
|
10003 | 6704 |
* Isar/Pure: new calculational elements 'moreover' and 'ultimately' |
6705 |
support accumulation of results, without applying any rules yet; |
|
6706 |
useful to collect intermediate results without explicit name |
|
6707 |
references, and for use with transitivity rules with more than 2 |
|
6708 |
premises; |
|
8184 | 6709 |
|
10003 | 6710 |
* Isar/Pure: scalable support for case-analysis type proofs: new |
6711 |
'case' language element refers to local contexts symbolically, as |
|
6712 |
produced by certain proof methods; internally, case names are attached |
|
6713 |
to theorems as "tags"; |
|
8440
d66f0f14b1ca
* HOL: exhaust_tac on datatypes superceded by new case_tac;
wenzelm
parents:
8425
diff
changeset
|
6714 |
|
10003 | 6715 |
* Isar/Pure: theory command 'hide' removes declarations from |
9330
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6716 |
class/type/const name spaces; |
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6717 |
|
10003 | 6718 |
* Isar/Pure: theory command 'defs' supports option "(overloaded)" to |
9330
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6719 |
indicate potential overloading; |
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6720 |
|
10003 | 6721 |
* Isar/Pure: changed syntax of local blocks from {{ }} to { }; |
8621
8ba0f90f6f35
* Isar/Pure: local results and corresponding term bindings are now
wenzelm
parents:
8603
diff
changeset
|
6722 |
|
10003 | 6723 |
* Isar/Pure: syntax of sorts made 'inner', i.e. have to write |
6724 |
"{a,b,c}" instead of {a,b,c}; |
|
9011
0cfc347f8d19
Isar/Pure: removed obsolete 'transfer' attribute (transfer of thms to
wenzelm
parents:
8994
diff
changeset
|
6725 |
|
10003 | 6726 |
* Isar/Pure now provides its own version of intro/elim/dest |
6727 |
attributes; useful for building new logics, but beware of confusion |
|
6728 |
with the version in Provers/classical; |
|
9612 | 6729 |
|
10003 | 6730 |
* Isar/Pure: the local context of (non-atomic) goals is provided via |
6731 |
case name 'antecedent'; |
|
8440
d66f0f14b1ca
* HOL: exhaust_tac on datatypes superceded by new case_tac;
wenzelm
parents:
8425
diff
changeset
|
6732 |
|
10003 | 6733 |
* Isar/Pure: removed obsolete 'transfer' attribute (transfer of thms |
6734 |
to the current context is now done automatically); |
|
9383
c21fa1c48de0
* HOL: removed obsolete expand_if = split_if; theorems if_splits =
wenzelm
parents:
9349
diff
changeset
|
6735 |
|
10003 | 6736 |
* Isar/Pure: theory command 'method_setup' provides a simple interface |
6737 |
for definining proof methods in ML; |
|
9612 | 6738 |
|
10003 | 6739 |
* Isar/Provers: intro/elim/dest attributes changed; renamed |
9941
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6740 |
intro/intro!/intro!! flags to intro!/intro/intro? (INCOMPATIBILITY, in |
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6741 |
most cases, one should have to change intro!! to intro? only); |
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6742 |
replaced "delrule" by "rule del"; |
8283
0a319c5746eb
* Pure now provides its own version of intro/elim/dest attributes;
wenzelm
parents:
8271
diff
changeset
|
6743 |
|
10003 | 6744 |
* Isar/Provers: new 'hypsubst' method, plain 'subst' method and |
36856
b343091e81d8
reverted parts of 7902dc7ea11d -- note that NEWS of published Isabelle releases are essentially read-only;
wenzelm
parents:
36849
diff
changeset
|
6745 |
'symmetric' attribute (the latter supercedes [RS sym]); |
10003 | 6746 |
|
6747 |
* Isar/Provers: splitter support (via 'split' attribute and 'simp' |
|
6748 |
method modifier); 'simp' method: 'only:' modifier removes loopers as |
|
6749 |
well (including splits); |
|
6750 |
||
6751 |
* Isar/Provers: Simplifier and Classical methods now support all kind |
|
6752 |
of modifiers used in the past, including 'cong', 'iff', etc. |
|
6753 |
||
6754 |
* Isar/Provers: added 'fastsimp' and 'clarsimp' methods (combination |
|
6755 |
of Simplifier and Classical reasoner); |
|
6756 |
||
6757 |
* Isar/HOL: new proof method 'cases' and improved version of 'induct' |
|
6758 |
now support named cases; major packages (inductive, datatype, primrec, |
|
6759 |
recdef) support case names and properly name parameters; |
|
9612 | 6760 |
|
10003 | 6761 |
* Isar/HOL: new transitivity rules for substitution in inequalities -- |
6762 |
monotonicity conditions are extracted to be proven at end of |
|
6763 |
calculations; |
|
6764 |
||
6765 |
* Isar/HOL: removed 'case_split' thm binding, should use 'cases' proof |
|
6766 |
method anyway; |
|
6767 |
||
6768 |
* Isar/HOL: removed old expand_if = split_if; theorems if_splits = |
|
6769 |
split_if split_if_asm; datatype package provides theorems foo.splits = |
|
6770 |
foo.split foo.split_asm for each datatype; |
|
6771 |
||
6772 |
* Isar/HOL: tuned inductive package, rename "intrs" to "intros" |
|
6773 |
(potential INCOMPATIBILITY), emulation of mk_cases feature for proof |
|
6774 |
scripts: new 'inductive_cases' command and 'ind_cases' method; (Note: |
|
6775 |
use "(cases (simplified))" method in proper proof texts); |
|
6776 |
||
6777 |
* Isar/HOL: added global 'arith_split' attribute for 'arith' method; |
|
6778 |
||
6779 |
* Isar: names of theorems etc. may be natural numbers as well; |
|
6780 |
||
6781 |
* Isar: 'pr' command: optional arguments for goals_limit and |
|
9724
2030c5d63741
* 'pr' command: optional argument for ProofContext.prems_limit;
wenzelm
parents:
9709
diff
changeset
|
6782 |
ProofContext.prems_limit; no longer prints theory contexts, but only |
2030c5d63741
* 'pr' command: optional argument for ProofContext.prems_limit;
wenzelm
parents:
9709
diff
changeset
|
6783 |
proof states; |
8487 | 6784 |
|
10003 | 6785 |
* Isar: diagnostic commands 'pr', 'thm', 'prop', 'term', 'typ' admit |
8518 | 6786 |
additional print modes to be specified; e.g. "pr(latex)" will print |
6787 |
proof state according to the Isabelle LaTeX style; |
|
8487 | 6788 |
|
10003 | 6789 |
* Isar: improved support for emulating tactic scripts, including proof |
9612 | 6790 |
methods 'rule_tac' etc., 'cut_tac', 'thin_tac', 'subgoal_tac', |
6791 |
'rename_tac', 'rotate_tac', 'tactic', and 'case_tac' / 'induct_tac' |
|
6792 |
(for HOL datatypes); |
|
8534 | 6793 |
|
10003 | 6794 |
* Isar: simplified (more robust) goal selection of proof methods: 1st |
6795 |
goal, all goals, or explicit goal specifier (tactic emulation); thus |
|
6796 |
'proof method scripts' have to be in depth-first order; |
|
8673
987ea1a559d0
Isar: simplified (more robust) goal selection of proof methods;
wenzelm
parents:
8655
diff
changeset
|
6797 |
|
10003 | 6798 |
* Isar: tuned 'let' syntax: replaced 'as' keyword by 'and'; |
8729
094dbd0fad0c
* improved name spaces: ambiguous output is qualified; support for
wenzelm
parents:
8705
diff
changeset
|
6799 |
|
10003 | 6800 |
* Isar: removed 'help' command, which hasn't been too helpful anyway; |
6801 |
should instead use individual commands for printing items |
|
6802 |
(print_commands, print_methods etc.); |
|
9224
0da360494917
* Isar: removed 'help' command, which hasn't been too helpful anyway;
wenzelm
parents:
9198
diff
changeset
|
6803 |
|
10003 | 6804 |
* Isar: added 'nothing' --- the empty list of theorems; |
9239 | 6805 |
|
8184 | 6806 |
|
8014 | 6807 |
*** HOL *** |
6808 |
||
10080 | 6809 |
* HOL/MicroJava: formalization of a fragment of Java, together with a |
6810 |
corresponding virtual machine and a specification of its bytecode |
|
6811 |
verifier and a lightweight bytecode verifier, including proofs of |
|
6812 |
type-safety; by Gerwin Klein, Tobias Nipkow, David von Oheimb, and |
|
6813 |
Cornelia Pusch (see also the homepage of project Bali at |
|
6814 |
http://isabelle.in.tum.de/Bali/); |
|
6815 |
||
8518 | 6816 |
* HOL/Algebra: new theory of rings and univariate polynomials, by |
6817 |
Clemens Ballarin; |
|
8014 | 6818 |
|
10157
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6819 |
* HOL/NumberTheory: fundamental Theorem of Arithmetic, Chinese |
10003 | 6820 |
Remainder Theorem, Fermat/Euler Theorem, Wilson's Theorem, by Thomas M |
6821 |
Rasmussen; |
|
8570 | 6822 |
|
10157
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6823 |
* HOL/Lattice: fundamental concepts of lattice theory and order |
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6824 |
structures, including duals, properties of bounds versus algebraic |
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6825 |
laws, lattice operations versus set-theoretic ones, the Knaster-Tarski |
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6826 |
Theorem for complete lattices etc.; may also serve as a demonstration |
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6827 |
for abstract algebraic reasoning using axiomatic type classes, and |
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6828 |
mathematics-style proof in Isabelle/Isar; by Markus Wenzel; |
6d3987f3aad9
* HOL/Lattice: fundamental concepts of lattice theory and order structures;
wenzelm
parents:
10137
diff
changeset
|
6829 |
|
10003 | 6830 |
* HOL/Prolog: a (bare-bones) implementation of Lambda-Prolog, by David |
6831 |
von Oheimb; |
|
9542 | 6832 |
|
10164
c240747082aa
* HOL/IMPP: extension of IMP with local variables and mutually
wenzelm
parents:
10157
diff
changeset
|
6833 |
* HOL/IMPP: extension of IMP with local variables and mutually |
c240747082aa
* HOL/IMPP: extension of IMP with local variables and mutually
wenzelm
parents:
10157
diff
changeset
|
6834 |
recursive procedures, by David von Oheimb; |
c240747082aa
* HOL/IMPP: extension of IMP with local variables and mutually
wenzelm
parents:
10157
diff
changeset
|
6835 |
|
10003 | 6836 |
* HOL/Lambda: converted into new-style theory and document; |
9542 | 6837 |
|
10003 | 6838 |
* HOL/ex/Multiquote: example of multiple nested quotations and |
6839 |
anti-quotations -- basically a generalized version of de-Bruijn |
|
6840 |
representation; very useful in avoiding lifting of operations; |
|
8848 | 6841 |
|
9612 | 6842 |
* HOL/record: added general record equality rule to simpset; fixed |
6843 |
select-update simplification procedure to handle extended records as |
|
6844 |
well; admit "r" as field name; |
|
9542 | 6845 |
|
8967 | 6846 |
* HOL: 0 is now overloaded over the new sort "zero", allowing its use with |
6847 |
other numeric types and also as the identity of groups, rings, etc.; |
|
6848 |
||
6849 |
* HOL: new axclass plus_ac0 for addition with the AC-laws and 0 as identity. |
|
6850 |
Types nat and int belong to this axclass; |
|
6851 |
||
10003 | 6852 |
* HOL: greatly improved simplification involving numerals of type nat, int, real: |
8788 | 6853 |
(i + #8 + j) = Suc k simplifies to #7 + (i + j) = k |
8832 | 6854 |
i*j + k + j*#3*i simplifies to #4*(i*j) + k |
6855 |
two terms #m*u and #n*u are replaced by #(m+n)*u |
|
6856 |
(where #m, #n and u can implicitly be 1; this is simproc combine_numerals) |
|
6857 |
and the term/formula #m*u+x ~~ #n*u+y simplifies simplifies to #(m-n)+x ~~ y |
|
6858 |
or x ~~ #(n-m)+y, where ~~ is one of = < <= or - (simproc cancel_numerals); |
|
8736 | 6859 |
|
10003 | 6860 |
* HOL: meson_tac is available (previously in ex/meson.ML); it is a |
6861 |
powerful prover for predicate logic but knows nothing of clasets; see |
|
6862 |
ex/mesontest.ML and ex/mesontest2.ML for example applications; |
|
9835 | 6863 |
|
8848 | 6864 |
* HOL: new version of "case_tac" subsumes both boolean case split and |
8440
d66f0f14b1ca
* HOL: exhaust_tac on datatypes superceded by new case_tac;
wenzelm
parents:
8425
diff
changeset
|
6865 |
"exhaust_tac" on datatypes; INCOMPATIBILITY: exhaust_tac no longer |
8518 | 6866 |
exists, may define val exhaust_tac = case_tac for ad-hoc portability; |
8440
d66f0f14b1ca
* HOL: exhaust_tac on datatypes superceded by new case_tac;
wenzelm
parents:
8425
diff
changeset
|
6867 |
|
8848 | 6868 |
* HOL: simplification no longer dives into case-expressions: only the |
10129 | 6869 |
selector expression is simplified, but not the remaining arms; to |
6870 |
enable full simplification of case-expressions for datatype t, you may |
|
6871 |
remove t.weak_case_cong from the simpset, either globally (Delcongs |
|
6872 |
[thm"t.weak_case_cong"];) or locally (delcongs [...]). |
|
8603 | 6873 |
|
8848 | 6874 |
* HOL/recdef: the recursion equations generated by 'recdef' for |
6875 |
function 'f' are now called f.simps instead of f.rules; if all |
|
6876 |
termination conditions are proved automatically, these simplification |
|
6877 |
rules are added to the simpset, as in primrec; rules may be named |
|
6878 |
individually as well, resulting in a separate list of theorems for |
|
6879 |
each equation; |
|
6880 |
||
9489
aa757b35b129
* blast(_tac) now handles actual object-logic rules as assumptions;
wenzelm
parents:
9457
diff
changeset
|
6881 |
* HOL/While is a new theory that provides a while-combinator. It |
aa757b35b129
* blast(_tac) now handles actual object-logic rules as assumptions;
wenzelm
parents:
9457
diff
changeset
|
6882 |
permits the definition of tail-recursive functions without the |
aa757b35b129
* blast(_tac) now handles actual object-logic rules as assumptions;
wenzelm
parents:
9457
diff
changeset
|
6883 |
provision of a termination measure. The latter is necessary once the |
aa757b35b129
* blast(_tac) now handles actual object-logic rules as assumptions;
wenzelm
parents:
9457
diff
changeset
|
6884 |
invariant proof rule for while is applied. |
9457 | 6885 |
|
10003 | 6886 |
* HOL: new (overloaded) notation for the set of elements below/above |
6887 |
some element: {..u}, {..u(}, {l..}, {)l..}. See theory SetInterval. |
|
8925 | 6888 |
|
8848 | 6889 |
* HOL: theorems impI, allI, ballI bound as "strip"; |
6890 |
||
10003 | 6891 |
* HOL: new tactic induct_thm_tac: thm -> string -> int -> tactic |
9746 | 6892 |
induct_tac th "x1 ... xn" expects th to have a conclusion of the form |
6893 |
P v1 ... vn and abbreviates res_inst_tac [("v1","x1"),...,("vn","xn")] th; |
|
6894 |
||
10003 | 6895 |
* HOL/Real: "rabs" replaced by overloaded "abs" function; |
9737 | 6896 |
|
10003 | 6897 |
* HOL: theory Sexp now in HOL/Induct examples (it used to be part of |
6898 |
main HOL, but was unused); |
|
8626 | 6899 |
|
10003 | 6900 |
* HOL: fewer consts declared as global (e.g. have to refer to |
6901 |
"Lfp.lfp" instead of "lfp" internally; affects ML packages only); |
|
8887
c0c583ce0b0b
* HOL/ML: even fewer consts are declared as global (see theories Ord,
wenzelm
parents:
8848
diff
changeset
|
6902 |
|
10003 | 6903 |
* HOL: tuned AST representation of nested pairs, avoiding bogus output |
6904 |
in case of overlap with user translations (e.g. judgements over |
|
6905 |
tuples); (note that the underlying logical represenation is still |
|
6906 |
bogus); |
|
9349
d43669fb423d
* tuned AST representation of nested pairs, avoiding bogus output in
wenzelm
parents:
9335
diff
changeset
|
6907 |
|
8412 | 6908 |
|
9542 | 6909 |
*** ZF *** |
6910 |
||
10003 | 6911 |
* ZF: simplification automatically cancels common terms in arithmetic |
6912 |
expressions over nat and int; |
|
9542 | 6913 |
|
10003 | 6914 |
* ZF: new treatment of nat to minimize type-checking: all operators |
6915 |
coerce their operands to a natural number using the function natify, |
|
6916 |
making the algebraic laws unconditional; |
|
9542 | 6917 |
|
10003 | 6918 |
* ZF: as above, for int: operators coerce their operands to an integer |
6919 |
using the function intify; |
|
9542 | 6920 |
|
10003 | 6921 |
* ZF: the integer library now contains many of the usual laws for the |
6922 |
orderings, including $<=, and monotonicity laws for $+ and $*; |
|
9542 | 6923 |
|
10003 | 6924 |
* ZF: new example ZF/ex/NatSum to demonstrate integer arithmetic |
6925 |
simplification; |
|
9388 | 6926 |
|
10003 | 6927 |
* FOL and ZF: AddIffs now available, giving theorems of the form P<->Q |
6928 |
to the simplifier and classical reasoner simultaneously; |
|
9388 | 6929 |
|
6930 |
||
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6931 |
*** General *** |
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6932 |
|
10003 | 6933 |
* Provers: blast_tac now handles actual object-logic rules as |
6934 |
assumptions; note that auto_tac uses blast_tac internally as well; |
|
6935 |
||
6936 |
* Provers: new functions rulify/rulify_no_asm: thm -> thm for turning |
|
6937 |
outer -->/All/Ball into ==>/!!; qed_spec_mp now uses rulify_no_asm; |
|
6938 |
||
9941
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6939 |
* Provers: delrules now handles destruct rules as well (no longer need |
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6940 |
explicit make_elim); |
fe05af7ec816
renamed atts: rulify to rule_format, elimify to elim_format;
wenzelm
parents:
9937
diff
changeset
|
6941 |
|
10003 | 6942 |
* Provers: Blast_tac now warns of and ignores "weak elimination rules" e.g. |
6943 |
[| inj ?f; ?f ?x = ?f ?y; ?x = ?y ==> ?W |] ==> ?W |
|
6944 |
use instead the strong form, |
|
6945 |
[| inj ?f; ~ ?W ==> ?f ?x = ?f ?y; ?x = ?y ==> ?W |] ==> ?W |
|
6946 |
in HOL, FOL and ZF the function cla_make_elim will create such rules |
|
6947 |
from destruct-rules; |
|
9489
aa757b35b129
* blast(_tac) now handles actual object-logic rules as assumptions;
wenzelm
parents:
9457
diff
changeset
|
6948 |
|
9709
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6949 |
* Provers: Simplifier.easy_setup provides a fast path to basic |
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6950 |
Simplifier setup for new object-logics; |
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6951 |
|
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6952 |
* Pure: AST translation rules no longer require constant head on LHS; |
9349
d43669fb423d
* tuned AST representation of nested pairs, avoiding bogus output in
wenzelm
parents:
9335
diff
changeset
|
6953 |
|
9709
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6954 |
* Pure: improved name spaces: ambiguous output is qualified; support |
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6955 |
for hiding of names; |
8729
094dbd0fad0c
* improved name spaces: ambiguous output is qualified; support for
wenzelm
parents:
8705
diff
changeset
|
6956 |
|
10003 | 6957 |
* system: smart setup of canonical ML_HOME, ISABELLE_INTERFACE, and |
6958 |
XSYMBOL_HOME; no longer need to do manual configuration in most |
|
6959 |
situations; |
|
6960 |
||
9709
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6961 |
* system: compression of ML heaps images may now be controlled via -c |
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6962 |
option of isabelle and isatool usedir (currently only observed by |
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6963 |
Poly/ML); |
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6964 |
|
9981
01a0c4772c18
system: isatool installfonts may handle X-Symbol fonts as well;
wenzelm
parents:
9971
diff
changeset
|
6965 |
* system: isatool installfonts may handle X-Symbol fonts as well (very |
01a0c4772c18
system: isatool installfonts may handle X-Symbol fonts as well;
wenzelm
parents:
9971
diff
changeset
|
6966 |
useful for remote X11); |
01a0c4772c18
system: isatool installfonts may handle X-Symbol fonts as well;
wenzelm
parents:
9971
diff
changeset
|
6967 |
|
9709
2d0ee9612ef1
* Isar/Provers: 'simp' method now supports 'cong' modifiers;
wenzelm
parents:
9701
diff
changeset
|
6968 |
* system: provide TAGS file for Isabelle sources; |
9052 | 6969 |
|
9288
06a55195741b
infix 'OF' is a version of 'MRS' with more appropriate argument order;
wenzelm
parents:
9239
diff
changeset
|
6970 |
* ML: infix 'OF' is a version of 'MRS' with more appropriate argument |
06a55195741b
infix 'OF' is a version of 'MRS' with more appropriate argument order;
wenzelm
parents:
9239
diff
changeset
|
6971 |
order; |
06a55195741b
infix 'OF' is a version of 'MRS' with more appropriate argument order;
wenzelm
parents:
9239
diff
changeset
|
6972 |
|
8994
803533fbb3ec
* ML: renamed flags Syntax.trace_norm_ast to Syntax.trace_ast; global
wenzelm
parents:
8991
diff
changeset
|
6973 |
* ML: renamed flags Syntax.trace_norm_ast to Syntax.trace_ast; global |
803533fbb3ec
* ML: renamed flags Syntax.trace_norm_ast to Syntax.trace_ast; global
wenzelm
parents:
8991
diff
changeset
|
6974 |
timing flag supersedes proof_timing and Toplevel.trace; |
803533fbb3ec
* ML: renamed flags Syntax.trace_norm_ast to Syntax.trace_ast; global
wenzelm
parents:
8991
diff
changeset
|
6975 |
|
10003 | 6976 |
* ML: new combinators |>> and |>>> for incremental transformations |
6977 |
with secondary results (e.g. certain theory extensions): |
|
6978 |
||
9330
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6979 |
* ML: PureThy.add_defs gets additional argument to indicate potential |
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6980 |
overloading (usually false); |
6861e3b00155
HOL: the disjoint sum is now "<+>" instead of "Plus";
wenzelm
parents:
9288
diff
changeset
|
6981 |
|
10003 | 6982 |
* ML: PureThy.add_thms/add_axioms/add_defs now return theorems as |
6983 |
results; |
|
8440
d66f0f14b1ca
* HOL: exhaust_tac on datatypes superceded by new case_tac;
wenzelm
parents:
8425
diff
changeset
|
6984 |
|
8358
a57d72b5d272
* isatool mkdir provides easy setup of Isabelle session directories,
wenzelm
parents:
8283
diff
changeset
|
6985 |
|
8015 | 6986 |
|
7986 | 6987 |
New in Isabelle99 (October 1999) |
6988 |
-------------------------------- |
|
4649 | 6989 |
|
5931 | 6990 |
*** Overview of INCOMPATIBILITIES (see below for more details) *** |
6991 |
||
6922 | 6992 |
* HOL: The THEN and ELSE parts of conditional expressions (if P then x else y) |
6993 |
are no longer simplified. (This allows the simplifier to unfold recursive |
|
6994 |
functional programs.) To restore the old behaviour, declare |
|
7215 | 6995 |
|
6996 |
Delcongs [if_weak_cong]; |
|
6922 | 6997 |
|
6269 | 6998 |
* HOL: Removed the obsolete syntax "Compl A"; use -A for set |
6999 |
complement; |
|
5931 | 7000 |
|
6269 | 7001 |
* HOL: the predicate "inj" is now defined by translation to "inj_on"; |
6174 | 7002 |
|
7847 | 7003 |
* HOL/datatype: mutual_induct_tac no longer exists -- |
7004 |
use induct_tac "x_1 ... x_n" instead of mutual_induct_tac ["x_1", ..., "x_n"] |
|
7005 |
||
6386
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7006 |
* HOL/typedef: fixed type inference for representing set; type |
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7007 |
arguments now have to occur explicitly on the rhs as type constraints; |
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7008 |
|
6269 | 7009 |
* ZF: The con_defs part of an inductive definition may no longer refer |
7010 |
to constants declared in the same theory; |
|
6057 | 7011 |
|
6269 | 7012 |
* HOL, ZF: the function mk_cases, generated by the inductive |
7013 |
definition package, has lost an argument. To simplify its result, it |
|
7014 |
uses the default simpset instead of a supplied list of theorems. |
|
6141 | 7015 |
|
7215 | 7016 |
* HOL/List: the constructors of type list are now Nil and Cons; |
7017 |
||
7619 | 7018 |
* Simplifier: the type of the infix ML functions |
8729
094dbd0fad0c
* improved name spaces: ambiguous output is qualified; support for
wenzelm
parents:
8705
diff
changeset
|
7019 |
setSSolver addSSolver setSolver addSolver |
7619 | 7020 |
is now simpset * solver -> simpset where `solver' is a new abstract type |
7021 |
for packaging solvers. A solver is created via |
|
8729
094dbd0fad0c
* improved name spaces: ambiguous output is qualified; support for
wenzelm
parents:
8705
diff
changeset
|
7022 |
mk_solver: string -> (thm list -> int -> tactic) -> solver |
7619 | 7023 |
where the string argument is only a comment. |
6057 | 7024 |
|
7647
2ceddd91cd0a
proper handling of dangling sort hypotheses (at last!);
wenzelm
parents:
7619
diff
changeset
|
7025 |
|
6069 | 7026 |
*** Proof tools *** |
7027 |
||
6343 | 7028 |
* Provers/Arith/fast_lin_arith.ML contains a functor for creating a |
7029 |
decision procedure for linear arithmetic. Currently it is used for |
|
7593 | 7030 |
types `nat', `int', and `real' in HOL (see below); it can, should and |
7031 |
will be instantiated for other types and logics as well. |
|
6069 | 7032 |
|
7324 | 7033 |
* The simplifier now accepts rewrite rules with flexible heads, eg |
7034 |
hom ?f ==> ?f(?x+?y) = ?f ?x + ?f ?y |
|
7035 |
They are applied like any rule with a non-pattern lhs, i.e. by first-order |
|
7036 |
matching. |
|
6069 | 7037 |
|
7593 | 7038 |
|
6014 | 7039 |
*** General *** |
7040 |
||
7986 | 7041 |
* New Isabelle/Isar subsystem provides an alternative to traditional |
7215 | 7042 |
tactical theorem proving; together with the ProofGeneral/isar user |
7043 |
interface it offers an interactive environment for developing human |
|
7044 |
readable proof documents (Isar == Intelligible semi-automated |
|
7886
8fa551e22e52
the settings environment is now statically scoped;
wenzelm
parents:
7863
diff
changeset
|
7045 |
reasoning); for further information see isatool doc isar-ref, |
7986 | 7046 |
src/HOL/Isar_examples and http://isabelle.in.tum.de/Isar/ |
7886
8fa551e22e52
the settings environment is now statically scoped;
wenzelm
parents:
7863
diff
changeset
|
7047 |
|
9612 | 7048 |
* improved and simplified presentation of theories: better HTML markup |
7049 |
(including colors), graph views in several sizes; isatool usedir now |
|
7050 |
provides a proper interface for user theories (via -P option); actual |
|
7051 |
document preparation based on (PDF)LaTeX is available as well (for |
|
7052 |
new-style theories only); see isatool doc system for more information; |
|
7215 | 7053 |
|
7252 | 7054 |
* native support for Proof General, both for classic Isabelle and |
7986 | 7055 |
Isabelle/Isar; |
7215 | 7056 |
|
7791 | 7057 |
* ML function thm_deps visualizes dependencies of theorems and lemmas, |
7058 |
using the graph browser tool; |
|
7059 |
||
6751 | 7060 |
* Isabelle manuals now also available as PDF; |
7061 |
||
6449 | 7062 |
* theory loader rewritten from scratch (may not be fully |
7063 |
bug-compatible); old loadpath variable has been replaced by show_path, |
|
6671 | 7064 |
add_path, del_path, reset_path functions; new operations such as |
7593 | 7065 |
update_thy, touch_thy, remove_thy, use/update_thy_only (see also |
7066 |
isatool doc ref); |
|
6449 | 7067 |
|
7215 | 7068 |
* improved isatool install: option -k creates KDE application icon, |
7069 |
option -p DIR installs standalone binaries; |
|
7070 |
||
7071 |
* added ML_PLATFORM setting (useful for cross-platform installations); |
|
7072 |
more robust handling of platform specific ML images for SML/NJ; |
|
7073 |
||
7886
8fa551e22e52
the settings environment is now statically scoped;
wenzelm
parents:
7863
diff
changeset
|
7074 |
* the settings environment is now statically scoped, i.e. it is never |
7986 | 7075 |
created again in sub-processes invoked from isabelle, isatool, or |
7886
8fa551e22e52
the settings environment is now statically scoped;
wenzelm
parents:
7863
diff
changeset
|
7076 |
Isabelle; |
8fa551e22e52
the settings environment is now statically scoped;
wenzelm
parents:
7863
diff
changeset
|
7077 |
|
7215 | 7078 |
* path element specification '~~' refers to '$ISABELLE_HOME'; |
7079 |
||
6343 | 7080 |
* in locales, the "assumes" and "defines" parts may be omitted if |
7081 |
empty; |
|
5973 | 7082 |
|
6269 | 7083 |
* new print_mode "xsymbols" for extended symbol support (e.g. genuine |
7084 |
long arrows); |
|
6259
488bdc1bd11a
path element specification '~~' refers to '$ISABELLE_HOME';
wenzelm
parents:
6174
diff
changeset
|
7085 |
|
6343 | 7086 |
* new print_mode "HTML"; |
7087 |
||
7088 |
* new flag show_tags controls display of tags of theorems (which are |
|
7089 |
basically just comments that may be attached by some tools); |
|
7090 |
||
6461 | 7091 |
* Isamode 2.6 requires patch to accomodate change of Isabelle font |
7092 |
mode and goal output format: |
|
7093 |
||
7094 |
diff -r Isamode-2.6/elisp/isa-load.el Isamode/elisp/isa-load.el |
|
7095 |
244c244 |
|
7096 |
< (list (isa-getenv "ISABELLE") "-msymbols" logic-name) |
|
7097 |
--- |
|
6533 | 7098 |
> (list (isa-getenv "ISABELLE") "-misabelle_font" "-msymbols" logic-name) |
6461 | 7099 |
diff -r Isabelle-2.6/elisp/isa-proofstate.el Isamode/elisp/isa-proofstate.el |
7100 |
181c181 |
|
7101 |
< (defconst proofstate-proofstart-regexp "^Level [0-9]+$" |
|
7102 |
--- |
|
7103 |
> (defconst proofstate-proofstart-regexp "^Level [0-9]+" |
|
7104 |
||
7450 | 7105 |
* function bind_thms stores lists of theorems (cf. bind_thm); |
7106 |
||
7593 | 7107 |
* new shorthand tactics ftac, eatac, datac, fatac; |
7108 |
||
7109 |
* qed (and friends) now accept "" as result name; in that case the |
|
7986 | 7110 |
theorem is not stored, but proper checks and presentation of the |
7111 |
result still apply; |
|
7593 | 7112 |
|
7805
0ae9ddc36fe0
theorem database now also indexes constants "Trueprop", "all",
wenzelm
parents:
7791
diff
changeset
|
7113 |
* theorem database now also indexes constants "Trueprop", "all", |
0ae9ddc36fe0
theorem database now also indexes constants "Trueprop", "all",
wenzelm
parents:
7791
diff
changeset
|
7114 |
"==>", "=="; thus thms_containing, findI etc. may retrieve more rules; |
0ae9ddc36fe0
theorem database now also indexes constants "Trueprop", "all",
wenzelm
parents:
7791
diff
changeset
|
7115 |
|
6028 | 7116 |
|
6057 | 7117 |
*** HOL *** |
7118 |
||
7215 | 7119 |
** HOL arithmetic ** |
7120 |
||
6343 | 7121 |
* There are now decision procedures for linear arithmetic over nat and |
7122 |
int: |
|
6131 | 7123 |
|
6343 | 7124 |
1. arith_tac copes with arbitrary formulae involving `=', `<', `<=', |
7125 |
`+', `-', `Suc', `min', `max' and numerical constants; other subterms |
|
7126 |
are treated as atomic; subformulae not involving type `nat' or `int' |
|
7127 |
are ignored; quantified subformulae are ignored unless they are |
|
7128 |
positive universal or negative existential. The tactic has to be |
|
7129 |
invoked by hand and can be a little bit slow. In particular, the |
|
7130 |
running time is exponential in the number of occurrences of `min' and |
|
7131 |
`max', and `-' on `nat'. |
|
6131 | 7132 |
|
6343 | 7133 |
2. fast_arith_tac is a cut-down version of arith_tac: it only takes |
7134 |
(negated) (in)equalities among the premises and the conclusion into |
|
7135 |
account (i.e. no compound formulae) and does not know about `min' and |
|
7136 |
`max', and `-' on `nat'. It is fast and is used automatically by the |
|
7137 |
simplifier. |
|
6131 | 7138 |
|
6343 | 7139 |
NB: At the moment, these decision procedures do not cope with mixed |
7140 |
nat/int formulae where the two parts interact, such as `m < n ==> |
|
7141 |
int(m) < int(n)'. |
|
6028 | 7142 |
|
7215 | 7143 |
* HOL/Numeral provides a generic theory of numerals (encoded |
7313 | 7144 |
efficiently as bit strings); setup for types nat/int/real is in place; |
7215 | 7145 |
INCOMPATIBILITY: since numeral syntax is now polymorphic, rather than |
7146 |
int, existing theories and proof scripts may require a few additional |
|
7147 |
type constraints; |
|
7148 |
||
7149 |
* integer division and remainder can now be performed on constant |
|
7150 |
arguments; |
|
7157 | 7151 |
|
7215 | 7152 |
* many properties of integer multiplication, division and remainder |
7153 |
are now available; |
|
6922 | 7154 |
|
7287 | 7155 |
* An interface to the Stanford Validity Checker (SVC) is available through the |
7156 |
tactic svc_tac. Propositional tautologies and theorems of linear arithmetic |
|
7157 |
are proved automatically. SVC must be installed separately, and its results |
|
7158 |
must be TAKEN ON TRUST (Isabelle does not check the proofs, but tags any |
|
7159 |
invocation of the underlying oracle). For SVC see |
|
7444 | 7160 |
http://verify.stanford.edu/SVC |
6922 | 7161 |
|
7125 | 7162 |
* IsaMakefile: the HOL-Real target now builds an actual image; |
7163 |
||
7215 | 7164 |
|
7165 |
** HOL misc ** |
|
7166 |
||
7595
5f5d575ddac3
* HOL/Real/HahnBanach: the Hahn-Banach theorem for real vector spaces
wenzelm
parents:
7593
diff
changeset
|
7167 |
* HOL/Real/HahnBanach: the Hahn-Banach theorem for real vector spaces |
5f5d575ddac3
* HOL/Real/HahnBanach: the Hahn-Banach theorem for real vector spaces
wenzelm
parents:
7593
diff
changeset
|
7168 |
(in Isabelle/Isar) -- by Gertrud Bauer; |
5f5d575ddac3
* HOL/Real/HahnBanach: the Hahn-Banach theorem for real vector spaces
wenzelm
parents:
7593
diff
changeset
|
7169 |
|
7691 | 7170 |
* HOL/BCV: generic model of bytecode verification, i.e. data-flow |
7171 |
analysis for assembly languages with subtypes; |
|
7172 |
||
6278 | 7173 |
* HOL/TLA (Lamport's Temporal Logic of Actions): major reorganization |
7174 |
-- avoids syntactic ambiguities and treats state, transition, and |
|
7175 |
temporal levels more uniformly; introduces INCOMPATIBILITIES due to |
|
7176 |
changed syntax and (many) tactics; |
|
7177 |
||
7791 | 7178 |
* HOL/inductive: Now also handles more general introduction rules such |
7179 |
as "ALL y. (y, x) : r --> y : acc r ==> x : acc r"; monotonicity |
|
7180 |
theorems are now maintained within the theory (maintained via the |
|
7181 |
"mono" attribute); |
|
7780
099742c562aa
Documented changes to HOL/inductive and function thm_deps.
berghofe
parents:
7691
diff
changeset
|
7182 |
|
7238
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7183 |
* HOL/datatype: Now also handles arbitrarily branching datatypes |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7184 |
(using function types) such as |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7185 |
|
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7186 |
datatype 'a tree = Atom 'a | Branch "nat => 'a tree" |
7047
d103b875ef1d
Datatype package now handles arbitrarily branching datatypes.
berghofe
parents:
6925
diff
changeset
|
7187 |
|
7326 | 7188 |
* HOL/record: record_simproc (part of the default simpset) takes care |
7189 |
of selectors applied to updated records; record_split_tac is no longer |
|
7327 | 7190 |
part of the default claset; update_defs may now be removed from the |
7191 |
simpset in many cases; COMPATIBILITY: old behavior achieved by |
|
7326 | 7192 |
|
7193 |
claset_ref () := claset() addSWrapper record_split_wrapper; |
|
7194 |
Delsimprocs [record_simproc] |
|
7195 |
||
6386
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7196 |
* HOL/typedef: fixed type inference for representing set; type |
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7197 |
arguments now have to occur explicitly on the rhs as type constraints; |
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7198 |
|
7287 | 7199 |
* HOL/recdef (TFL): 'congs' syntax now expects comma separated list of theorem |
7200 |
names rather than an ML expression; |
|
7201 |
||
7202 |
* HOL/defer_recdef (TFL): like recdef but the well-founded relation can be |
|
7203 |
supplied later. Program schemes can be defined, such as |
|
7204 |
"While B C s = (if B s then While B C (C s) else s)" |
|
7205 |
where the well-founded relation can be chosen after B and C have been given. |
|
6563 | 7206 |
|
7215 | 7207 |
* HOL/List: the constructors of type list are now Nil and Cons; |
7208 |
INCOMPATIBILITY: while [] and infix # syntax is still there, of |
|
7209 |
course, ML tools referring to List.list.op # etc. have to be adapted; |
|
7210 |
||
7238
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7211 |
* HOL_quantifiers flag superseded by "HOL" print mode, which is |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7212 |
disabled by default; run isabelle with option -m HOL to get back to |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7213 |
the original Gordon/HOL-style output; |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7214 |
|
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7215 |
* HOL/Ord.thy: new bounded quantifier syntax (input only): ALL x<y. P, |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7216 |
ALL x<=y. P, EX x<y. P, EX x<=y. P; |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7217 |
|
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7218 |
* HOL basic syntax simplified (more orthogonal): all variants of |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7219 |
All/Ex now support plain / symbolic / HOL notation; plain syntax for |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7220 |
Eps operator is provided as well: "SOME x. P[x]"; |
36e58620ffc8
replaced HOL_quantifiers flag by "HOL" print mode;
wenzelm
parents:
7216
diff
changeset
|
7221 |
|
7320 | 7222 |
* HOL/Sum.thy: sum_case has been moved to HOL/Datatype; |
7261 | 7223 |
|
7280 | 7224 |
* HOL/Univ.thy: infix syntax <*>, <+>, <**>, <+> eliminated and made |
7225 |
thus available for user theories; |
|
7226 |
||
7300
8439bf404c28
* HOLCF/IOA/Sequents: renamed 'Cons' to 'Consq' to avoid clash with HOL/List;
wenzelm
parents:
7287
diff
changeset
|
7227 |
* HOLCF/IOA/Sequents: renamed 'Cons' to 'Consq' to avoid clash with |
8439bf404c28
* HOLCF/IOA/Sequents: renamed 'Cons' to 'Consq' to avoid clash with HOL/List;
wenzelm
parents:
7287
diff
changeset
|
7228 |
HOL/List; hardly an INCOMPATIBILITY since '>>' syntax is used all the |
8439bf404c28
* HOLCF/IOA/Sequents: renamed 'Cons' to 'Consq' to avoid clash with HOL/List;
wenzelm
parents:
7287
diff
changeset
|
7229 |
time; |
8439bf404c28
* HOLCF/IOA/Sequents: renamed 'Cons' to 'Consq' to avoid clash with HOL/List;
wenzelm
parents:
7287
diff
changeset
|
7230 |
|
7986 | 7231 |
* HOL: new tactic smp_tac: int -> int -> tactic, which applies spec |
7232 |
several times and then mp; |
|
7492 | 7233 |
|
7215 | 7234 |
|
7113 | 7235 |
*** LK *** |
7236 |
||
7215 | 7237 |
* the notation <<...>> is now available as a notation for sequences of |
7238 |
formulas; |
|
7113 | 7239 |
|
7240 |
* the simplifier is now installed |
|
7241 |
||
8729
094dbd0fad0c
* improved name spaces: ambiguous output is qualified; support for
wenzelm
parents:
8705
diff
changeset
|
7242 |
* the axiom system has been generalized (thanks to Soren Heilmann) |
7113 | 7243 |
|
7244 |
* the classical reasoner now has a default rule database |
|
7245 |
||
7246 |
||
6064 | 7247 |
*** ZF *** |
7248 |
||
7249 |
* new primrec section allows primitive recursive functions to be given |
|
6269 | 7250 |
directly (as in HOL) over datatypes and the natural numbers; |
6064 | 7251 |
|
6269 | 7252 |
* new tactics induct_tac and exhaust_tac for induction (or case |
7253 |
analysis) over datatypes and the natural numbers; |
|
6064 | 7254 |
|
7255 |
* the datatype declaration of type T now defines the recursor T_rec; |
|
7256 |
||
6141 | 7257 |
* simplification automatically does freeness reasoning for datatype |
6269 | 7258 |
constructors; |
6141 | 7259 |
|
6269 | 7260 |
* automatic type-inference, with AddTCs command to insert new |
7261 |
type-checking rules; |
|
6155 | 7262 |
|
6269 | 7263 |
* datatype introduction rules are now added as Safe Introduction rules |
7264 |
to the claset; |
|
6155 | 7265 |
|
6269 | 7266 |
* the syntax "if P then x else y" is now available in addition to |
7267 |
if(P,x,y); |
|
7268 |
||
6069 | 7269 |
|
6343 | 7270 |
*** Internal programming interfaces *** |
7271 |
||
7919
35c18affc1d8
tuned simplifier trace output; new flag debug_simp
wenzelm
parents:
7886
diff
changeset
|
7272 |
* tuned simplifier trace output; new flag debug_simp; |
35c18affc1d8
tuned simplifier trace output; new flag debug_simp
wenzelm
parents:
7886
diff
changeset
|
7273 |
|
7420
cba45c114f3b
structures Vartab / Termtab (instances of TableFun);
wenzelm
parents:
7327
diff
changeset
|
7274 |
* structures Vartab / Termtab (instances of TableFun) offer efficient |
cba45c114f3b
structures Vartab / Termtab (instances of TableFun);
wenzelm
parents:
7327
diff
changeset
|
7275 |
tables indexed by indexname_ord / term_ord (compatible with aconv); |
cba45c114f3b
structures Vartab / Termtab (instances of TableFun);
wenzelm
parents:
7327
diff
changeset
|
7276 |
|
6386
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7277 |
* AxClass.axclass_tac lost the theory argument; |
e9e8af97f48f
HOL/typedef: fixed type inference for representing set;
wenzelm
parents:
6343
diff
changeset
|
7278 |
|
6343 | 7279 |
* tuned current_goals_markers semantics: begin / end goal avoids |
7280 |
printing empty lines; |
|
7281 |
||
7282 |
* removed prs and prs_fn hook, which was broken because it did not |
|
7283 |
include \n in its semantics, forcing writeln to add one |
|
7284 |
uncoditionally; replaced prs_fn by writeln_fn; consider std_output: |
|
7285 |
string -> unit if you really want to output text without newline; |
|
7286 |
||
7287 |
* Symbol.output subject to print mode; INCOMPATIBILITY: defaults to |
|
7288 |
plain output, interface builders may have to enable 'isabelle_font' |
|
7289 |
mode to get Isabelle font glyphs as before; |
|
7290 |
||
7291 |
* refined token_translation interface; INCOMPATIBILITY: output length |
|
7292 |
now of type real instead of int; |
|
7293 |
||
7196 | 7294 |
* theory loader actions may be traced via new ThyInfo.add_hook |
7295 |
interface (see src/Pure/Thy/thy_info.ML); example application: keep |
|
7296 |
your own database of information attached to *whole* theories -- as |
|
7297 |
opposed to intra-theory data slots offered via TheoryDataFun; |
|
7298 |
||
7647
2ceddd91cd0a
proper handling of dangling sort hypotheses (at last!);
wenzelm
parents:
7619
diff
changeset
|
7299 |
* proper handling of dangling sort hypotheses (at last!); |
2ceddd91cd0a
proper handling of dangling sort hypotheses (at last!);
wenzelm
parents:
7619
diff
changeset
|
7300 |
Thm.strip_shyps and Drule.strip_shyps_warning take care of removing |
2ceddd91cd0a
proper handling of dangling sort hypotheses (at last!);
wenzelm
parents:
7619
diff
changeset
|
7301 |
extra sort hypotheses that can be witnessed from the type signature; |
7986 | 7302 |
the force_strip_shyps flag is gone, any remaining shyps are simply |
7303 |
left in the theorem (with a warning issued by strip_shyps_warning); |
|
7647
2ceddd91cd0a
proper handling of dangling sort hypotheses (at last!);
wenzelm
parents:
7619
diff
changeset
|
7304 |
|
6343 | 7305 |
|
6064 | 7306 |
|
5781 | 7307 |
New in Isabelle98-1 (October 1998) |
7308 |
---------------------------------- |
|
7309 |
||
5127 | 7310 |
*** Overview of INCOMPATIBILITIES (see below for more details) *** |
4842 | 7311 |
|
5726 | 7312 |
* several changes of automated proof tools; |
5373 | 7313 |
|
5726 | 7314 |
* HOL: major changes to the inductive and datatype packages, including |
7315 |
some minor incompatibilities of theory syntax; |
|
5214 | 7316 |
|
5726 | 7317 |
* HOL: renamed r^-1 to 'converse' from 'inverse'; 'inj_onto' is now |
5217 | 7318 |
called `inj_on'; |
5160 | 7319 |
|
5275 | 7320 |
* HOL: removed duplicate thms in Arith: |
7321 |
less_imp_add_less should be replaced by trans_less_add1 |
|
7322 |
le_imp_add_le should be replaced by trans_le_add1 |
|
5160 | 7323 |
|
5726 | 7324 |
* HOL: unary minus is now overloaded (new type constraints may be |
7325 |
required); |
|
5490 | 7326 |
|
5726 | 7327 |
* HOL and ZF: unary minus for integers is now #- instead of #~. In |
7328 |
ZF, expressions such as n#-1 must be changed to n#- 1, since #-1 is |
|
7329 |
now taken as an integer constant. |
|
5541 | 7330 |
|
5726 | 7331 |
* Pure: ML function 'theory_of' renamed to 'theory'; |
5397
034ed25535b9
* Pure: ML function 'theory_of' replaced by 'theory';
wenzelm
parents:
5373
diff
changeset
|
7332 |
|
5363 | 7333 |
|
5127 | 7334 |
*** Proof tools *** |
4880 | 7335 |
|
5657
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7336 |
* Simplifier: |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7337 |
1. Asm_full_simp_tac is now more aggressive. |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7338 |
1. It will sometimes reorient premises if that increases their power to |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7339 |
simplify. |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7340 |
2. It does no longer proceed strictly from left to right but may also |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7341 |
rotate premises to achieve further simplification. |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7342 |
For compatibility reasons there is now Asm_lr_simp_tac which is like the |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7343 |
old Asm_full_simp_tac in that it does not rotate premises. |
1a6c9c6a3f8e
2. The simplifier now knows a little bit about nat-arithmetic.
nipkow
parents:
5651
diff
changeset
|
7344 |
2. The simplifier now knows a little bit about nat-arithmetic. |
4880 | 7345 |
|
5127 | 7346 |
* Classical reasoner: wrapper mechanism for the classical reasoner now |
7347 |
allows for selected deletion of wrappers, by introduction of names for |
|
7348 |
wrapper functionals. This implies that addbefore, addSbefore, |
|
7349 |
addaltern, and addSaltern now take a pair (name, tactic) as argument, |
|
7350 |
and that adding two tactics with the same name overwrites the first |
|
7351 |
one (emitting a warning). |
|
4824 | 7352 |
type wrapper = (int -> tactic) -> (int -> tactic) |
4649 | 7353 |
setWrapper, setSWrapper, compWrapper and compSWrapper are replaced by |
4824 | 7354 |
addWrapper, addSWrapper: claset * (string * wrapper) -> claset |
7355 |
delWrapper, delSWrapper: claset * string -> claset |
|
4649 | 7356 |
getWrapper is renamed to appWrappers, getSWrapper to appSWrappers; |
7357 |
||
5705
56f2030c46c6
tuned (all proofs are INSTABLE by David's definition of instability);
wenzelm
parents:
5671
diff
changeset
|
7358 |
* Classical reasoner: addbefore/addSbefore now have APPEND/ORELSE |
5726 | 7359 |
semantics; addbefore now affects only the unsafe part of step_tac |
7360 |
etc.; this affects addss/auto_tac/force_tac, so EXISTING PROOFS MAY |
|
7361 |
FAIL, but proofs should be fixable easily, e.g. by replacing Auto_tac |
|
7362 |
by Force_tac; |
|
5524 | 7363 |
|
5726 | 7364 |
* Classical reasoner: setwrapper to setWrapper and compwrapper to |
7365 |
compWrapper; added safe wrapper (and access functions for it); |
|
5524 | 7366 |
|
5127 | 7367 |
* HOL/split_all_tac is now much faster and fails if there is nothing |
5726 | 7368 |
to split. Some EXISTING PROOFS MAY REQUIRE ADAPTION because the order |
7369 |
and the names of the automatically generated variables have changed. |
|
7370 |
split_all_tac has moved within claset() from unsafe wrappers to safe |
|
7371 |
wrappers, which means that !!-bound variables are split much more |
|
7372 |
aggressively, and safe_tac and clarify_tac now split such variables. |
|
7373 |
If this splitting is not appropriate, use delSWrapper "split_all_tac". |
|
7374 |
Note: the same holds for record_split_tac, which does the job of |
|
7375 |
split_all_tac for record fields. |
|
5127 | 7376 |
|
5726 | 7377 |
* HOL/Simplifier: Rewrite rules for case distinctions can now be added |
7378 |
permanently to the default simpset using Addsplits just like |
|
7379 |
Addsimps. They can be removed via Delsplits just like |
|
7380 |
Delsimps. Lower-case versions are also available. |
|
5127 | 7381 |
|
5726 | 7382 |
* HOL/Simplifier: The rule split_if is now part of the default |
7383 |
simpset. This means that the simplifier will eliminate all occurrences |
|
7384 |
of if-then-else in the conclusion of a goal. To prevent this, you can |
|
7385 |
either remove split_if completely from the default simpset by |
|
7386 |
`Delsplits [split_if]' or remove it in a specific call of the |
|
7387 |
simplifier using `... delsplits [split_if]'. You can also add/delete |
|
7388 |
other case splitting rules to/from the default simpset: every datatype |
|
7389 |
generates suitable rules `split_t_case' and `split_t_case_asm' (where |
|
7390 |
t is the name of the datatype). |
|
5127 | 7391 |
|
5726 | 7392 |
* Classical reasoner / Simplifier combination: new force_tac (and |
5127 | 7393 |
derivatives Force_tac, force) combines rewriting and classical |
7394 |
reasoning (and whatever other tools) similarly to auto_tac, but is |
|
5726 | 7395 |
aimed to solve the given subgoal completely. |
5127 | 7396 |
|
7397 |
||
7398 |
*** General *** |
|
7399 |
||
5217 | 7400 |
* new top-level commands `Goal' and `Goalw' that improve upon `goal' |
5127 | 7401 |
and `goalw': the theory is no longer needed as an explicit argument - |
7402 |
the current theory context is used; assumptions are no longer returned |
|
7403 |
at the ML-level unless one of them starts with ==> or !!; it is |
|
5217 | 7404 |
recommended to convert to these new commands using isatool fixgoal |
7405 |
(backup your sources first!); |
|
4842 | 7406 |
|
5217 | 7407 |
* new top-level commands 'thm' and 'thms' for retrieving theorems from |
5207 | 7408 |
the current theory context, and 'theory' to lookup stored theories; |
4806 | 7409 |
|
5722 | 7410 |
* new theory section 'locale' for declaring constants, assumptions and |
7411 |
definitions that have local scope; |
|
7412 |
||
5127 | 7413 |
* new theory section 'nonterminals' for purely syntactic types; |
4858 | 7414 |
|
5127 | 7415 |
* new theory section 'setup' for generic ML setup functions |
7416 |
(e.g. package initialization); |
|
4869 | 7417 |
|
5131 | 7418 |
* the distribution now includes Isabelle icons: see |
7419 |
lib/logo/isabelle-{small,tiny}.xpm; |
|
7420 |
||
5363 | 7421 |
* isatool install - install binaries with absolute references to |
7422 |
ISABELLE_HOME/bin; |
|
7423 |
||
5572 | 7424 |
* isatool logo -- create instances of the Isabelle logo (as EPS); |
7425 |
||
5407 | 7426 |
* print mode 'emacs' reserved for Isamode; |
7427 |
||
5726 | 7428 |
* support multiple print (ast) translations per constant name; |
7429 |
||
6925
8d4d45ec6a3d
theorems involving oracles are now printed with a suffixed [!];
wenzelm
parents:
6922
diff
changeset
|
7430 |
* theorems involving oracles are now printed with a suffixed [!]; |
8d4d45ec6a3d
theorems involving oracles are now printed with a suffixed [!];
wenzelm
parents:
6922
diff
changeset
|
7431 |
|
4711 | 7432 |
|
4661 | 7433 |
*** HOL *** |
7434 |
||
5710 | 7435 |
* there is now a tutorial on Isabelle/HOL (do 'isatool doc tutorial'); |
5709 | 7436 |
|
5217 | 7437 |
* HOL/inductive package reorganized and improved: now supports mutual |
5267 | 7438 |
definitions such as |
5217 | 7439 |
|
7440 |
inductive EVEN ODD |
|
7441 |
intrs |
|
7442 |
null "0 : EVEN" |
|
7443 |
oddI "n : EVEN ==> Suc n : ODD" |
|
7444 |
evenI "n : ODD ==> Suc n : EVEN" |
|
7445 |
||
7446 |
new theorem list "elims" contains an elimination rule for each of the |
|
7447 |
recursive sets; inductive definitions now handle disjunctive premises |
|
7448 |
correctly (also ZF); |
|
5214 | 7449 |
|
5217 | 7450 |
INCOMPATIBILITIES: requires Inductive as an ancestor; component |
7451 |
"mutual_induct" no longer exists - the induction rule is always |
|
7452 |
contained in "induct"; |
|
7453 |
||
7454 |
||
7455 |
* HOL/datatype package re-implemented and greatly improved: now |
|
5267 | 7456 |
supports mutually recursive datatypes such as |
5217 | 7457 |
|
7458 |
datatype |
|
7459 |
'a aexp = IF_THEN_ELSE ('a bexp) ('a aexp) ('a aexp) |
|
7460 |
| SUM ('a aexp) ('a aexp) |
|
7461 |
| DIFF ('a aexp) ('a aexp) |
|
7462 |
| NUM 'a |
|
7463 |
and |
|
7464 |
'a bexp = LESS ('a aexp) ('a aexp) |
|
7465 |
| AND ('a bexp) ('a bexp) |
|
7466 |
| OR ('a bexp) ('a bexp) |
|
7467 |
||
5267 | 7468 |
as well as indirectly recursive datatypes such as |
5214 | 7469 |
|
5217 | 7470 |
datatype |
7471 |
('a, 'b) term = Var 'a |
|
7472 |
| App 'b ((('a, 'b) term) list) |
|
5214 | 7473 |
|
5217 | 7474 |
The new tactic mutual_induct_tac [<var_1>, ..., <var_n>] i performs |
7475 |
induction on mutually / indirectly recursive datatypes. |
|
7476 |
||
7477 |
Primrec equations are now stored in theory and can be accessed via |
|
7478 |
<function_name>.simps. |
|
7479 |
||
7480 |
INCOMPATIBILITIES: |
|
5214 | 7481 |
|
5217 | 7482 |
- Theories using datatypes must now have theory Datatype as an |
7483 |
ancestor. |
|
7484 |
- The specific <typename>.induct_tac no longer exists - use the |
|
7485 |
generic induct_tac instead. |
|
5226 | 7486 |
- natE has been renamed to nat.exhaust - use exhaust_tac |
5217 | 7487 |
instead of res_inst_tac ... natE. Note that the variable |
5226 | 7488 |
names in nat.exhaust differ from the names in natE, this |
5217 | 7489 |
may cause some "fragile" proofs to fail. |
7490 |
- The theorems split_<typename>_case and split_<typename>_case_asm |
|
7491 |
have been renamed to <typename>.split and <typename>.split_asm. |
|
7492 |
- Since default sorts of type variables are now handled correctly, |
|
7493 |
some datatype definitions may have to be annotated with explicit |
|
7494 |
sort constraints. |
|
7495 |
- Primrec definitions no longer require function name and type |
|
7496 |
of recursive argument. |
|
5214 | 7497 |
|
5217 | 7498 |
Consider using isatool fixdatatype to adapt your theories and proof |
7499 |
scripts to the new package (backup your sources first!). |
|
7500 |
||
7501 |
||
5726 | 7502 |
* HOL/record package: considerably improved implementation; now |
7503 |
includes concrete syntax for record types, terms, updates; theorems |
|
7504 |
for surjective pairing and splitting !!-bound record variables; proof |
|
7505 |
support is as follows: |
|
7506 |
||
7507 |
1) standard conversions (selectors or updates applied to record |
|
7508 |
constructor terms) are part of the standard simpset; |
|
7509 |
||
7510 |
2) inject equations of the form ((x, y) = (x', y')) == x=x' & y=y' are |
|
7511 |
made part of standard simpset and claset via addIffs; |
|
7512 |
||
7513 |
3) a tactic for record field splitting (record_split_tac) is part of |
|
7514 |
the standard claset (addSWrapper); |
|
7515 |
||
7516 |
To get a better idea about these rules you may retrieve them via |
|
7517 |
something like 'thms "foo.simps"' or 'thms "foo.iffs"', where "foo" is |
|
7518 |
the name of your record type. |
|
7519 |
||
7520 |
The split tactic 3) conceptually simplifies by the following rule: |
|
7521 |
||
7522 |
"(!!x. PROP ?P x) == (!!a b. PROP ?P (a, b))" |
|
7523 |
||
7524 |
Thus any record variable that is bound by meta-all will automatically |
|
7525 |
blow up into some record constructor term, consequently the |
|
7526 |
simplifications of 1), 2) apply. Thus force_tac, auto_tac etc. shall |
|
7527 |
solve record problems automatically. |
|
7528 |
||
5214 | 7529 |
|
5125 | 7530 |
* reorganized the main HOL image: HOL/Integ and String loaded by |
7531 |
default; theory Main includes everything; |
|
7532 |
||
5650 | 7533 |
* automatic simplification of integer sums and comparisons, using cancellation; |
7534 |
||
5526 | 7535 |
* added option_map_eq_Some and not_Some_eq to the default simpset and claset; |
5127 | 7536 |
|
7537 |
* added disj_not1 = "(~P | Q) = (P --> Q)" to the default simpset; |
|
7538 |
||
7539 |
* many new identities for unions, intersections, set difference, etc.; |
|
7540 |
||
7541 |
* expand_if, expand_split, expand_sum_case and expand_nat_case are now |
|
7542 |
called split_if, split_split, split_sum_case and split_nat_case (to go |
|
7543 |
with add/delsplits); |
|
5125 | 7544 |
|
5127 | 7545 |
* HOL/Prod introduces simplification procedure unit_eq_proc rewriting |
7546 |
(?x::unit) = (); this is made part of the default simpset, which COULD |
|
7547 |
MAKE EXISTING PROOFS FAIL under rare circumstances (consider |
|
5207 | 7548 |
'Delsimprocs [unit_eq_proc];' as last resort); also note that |
7549 |
unit_abs_eta_conv is added in order to counter the effect of |
|
7550 |
unit_eq_proc on (%u::unit. f u), replacing it by f rather than by |
|
7551 |
%u.f(); |
|
5125 | 7552 |
|
5217 | 7553 |
* HOL/Fun INCOMPATIBILITY: `inj_onto' is now called `inj_on' (which |
7554 |
makes more sense); |
|
5109 | 7555 |
|
5475 | 7556 |
* HOL/Set INCOMPATIBILITY: rule `equals0D' is now a well-formed destruct rule; |
7557 |
It and 'sym RS equals0D' are now in the default claset, giving automatic |
|
7558 |
disjointness reasoning but breaking a few old proofs. |
|
5267 | 7559 |
|
5217 | 7560 |
* HOL/Relation INCOMPATIBILITY: renamed the relational operator r^-1 |
7561 |
to 'converse' from 'inverse' (for compatibility with ZF and some |
|
7562 |
literature); |
|
5085
8e5a7942fdea
simplification procedure unit_eq_proc rewrites (?x::unit) = ();
wenzelm
parents:
5077
diff
changeset
|
7563 |
|
5127 | 7564 |
* HOL/recdef can now declare non-recursive functions, with {} supplied as |
7565 |
the well-founded relation; |
|
4838 | 7566 |
|
5490 | 7567 |
* HOL/Set INCOMPATIBILITY: the complement of set A is now written -A instead of |
7568 |
Compl A. The "Compl" syntax remains available as input syntax for this |
|
7569 |
release ONLY. |
|
7570 |
||
5127 | 7571 |
* HOL/Update: new theory of function updates: |
7572 |
f(a:=b) == %x. if x=a then b else f x |
|
7573 |
may also be iterated as in f(a:=b,c:=d,...); |
|
5077
71043526295f
* HOL/List: new function list_update written xs[i:=v] that updates the i-th
nipkow
parents:
5075
diff
changeset
|
7574 |
|
5127 | 7575 |
* HOL/Vimage: new theory for inverse image of a function, syntax f-``B; |
4899 | 7576 |
|
5282 | 7577 |
* HOL/List: |
7578 |
- new function list_update written xs[i:=v] that updates the i-th |
|
7579 |
list position. May also be iterated as in xs[i:=a,j:=b,...]. |
|
5428 | 7580 |
- new function `upt' written [i..j(] which generates the list |
7581 |
[i,i+1,...,j-1], i.e. the upper bound is excluded. To include the upper |
|
7582 |
bound write [i..j], which is a shorthand for [i..j+1(]. |
|
5282 | 7583 |
- new lexicographic orderings and corresponding wellfoundedness theorems. |
4779 | 7584 |
|
5127 | 7585 |
* HOL/Arith: |
7586 |
- removed 'pred' (predecessor) function; |
|
7587 |
- generalized some theorems about n-1; |
|
7588 |
- many new laws about "div" and "mod"; |
|
7589 |
- new laws about greatest common divisors (see theory ex/Primes); |
|
4766 | 7590 |
|
5127 | 7591 |
* HOL/Relation: renamed the relational operator r^-1 "converse" |
4842 | 7592 |
instead of "inverse"; |
4711 | 7593 |
|
5651 | 7594 |
* HOL/Induct/Multiset: a theory of multisets, including the wellfoundedness |
7595 |
of the multiset ordering; |
|
7596 |
||
5127 | 7597 |
* directory HOL/Real: a construction of the reals using Dedekind cuts |
5651 | 7598 |
(not included by default); |
4835 | 7599 |
|
5127 | 7600 |
* directory HOL/UNITY: Chandy and Misra's UNITY formalism; |
4711 | 7601 |
|
5651 | 7602 |
* directory HOL/Hoare: a new version of Hoare logic which permits many-sorted |
7603 |
programs, i.e. different program variables may have different types. |
|
7604 |
||
5142 | 7605 |
* calling (stac rew i) now fails if "rew" has no effect on the goal |
7606 |
[previously, this check worked only if the rewrite rule was unconditional] |
|
5308 | 7607 |
Now rew can involve either definitions or equalities (either == or =). |
5002
7b4c2a153738
* improved the theory data mechanism to support real encapsulation;
wenzelm
parents:
4981
diff
changeset
|
7608 |
|
5363 | 7609 |
|
4879
58656c6a3551
"let" is no longer restricted to FOL terms and allows any logical terms
paulson
parents:
4869
diff
changeset
|
7610 |
*** ZF *** |
58656c6a3551
"let" is no longer restricted to FOL terms and allows any logical terms
paulson
parents:
4869
diff
changeset
|
7611 |
|
5332 | 7612 |
* theory Main includes everything; INCOMPATIBILITY: theory ZF.thy contains |
7613 |
only the theorems proved on ZF.ML; |
|
5160 | 7614 |
|
5475 | 7615 |
* ZF INCOMPATIBILITY: rule `equals0D' is now a well-formed destruct rule; |
7616 |
It and 'sym RS equals0D' are now in the default claset, giving automatic |
|
7617 |
disjointness reasoning but breaking a few old proofs. |
|
5267 | 7618 |
|
5160 | 7619 |
* ZF/Update: new theory of function updates |
7620 |
with default rewrite rule f(x:=y) ` z = if(z=x, y, f`z) |
|
7621 |
may also be iterated as in f(a:=b,c:=d,...); |
|
7622 |
||
4879
58656c6a3551
"let" is no longer restricted to FOL terms and allows any logical terms
paulson
parents:
4869
diff
changeset
|
7623 |
* in let x=t in u(x), neither t nor u(x) has to be an FOL term. |
4649 | 7624 |
|
5142 | 7625 |
* calling (stac rew i) now fails if "rew" has no effect on the goal |
7626 |
[previously, this check worked only if the rewrite rule was unconditional] |
|
5308 | 7627 |
Now rew can involve either definitions or equalities (either == or =). |
5142 | 7628 |
|
5160 | 7629 |
* case_tac provided for compatibility with HOL |
7630 |
(like the old excluded_middle_tac, but with subgoals swapped) |
|
7631 |
||
4842 | 7632 |
|
5127 | 7633 |
*** Internal programming interfaces *** |
5002
7b4c2a153738
* improved the theory data mechanism to support real encapsulation;
wenzelm
parents:
4981
diff
changeset
|
7634 |
|
5251 | 7635 |
* Pure: several new basic modules made available for general use, see |
7636 |
also src/Pure/README; |
|
5207 | 7637 |
|
5008 | 7638 |
* improved the theory data mechanism to support encapsulation (data |
7639 |
kind name replaced by private Object.kind, acting as authorization |
|
5373 | 7640 |
key); new type-safe user interface via functor TheoryDataFun; generic |
7641 |
print_data function becomes basically useless; |
|
5002
7b4c2a153738
* improved the theory data mechanism to support real encapsulation;
wenzelm
parents:
4981
diff
changeset
|
7642 |
|
5251 | 7643 |
* removed global_names compatibility flag -- all theory declarations |
7644 |
are qualified by default; |
|
7645 |
||
5085
8e5a7942fdea
simplification procedure unit_eq_proc rewrites (?x::unit) = ();
wenzelm
parents:
5077
diff
changeset
|
7646 |
* module Pure/Syntax now offers quote / antiquote translation |
8e5a7942fdea
simplification procedure unit_eq_proc rewrites (?x::unit) = ();
wenzelm
parents:
5077
diff
changeset
|
7647 |
functions (useful for Hoare logic etc. with implicit dependencies); |
5373 | 7648 |
see HOL/ex/Antiquote for an example use; |
5085
8e5a7942fdea
simplification procedure unit_eq_proc rewrites (?x::unit) = ();
wenzelm
parents:
5077
diff
changeset
|
7649 |
|
5127 | 7650 |
* Simplifier now offers conversions (asm_)(full_)rewrite: simpset -> |
7651 |
cterm -> thm; |
|
7652 |
||
5207 | 7653 |
* new tactical CHANGED_GOAL for checking that a tactic modifies a |
7654 |
subgoal; |
|
5142 | 7655 |
|
5251 | 7656 |
* Display.print_goals function moved to Locale.print_goals; |
7657 |
||
5731 | 7658 |
* standard print function for goals supports current_goals_markers |
7659 |
variable for marking begin of proof, end of proof, start of goal; the |
|
7660 |
default is ("", "", ""); setting current_goals_markers := ("<proof>", |
|
7661 |
"</proof>", "<goal>") causes SGML like tagged proof state printing, |
|
7662 |
for example; |
|
7663 |
||
5002
7b4c2a153738
* improved the theory data mechanism to support real encapsulation;
wenzelm
parents:
4981
diff
changeset
|
7664 |
|
7b4c2a153738
* improved the theory data mechanism to support real encapsulation;
wenzelm
parents:
4981
diff
changeset
|
7665 |
|
4410 | 7666 |
New in Isabelle98 (January 1998) |
7667 |
-------------------------------- |
|
7668 |
||
7669 |
*** Overview of INCOMPATIBILITIES (see below for more details) *** |
|
7670 |
||
7671 |
* changed lexical syntax of terms / types: dots made part of long |
|
7672 |
identifiers, e.g. "%x.x" no longer possible, should be "%x. x"; |
|
7673 |
||
7674 |
* simpset (and claset) reference variable replaced by functions |
|
7675 |
simpset / simpset_ref; |
|
7676 |
||
7677 |
* no longer supports theory aliases (via merge) and non-trivial |
|
7678 |
implicit merge of thms' signatures; |
|
7679 |
||
7680 |
* most internal names of constants changed due to qualified names; |
|
7681 |
||
7682 |
* changed Pure/Sequence interface (see Pure/seq.ML); |
|
7683 |
||
3454 | 7684 |
|
3715 | 7685 |
*** General Changes *** |
7686 |
||
4174 | 7687 |
* hierachically structured name spaces (for consts, types, axms, thms |
3943 | 7688 |
etc.); new lexical class 'longid' (e.g. Foo.bar.x) may render much of |
4108 | 7689 |
old input syntactically incorrect (e.g. "%x.x"); COMPATIBILITY: |
7690 |
isatool fixdots ensures space after dots (e.g. "%x. x"); set |
|
4174 | 7691 |
long_names for fully qualified output names; NOTE: ML programs |
7692 |
(special tactics, packages etc.) referring to internal names may have |
|
7693 |
to be adapted to cope with fully qualified names; in case of severe |
|
7694 |
backward campatibility problems try setting 'global_names' at compile |
|
7695 |
time to have enrything declared within a flat name space; one may also |
|
7696 |
fine tune name declarations in theories via the 'global' and 'local' |
|
7697 |
section; |
|
4108 | 7698 |
|
7699 |
* reimplemented the implicit simpset and claset using the new anytype |
|
7700 |
data filed in signatures; references simpset:simpset ref etc. are |
|
7701 |
replaced by functions simpset:unit->simpset and |
|
7702 |
simpset_ref:unit->simpset ref; COMPATIBILITY: use isatool fixclasimp |
|
7703 |
to patch your ML files accordingly; |
|
3856 | 7704 |
|
3857 | 7705 |
* HTML output now includes theory graph data for display with Java |
7706 |
applet or isatool browser; data generated automatically via isatool |
|
3901 | 7707 |
usedir (see -i option, ISABELLE_USEDIR_OPTIONS); |
3857 | 7708 |
|
3856 | 7709 |
* defs may now be conditional; improved rewrite_goals_tac to handle |
7710 |
conditional equations; |
|
7711 |
||
4174 | 7712 |
* defs now admits additional type arguments, using TYPE('a) syntax; |
7713 |
||
3901 | 7714 |
* theory aliases via merge (e.g. M=A+B+C) no longer supported, always |
7715 |
creates a new theory node; implicit merge of thms' signatures is |
|
4112 | 7716 |
restricted to 'trivial' ones; COMPATIBILITY: one may have to use |
3901 | 7717 |
transfer:theory->thm->thm in (rare) cases; |
7718 |
||
3968
ec138de716d9
improved handling of draft signatures / theories; draft thms (and
wenzelm
parents:
3964
diff
changeset
|
7719 |
* improved handling of draft signatures / theories; draft thms (and |
ec138de716d9
improved handling of draft signatures / theories; draft thms (and
wenzelm
parents:
3964
diff
changeset
|
7720 |
ctyps, cterms) are automatically promoted to real ones; |
ec138de716d9
improved handling of draft signatures / theories; draft thms (and
wenzelm
parents:
3964
diff
changeset
|
7721 |
|
3901 | 7722 |
* slightly changed interfaces for oracles: admit many per theory, named |
7723 |
(e.g. oracle foo = mlfun), additional name argument for invoke_oracle; |
|
7724 |
||
7725 |
* print_goals: optional output of const types (set show_consts and |
|
7726 |
show_types); |
|
3851
fe9932a7cd46
print_goals: optional output of const types (set show_consts);
wenzelm
parents:
3846
diff
changeset
|
7727 |
|
4388 | 7728 |
* improved output of warnings (###) and errors (***); |
3697
c5833dfcc2cc
Pure: fixed idt/idts vs. pttrn/pttrns syntactic categories;
wenzelm
parents:
3671
diff
changeset
|
7729 |
|
4178
e64ff1c1bc70
subgoal_tac displays a warning if the new subgoal has type variables
paulson
parents:
4174
diff
changeset
|
7730 |
* subgoal_tac displays a warning if the new subgoal has type variables; |
e64ff1c1bc70
subgoal_tac displays a warning if the new subgoal has type variables
paulson
parents:
4174
diff
changeset
|
7731 |
|
3715 | 7732 |
* removed old README and Makefiles; |
3697
c5833dfcc2cc
Pure: fixed idt/idts vs. pttrn/pttrns syntactic categories;
wenzelm
parents:
3671
diff
changeset
|
7733 |
|
3856 | 7734 |
* replaced print_goals_ref hook by print_current_goals_fn and result_error_fn; |
3670
9fea3562f8c7
replaced print_goals_ref hook by print_current_goals_fn and
wenzelm
parents:
3658
diff
changeset
|
7735 |
|
3715 | 7736 |
* removed obsolete init_pps and init_database; |
7737 |
||
7738 |
* deleted the obsolete tactical STATE, which was declared by |
|
7739 |
fun STATE tacfun st = tacfun st st; |
|
7740 |
||
4388 | 7741 |
* cd and use now support path variables, e.g. $ISABELLE_HOME, or ~ |
7742 |
(which abbreviates $HOME); |
|
4269 | 7743 |
|
7744 |
* changed Pure/Sequence interface (see Pure/seq.ML); COMPATIBILITY: |
|
7745 |
use isatool fixseq to adapt your ML programs (this works for fully |
|
7746 |
qualified references to the Sequence structure only!); |
|
7747 |
||
4381 | 7748 |
* use_thy no longer requires writable current directory; it always |
7749 |
reloads .ML *and* .thy file, if either one is out of date; |
|
4269 | 7750 |
|
3715 | 7751 |
|
7752 |
*** Classical Reasoner *** |
|
7753 |
||
3744 | 7754 |
* Clarify_tac, clarify_tac, clarify_step_tac, Clarify_step_tac: new |
7755 |
tactics that use classical reasoning to simplify a subgoal without |
|
7756 |
splitting it into several subgoals; |
|
3715 | 7757 |
|
3719 | 7758 |
* Safe_tac: like safe_tac but uses the default claset; |
7759 |
||
3715 | 7760 |
|
7761 |
*** Simplifier *** |
|
7762 |
||
7763 |
* added simplification meta rules: |
|
7764 |
(asm_)(full_)simplify: simpset -> thm -> thm; |
|
7765 |
||
7766 |
* simplifier.ML no longer part of Pure -- has to be loaded by object |
|
7767 |
logics (again); |
|
7768 |
||
7769 |
* added prems argument to simplification procedures; |
|
7770 |
||
4325 | 7771 |
* HOL, FOL, ZF: added infix function `addsplits': |
7772 |
instead of `<simpset> setloop (split_tac <thms>)' |
|
7773 |
you can simply write `<simpset> addsplits <thms>' |
|
7774 |
||
3715 | 7775 |
|
7776 |
*** Syntax *** |
|
7777 |
||
4174 | 7778 |
* TYPE('a) syntax for type reflection terms; |
7779 |
||
3985 | 7780 |
* no longer handles consts with name "" -- declare as 'syntax' instead; |
3856 | 7781 |
|
7782 |
* pretty printer: changed order of mixfix annotation preference (again!); |
|
3846 | 7783 |
|
3715 | 7784 |
* Pure: fixed idt/idts vs. pttrn/pttrns syntactic categories; |
7785 |
||
7786 |
||
7787 |
*** HOL *** |
|
7788 |
||
5726 | 7789 |
* HOL: there is a new splitter `split_asm_tac' that can be used e.g. |
4189 | 7790 |
with `addloop' of the simplifier to faciliate case splitting in premises. |
7791 |
||
4035 | 7792 |
* HOL/TLA: Stephan Merz's formalization of Lamport's Temporal Logic of Actions; |
3985 | 7793 |
|
7794 |
* HOL/Auth: new protocol proofs including some for the Internet |
|
4035 | 7795 |
protocol TLS; |
3985 | 7796 |
|
4125 | 7797 |
* HOL/Map: new theory of `maps' a la VDM; |
3982 | 7798 |
|
4335 | 7799 |
* HOL/simplifier: simplification procedures nat_cancel_sums for |
7800 |
cancelling out common nat summands from =, <, <= (in)equalities, or |
|
7801 |
differences; simplification procedures nat_cancel_factor for |
|
7802 |
cancelling common factor from =, <, <= (in)equalities over natural |
|
4373 | 7803 |
sums; nat_cancel contains both kinds of procedures, it is installed by |
7804 |
default in Arith.thy -- this COULD MAKE EXISTING PROOFS FAIL; |
|
4335 | 7805 |
|
3580 | 7806 |
* HOL/simplifier: terms of the form |
4325 | 7807 |
`? x. P1(x) & ... & Pn(x) & x=t & Q1(x) & ... Qn(x)' (or t=x) |
3580 | 7808 |
are rewritten to |
4035 | 7809 |
`P1(t) & ... & Pn(t) & Q1(t) & ... Qn(t)', |
7810 |
and those of the form |
|
4325 | 7811 |
`! x. P1(x) & ... & Pn(x) & x=t & Q1(x) & ... Qn(x) --> R(x)' (or t=x) |
4035 | 7812 |
are rewritten to |
7813 |
`P1(t) & ... & Pn(t) & Q1(t) & ... Qn(t) --> R(t)', |
|
7814 |
||
7815 |
* HOL/datatype |
|
7816 |
Each datatype `t' now comes with a theorem `split_t_case' of the form |
|
3580 | 7817 |
|
4035 | 7818 |
P(t_case f1 ... fn x) = |
7819 |
( (!y1 ... ym1. x = C1 y1 ... ym1 --> P(f1 y1 ... ym1)) & |
|
7820 |
... |
|
4189 | 7821 |
(!y1 ... ymn. x = Cn y1 ... ymn --> P(f1 y1 ... ymn)) |
4035 | 7822 |
) |
7823 |
||
4930
89271bc4e7ed
extended addsplits and delsplits to handle also split rules for assumptions
oheimb
parents:
4915
diff
changeset
|
7824 |
and a theorem `split_t_case_asm' of the form |
4189 | 7825 |
|
7826 |
P(t_case f1 ... fn x) = |
|
7827 |
~( (? y1 ... ym1. x = C1 y1 ... ym1 & ~P(f1 y1 ... ym1)) | |
|
7828 |
... |
|
7829 |
(? y1 ... ymn. x = Cn y1 ... ymn & ~P(f1 y1 ... ymn)) |
|
7830 |
) |
|
4930
89271bc4e7ed
extended addsplits and delsplits to handle also split rules for assumptions
oheimb
parents:
4915
diff
changeset
|
7831 |
which can be added to a simpset via `addsplits'. The existing theorems |
89271bc4e7ed
extended addsplits and delsplits to handle also split rules for assumptions
oheimb
parents:
4915
diff
changeset
|
7832 |
expand_list_case and expand_option_case have been renamed to |
89271bc4e7ed
extended addsplits and delsplits to handle also split rules for assumptions
oheimb
parents:
4915
diff
changeset
|
7833 |
split_list_case and split_option_case. |
4189 | 7834 |
|
4361 | 7835 |
* HOL/Arithmetic: |
7836 |
- `pred n' is automatically converted to `n-1'. |
|
7837 |
Users are strongly encouraged not to use `pred' any longer, |
|
7838 |
because it will disappear altogether at some point. |
|
7839 |
- Users are strongly encouraged to write "0 < n" rather than |
|
7840 |
"n ~= 0". Theorems and proof tools have been modified towards this |
|
7841 |
`standard'. |
|
4357 | 7842 |
|
4502 | 7843 |
* HOL/Lists: |
7844 |
the function "set_of_list" has been renamed "set" (and its theorems too); |
|
7845 |
the function "nth" now takes its arguments in the reverse order and |
|
7846 |
has acquired the infix notation "!" as in "xs!n". |
|
3570 | 7847 |
|
4154 | 7848 |
* HOL/Set: UNIV is now a constant and is no longer translated to Compl{}; |
7849 |
||
7850 |
* HOL/Set: The operator (UN x.B x) now abbreviates (UN x:UNIV. B x) and its |
|
7851 |
specialist theorems (like UN1_I) are gone. Similarly for (INT x.B x); |
|
7852 |
||
4575 | 7853 |
* HOL/record: extensible records with schematic structural subtyping |
7854 |
(single inheritance); EXPERIMENTAL version demonstrating the encoding, |
|
7855 |
still lacks various theorems and concrete record syntax; |
|
7856 |
||
4125 | 7857 |
|
3715 | 7858 |
*** HOLCF *** |
3535 | 7859 |
|
4125 | 7860 |
* removed "axioms" and "generated by" sections; |
7861 |
||
4123 | 7862 |
* replaced "ops" section by extended "consts" section, which is capable of |
4125 | 7863 |
handling the continuous function space "->" directly; |
7864 |
||
7865 |
* domain package: |
|
7866 |
. proves theorems immediately and stores them in the theory, |
|
7867 |
. creates hierachical name space, |
|
7868 |
. now uses normal mixfix annotations (instead of cinfix...), |
|
7869 |
. minor changes to some names and values (for consistency), |
|
7870 |
. e.g. cases -> casedist, dists_eq -> dist_eqs, [take_lemma] -> take_lemmas, |
|
7871 |
. separator between mutual domain defs: changed "," to "and", |
|
7872 |
. improved handling of sort constraints; now they have to |
|
7873 |
appear on the left-hand side of the equations only; |
|
4123 | 7874 |
|
7875 |
* fixed LAM <x,y,zs>.b syntax; |
|
3567 | 7876 |
|
3744 | 7877 |
* added extended adm_tac to simplifier in HOLCF -- can now discharge |
7878 |
adm (%x. P (t x)), where P is chainfinite and t continuous; |
|
3579 | 7879 |
|
7880 |
||
3719 | 7881 |
*** FOL and ZF *** |
7882 |
||
5726 | 7883 |
* FOL: there is a new splitter `split_asm_tac' that can be used e.g. |
4189 | 7884 |
with `addloop' of the simplifier to faciliate case splitting in premises. |
7885 |
||
3744 | 7886 |
* qed_spec_mp, qed_goal_spec_mp, qed_goalw_spec_mp are available, as |
7887 |
in HOL, they strip ALL and --> from proved theorems; |
|
7888 |
||
3719 | 7889 |
|
3579 | 7890 |
|
3006 | 7891 |
New in Isabelle94-8 (May 1997) |
7892 |
------------------------------ |
|
2654 | 7893 |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7894 |
*** General Changes *** |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7895 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7896 |
* new utilities to build / run / maintain Isabelle etc. (in parts |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7897 |
still somewhat experimental); old Makefiles etc. still functional; |
2971 | 7898 |
|
3205 | 7899 |
* new 'Isabelle System Manual'; |
7900 |
||
2825 | 7901 |
* INSTALL text, together with ./configure and ./build scripts; |
2773 | 7902 |
|
3006 | 7903 |
* reimplemented type inference for greater efficiency, better error |
7904 |
messages and clean internal interface; |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7905 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7906 |
* prlim command for dealing with lots of subgoals (an easier way of |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7907 |
setting goals_limit); |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7908 |
|
3006 | 7909 |
|
7910 |
*** Syntax *** |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7911 |
|
3116 | 7912 |
* supports alternative (named) syntax tables (parser and pretty |
7913 |
printer); internal interface is provided by add_modesyntax(_i); |
|
7914 |
||
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7915 |
* Pure, FOL, ZF, HOL, HOLCF now support symbolic input and output; to |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7916 |
be used in conjunction with the Isabelle symbol font; uses the |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7917 |
"symbols" syntax table; |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7918 |
|
2705 | 7919 |
* added token_translation interface (may translate name tokens in |
2756 | 7920 |
arbitrary ways, dependent on their type (free, bound, tfree, ...) and |
3116 | 7921 |
the current print_mode); IMPORTANT: user print translation functions |
7922 |
are responsible for marking newly introduced bounds |
|
7923 |
(Syntax.mark_boundT); |
|
2705 | 7924 |
|
2730 | 7925 |
* token translations for modes "xterm" and "xterm_color" that display |
3006 | 7926 |
names in bold, underline etc. or colors (which requires a color |
7927 |
version of xterm); |
|
2730 | 7928 |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7929 |
* infixes may now be declared with names independent of their syntax; |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7930 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7931 |
* added typed_print_translation (like print_translation, but may |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7932 |
access type of constant); |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7933 |
|
3006 | 7934 |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7935 |
*** Classical Reasoner *** |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7936 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7937 |
Blast_tac: a new tactic! It is often more powerful than fast_tac, but has |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7938 |
some limitations. Blast_tac... |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7939 |
+ ignores addss, addbefore, addafter; this restriction is intrinsic |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7940 |
+ ignores elimination rules that don't have the correct format |
5726 | 7941 |
(the conclusion MUST be a formula variable) |
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7942 |
+ ignores types, which can make HOL proofs fail |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7943 |
+ rules must not require higher-order unification, e.g. apply_type in ZF |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7944 |
[message "Function Var's argument not a bound variable" relates to this] |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7945 |
+ its proof strategy is more general but can actually be slower |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7946 |
|
3107 | 7947 |
* substitution with equality assumptions no longer permutes other |
7948 |
assumptions; |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7949 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7950 |
* minor changes in semantics of addafter (now called addaltern); renamed |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7951 |
setwrapper to setWrapper and compwrapper to compWrapper; added safe wrapper |
3107 | 7952 |
(and access functions for it); |
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7953 |
|
5726 | 7954 |
* improved combination of classical reasoner and simplifier: |
3317 | 7955 |
+ functions for handling clasimpsets |
7956 |
+ improvement of addss: now the simplifier is called _after_ the |
|
7957 |
safe steps. |
|
7958 |
+ safe variant of addss called addSss: uses safe simplifications |
|
5726 | 7959 |
_during_ the safe steps. It is more complete as it allows multiple |
3317 | 7960 |
instantiations of unknowns (e.g. with slow_tac). |
3006 | 7961 |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7962 |
*** Simplifier *** |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7963 |
|
3006 | 7964 |
* added interface for simplification procedures (functions that |
7965 |
produce *proven* rewrite rules on the fly, depending on current |
|
7966 |
redex); |
|
7967 |
||
7968 |
* ordering on terms as parameter (used for ordered rewriting); |
|
7969 |
||
3107 | 7970 |
* new functions delcongs, deleqcongs, and Delcongs. richer rep_ss; |
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7971 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7972 |
* the solver is now split into a safe and an unsafe part. |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7973 |
This should be invisible for the normal user, except that the |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7974 |
functions setsolver and addsolver have been renamed to setSolver and |
3107 | 7975 |
addSolver; added safe_asm_full_simp_tac; |
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7976 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7977 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7978 |
*** HOL *** |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7979 |
|
3042 | 7980 |
* a generic induction tactic `induct_tac' which works for all datatypes and |
3107 | 7981 |
also for type `nat'; |
3042 | 7982 |
|
3316 | 7983 |
* a generic case distinction tactic `exhaust_tac' which works for all |
7984 |
datatypes and also for type `nat'; |
|
7985 |
||
7986 |
* each datatype comes with a function `size'; |
|
7987 |
||
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7988 |
* patterns in case expressions allow tuple patterns as arguments to |
3107 | 7989 |
constructors, for example `case x of [] => ... | (x,y,z)#ps => ...'; |
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7990 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7991 |
* primrec now also works with type nat; |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7992 |
|
3338 | 7993 |
* recdef: a new declaration form, allows general recursive functions to be |
7994 |
defined in theory files. See HOL/ex/Fib, HOL/ex/Primes, HOL/Subst/Unify. |
|
7995 |
||
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7996 |
* the constant for negation has been renamed from "not" to "Not" to |
3107 | 7997 |
harmonize with FOL, ZF, LK, etc.; |
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
7998 |
|
3107 | 7999 |
* HOL/ex/LFilter theory of a corecursive "filter" functional for |
8000 |
infinite lists; |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8001 |
|
3227 | 8002 |
* HOL/Modelcheck demonstrates invocation of model checker oracle; |
8003 |
||
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8004 |
* HOL/ex/Ring.thy declares cring_simp, which solves equational |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8005 |
problems in commutative rings, using axiomatic type classes for + and *; |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8006 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8007 |
* more examples in HOL/MiniML and HOL/Auth; |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8008 |
|
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8009 |
* more default rewrite rules for quantifiers, union/intersection; |
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8010 |
|
3321 | 8011 |
* a new constant `arbitrary == @x.False'; |
8012 |
||
3107 | 8013 |
* HOLCF/IOA replaces old HOL/IOA; |
8014 |
||
5726 | 8015 |
* HOLCF changes: derived all rules and arities |
8016 |
+ axiomatic type classes instead of classes |
|
2653
f1a6997cdc06
described changes for HOLCF-Version without rules and arities
slotosch
parents:
2649
diff
changeset
|
8017 |
+ typedef instead of faking type definitions |
2747 | 8018 |
+ eliminated the internal constants less_fun, less_cfun, UU_fun, UU_cfun etc. |
2730 | 8019 |
+ new axclasses cpo, chfin, flat with flat < chfin < pcpo < cpo < po |
2653
f1a6997cdc06
described changes for HOLCF-Version without rules and arities
slotosch
parents:
2649
diff
changeset
|
8020 |
+ eliminated the types void, one, tr |
f1a6997cdc06
described changes for HOLCF-Version without rules and arities
slotosch
parents:
2649
diff
changeset
|
8021 |
+ use unit lift and bool lift (with translations) instead of one and tr |
f1a6997cdc06
described changes for HOLCF-Version without rules and arities
slotosch
parents:
2649
diff
changeset
|
8022 |
+ eliminated blift from Lift3.thy (use Def instead of blift) |
3107 | 8023 |
all eliminated rules are derived as theorems --> no visible changes ; |
2649 | 8024 |
|
3006 | 8025 |
|
3002
223e5d65faaa
Reorganized under headings. Also documented Blast_tac and LFilter
paulson
parents:
2993
diff
changeset
|
8026 |
*** ZF *** |
2553 | 8027 |
|
2865 | 8028 |
* ZF now has Fast_tac, Simp_tac and Auto_tac. Union_iff is a now a default |
8029 |
rewrite rule; this may affect some proofs. eq_cs is gone but can be put back |
|
8030 |
as ZF_cs addSIs [equalityI]; |
|
2553 | 8031 |
|
2554 | 8032 |
|
2732 | 8033 |
|
2553 | 8034 |
New in Isabelle94-7 (November 96) |
8035 |
--------------------------------- |
|
8036 |
||
8037 |
* allowing negative levels (as offsets) in prlev and choplev; |
|
8038 |
||
2554 | 8039 |
* super-linear speedup for large simplifications; |
8040 |
||
8041 |
* FOL, ZF and HOL now use miniscoping: rewriting pushes |
|
8042 |
quantifications in as far as possible (COULD MAKE EXISTING PROOFS |
|
8043 |
FAIL); can suppress it using the command Delsimps (ex_simps @ |
|
8044 |
all_simps); De Morgan laws are also now included, by default; |
|
8045 |
||
8046 |
* improved printing of ==> : ~: |
|
8047 |
||
8048 |
* new object-logic "Sequents" adds linear logic, while replacing LK |
|
8049 |
and Modal (thanks to Sara Kalvala); |
|
8050 |
||
8051 |
* HOL/Auth: correctness proofs for authentication protocols; |
|
8052 |
||
8053 |
* HOL: new auto_tac combines rewriting and classical reasoning (many |
|
8054 |
examples on HOL/Auth); |
|
8055 |
||
8056 |
* HOL: new command AddIffs for declaring theorems of the form P=Q to |
|
8057 |
the rewriter and classical reasoner simultaneously; |
|
8058 |
||
8059 |
* function uresult no longer returns theorems in "standard" format; |
|
8060 |
regain previous version by: val uresult = standard o uresult; |
|
8061 |
||
8062 |
||
8063 |
||
8064 |
New in Isabelle94-6 |
|
8065 |
------------------- |
|
8066 |
||
8067 |
* oracles -- these establish an interface between Isabelle and trusted |
|
8068 |
external reasoners, which may deliver results as theorems; |
|
8069 |
||
8070 |
* proof objects (in particular record all uses of oracles); |
|
8071 |
||
8072 |
* Simp_tac, Fast_tac, etc. that refer to implicit simpset / claset; |
|
8073 |
||
8074 |
* "constdefs" section in theory files; |
|
8075 |
||
8076 |
* "primrec" section (HOL) no longer requires names; |
|
8077 |
||
8078 |
* internal type "tactic" now simply "thm -> thm Sequence.seq"; |
|
8079 |
||
8080 |
||
8081 |
||
8082 |
New in Isabelle94-5 |
|
8083 |
------------------- |
|
8084 |
||
8085 |
* reduced space requirements; |
|
8086 |
||
8087 |
* automatic HTML generation from theories; |
|
8088 |
||
8089 |
* theory files no longer require "..." (quotes) around most types; |
|
8090 |
||
8091 |
* new examples, including two proofs of the Church-Rosser theorem; |
|
8092 |
||
8093 |
* non-curried (1994) version of HOL is no longer distributed; |
|
8094 |
||
2553 | 8095 |
|
2557 | 8096 |
|
8097 |
New in Isabelle94-4 |
|
8098 |
------------------- |
|
8099 |
||
2747 | 8100 |
* greatly reduced space requirements; |
2557 | 8101 |
|
8102 |
* theory files (.thy) no longer require \...\ escapes at line breaks; |
|
8103 |
||
5726 | 8104 |
* searchable theorem database (see the section "Retrieving theorems" on |
2557 | 8105 |
page 8 of the Reference Manual); |
8106 |
||
8107 |
* new examples, including Grabczewski's monumental case study of the |
|
8108 |
Axiom of Choice; |
|
8109 |
||
8110 |
* The previous version of HOL renamed to Old_HOL; |
|
8111 |
||
5726 | 8112 |
* The new version of HOL (previously called CHOL) uses a curried syntax |
2557 | 8113 |
for functions. Application looks like f a b instead of f(a,b); |
8114 |
||
8115 |
* Mutually recursive inductive definitions finally work in HOL; |
|
8116 |
||
8117 |
* In ZF, pattern-matching on tuples is now available in all abstractions and |
|
8118 |
translates to the operator "split"; |
|
8119 |
||
8120 |
||
8121 |
||
8122 |
New in Isabelle94-3 |
|
8123 |
------------------- |
|
8124 |
||
5726 | 8125 |
* new infix operator, addss, allowing the classical reasoner to |
2557 | 8126 |
perform simplification at each step of its search. Example: |
5726 | 8127 |
fast_tac (cs addss ss) |
2557 | 8128 |
|
5726 | 8129 |
* a new logic, CHOL, the same as HOL, but with a curried syntax |
8130 |
for functions. Application looks like f a b instead of f(a,b). Also pairs |
|
2557 | 8131 |
look like (a,b) instead of <a,b>; |
8132 |
||
8133 |
* PLEASE NOTE: CHOL will eventually replace HOL! |
|
8134 |
||
8135 |
* In CHOL, pattern-matching on tuples is now available in all abstractions. |
|
8136 |
It translates to the operator "split". A new theory of integers is available; |
|
8137 |
||
8138 |
* In ZF, integer numerals now denote two's-complement binary integers. |
|
8139 |
Arithmetic operations can be performed by rewriting. See ZF/ex/Bin.ML; |
|
8140 |
||
5726 | 8141 |
* Many new examples: I/O automata, Church-Rosser theorem, equivalents |
2557 | 8142 |
of the Axiom of Choice; |
8143 |
||
8144 |
||
8145 |
||
8146 |
New in Isabelle94-2 |
|
8147 |
------------------- |
|
8148 |
||
5726 | 8149 |
* Significantly faster resolution; |
2557 | 8150 |
|
8151 |
* the different sections in a .thy file can now be mixed and repeated |
|
8152 |
freely; |
|
8153 |
||
8154 |
* Database of theorems for FOL, HOL and ZF. New |
|
8155 |
commands including qed, qed_goal and bind_thm store theorems in the database. |
|
8156 |
||
8157 |
* Simple database queries: return a named theorem (get_thm) or all theorems of |
|
8158 |
a given theory (thms_of), or find out what theory a theorem was proved in |
|
8159 |
(theory_of_thm); |
|
8160 |
||
8161 |
* Bugs fixed in the inductive definition and datatype packages; |
|
8162 |
||
8163 |
* The classical reasoner provides deepen_tac and depth_tac, making FOL_dup_cs |
|
8164 |
and HOL_dup_cs obsolete; |
|
8165 |
||
8166 |
* Syntactic ambiguities caused by the new treatment of syntax in Isabelle94-1 |
|
8167 |
have been removed; |
|
8168 |
||
8169 |
* Simpler definition of function space in ZF; |
|
8170 |
||
8171 |
* new results about cardinal and ordinal arithmetic in ZF; |
|
8172 |
||
8173 |
* 'subtype' facility in HOL for introducing new types as subsets of existing |
|
8174 |
types; |
|
8175 |
||
24213 | 8176 |
:mode=text:wrap=hard:maxLineLen=72: |