author | wenzelm |
Sat, 09 Jul 2011 21:53:27 +0200 | |
changeset 43721 | fad8634cee62 |
parent 43709 | 717e96cf9527 |
child 43731 | 70072780e095 |
child 43736 | d2f7af6e993c |
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). |
|
43527
1aacef7471c2
Release notes should be written from the user's perspective. Don't assume the user has universal knowledge of the system.
ballarin
parents:
43319
diff
changeset
|
25 |
The global load path (such as src/HOL/Library) has been discontinued. |
1aacef7471c2
Release notes should be written from the user's perspective. Don't assume the user has universal knowledge of the system.
ballarin
parents:
43319
diff
changeset
|
26 |
Note that the path element ~~ may be used to reference theories in the |
1aacef7471c2
Release notes should be written from the user's perspective. Don't assume the user has universal knowledge of the system.
ballarin
parents:
43319
diff
changeset
|
27 |
Isabelle home folder -- for instance, "~~/src/HOL/Library/FuncSet". |
1aacef7471c2
Release notes should be written from the user's perspective. Don't assume the user has universal knowledge of the system.
ballarin
parents:
43319
diff
changeset
|
28 |
INCOMPATIBILITY. |
41886 | 29 |
|
41950
134131d519c0
clarified ISABELLE_CSDP setting (formerly CSDP_EXE);
wenzelm
parents:
41944
diff
changeset
|
30 |
* 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
|
31 |
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
|
32 |
|
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_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
|
34 |
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
|
35 |
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
|
36 |
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
|
37 |
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
|
38 |
|
c7297638599b
cleanup of former settings GHC_PATH, EXEC_GHC, EXEC_OCAML, EXEC_SWIPL, EXEC_YAP -- discontinued implicit detection;
wenzelm
parents:
41950
diff
changeset
|
39 |
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
|
40 |
been discontinued. INCOMPATIBILITY. |
41950
134131d519c0
clarified ISABELLE_CSDP setting (formerly CSDP_EXE);
wenzelm
parents:
41944
diff
changeset
|
41 |
|
42669
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
42 |
* Name space: former unsynchronized references are now proper |
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
43 |
configuration options, with more conventional names: |
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
44 |
|
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
45 |
long_names ~> names_long |
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
46 |
short_names ~> names_short |
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
47 |
unique_names ~> names_unique |
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
48 |
|
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
49 |
Minor INCOMPATIBILITY, need to declare options in context like this: |
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
50 |
|
04dfffda5671
more conventional naming scheme: names_long, names_short, names_unique;
wenzelm
parents:
42658
diff
changeset
|
51 |
declare [[names_unique = false]] |
42358
b47d41d9f4b5
Name_Space: proper configuration options long_names, short_names, unique_names instead of former unsynchronized references;
wenzelm
parents:
42290
diff
changeset
|
52 |
|
42502 | 53 |
* Literal facts `prop` may contain dummy patterns, e.g. `_ = _`. Note |
54 |
that the result needs to be unique, which means fact specifications |
|
55 |
may have to be refined after enriching a proof context. |
|
56 |
||
42633 | 57 |
* Isabelle/Isar reference manual provides more formal references in |
58 |
syntax diagrams. |
|
59 |
||
41703
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
60 |
|
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
61 |
*** HOL *** |
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
62 |
|
42874 | 63 |
* Finite_Set.thy: more coherent development of fold_set locales: |
64 |
||
65 |
locale fun_left_comm ~> locale comp_fun_commute |
|
66 |
locale fun_left_comm_idem ~> locale comp_fun_idem |
|
67 |
||
68 |
Both use point-free characterisation; interpretation proofs may need adjustment. |
|
69 |
INCOMPATIBILITY. |
|
70 |
||
42843 | 71 |
* Code generation: |
72 |
- theory Library/Code_Char_ord provides native ordering of characters |
|
73 |
in the target language. |
|
74 |
||
42815 | 75 |
* Declare ext [intro] by default. Rare INCOMPATIBILITY. |
76 |
||
41792
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
77 |
* Nitpick: |
41877 | 78 |
- Added "need" and "total_consts" options. |
41993
bd6296de1432
reintroduced "show_skolems" option -- useful when too many Skolems are displayed
blanchet
parents:
41955
diff
changeset
|
79 |
- 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
|
80 |
- Renamed attribute: nitpick_def ~> nitpick_unfold. |
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
81 |
INCOMPATIBILITY. |
ff3cb0c418b7
renamed "nitpick\_def" to "nitpick_unfold" to reflect its new semantics
blanchet
parents:
41734
diff
changeset
|
82 |
|
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
83 |
* Sledgehammer: |
43627
ecd4bb7a8bc0
update documentation after "type_enc" renaming + fixed a few other out-of-date factlets
blanchet
parents:
43613
diff
changeset
|
84 |
- sledgehammer available_provers ~> sledgehammer supported_provers. |
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
85 |
INCOMPATIBILITY. |
42582 | 86 |
- Added support for SNARK and ToFoF-E on SystemOnTPTP and for simply typed |
87 |
TPTP problems (TFF). |
|
43627
ecd4bb7a8bc0
update documentation after "type_enc" renaming + fixed a few other out-of-date factlets
blanchet
parents:
43613
diff
changeset
|
88 |
- Added "preplay_timeout", "slicing", "type_enc", "sound", "max_mono_iters", |
ecd4bb7a8bc0
update documentation after "type_enc" renaming + fixed a few other out-of-date factlets
blanchet
parents:
43613
diff
changeset
|
89 |
and "max_new_mono_instances" options. |
ecd4bb7a8bc0
update documentation after "type_enc" renaming + fixed a few other out-of-date factlets
blanchet
parents:
43613
diff
changeset
|
90 |
- Removed "explicit_apply" and "full_types" options as well as "Full Types" |
ecd4bb7a8bc0
update documentation after "type_enc" renaming + fixed a few other out-of-date factlets
blanchet
parents:
43613
diff
changeset
|
91 |
Proof General menu item. INCOMPATIBILITY. |
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
92 |
|
43206
831d28439b3a
marked "metisF" as legacy -- nobody uses it or needs it
blanchet
parents:
42897
diff
changeset
|
93 |
* Metis: |
43573 | 94 |
- Removed "metisF" -- use "metis" instead. INCOMPATIBILITY. |
95 |
- Obsoleted "metisFT" -- use "metis (full_types)" instead. INCOMPATIBILITY. |
|
43206
831d28439b3a
marked "metisF" as legacy -- nobody uses it or needs it
blanchet
parents:
42897
diff
changeset
|
96 |
|
41999
3c029ef9e0f2
added "simp:", "intro:", and "elim:" to "try" command
blanchet
parents:
41993
diff
changeset
|
97 |
* "try": |
43570 | 98 |
- Renamed "try_methods" and added "simp:", "intro:", "dest:", and "elim:" |
99 |
options. INCOMPATIBILITY. |
|
100 |
- Introduced "try" that not only runs "try_methods" but also "solve_direct", |
|
101 |
"sledgehammer", "quickcheck", and "nitpick". |
|
41999
3c029ef9e0f2
added "simp:", "intro:", and "elim:" to "try" command
blanchet
parents:
41993
diff
changeset
|
102 |
|
42160 | 103 |
* Quickcheck: |
104 |
- Added "eval" option to evaluate terms for the found counterexample |
|
105 |
(currently only supported by the default (exhaustive) tester) |
|
106 |
- Added post-processing of terms to obtain readable counterexamples |
|
107 |
(currently only supported by the default (exhaustive) tester) |
|
43319 | 108 |
- New counterexample generator quickcheck[narrowing] enables |
109 |
narrowing-based testing. |
|
110 |
It requires that the Glasgow Haskell compiler is installed and |
|
111 |
its location is known to Isabelle with the environment variable |
|
112 |
ISABELLE_GHC. |
|
42160 | 113 |
|
41846
b368a7aee46a
removed support for tail-recursion from function package (now implemented by partial_function)
krauss
parents:
41792
diff
changeset
|
114 |
* Function package: discontinued option "tailrec". |
b368a7aee46a
removed support for tail-recursion from function package (now implemented by partial_function)
krauss
parents:
41792
diff
changeset
|
115 |
INCOMPATIBILITY. Use partial_function instead. |
b368a7aee46a
removed support for tail-recursion from function package (now implemented by partial_function)
krauss
parents:
41792
diff
changeset
|
116 |
|
42149 | 117 |
* HOL-Probability: |
118 |
- Caratheodory's extension lemma is now proved for ring_of_sets. |
|
119 |
- Infinite products of probability measures are now available. |
|
120 |
- Use extended reals instead of positive extended reals. |
|
121 |
INCOMPATIBILITY. |
|
41727
ab3f6d76fb23
available_provers ~> supported_provers (for clarity)
blanchet
parents:
41703
diff
changeset
|
122 |
|
42484 | 123 |
|
41685
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
124 |
*** Document preparation *** |
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
125 |
|
43709
717e96cf9527
discontinued special treatment of hard tabulators;
wenzelm
parents:
43627
diff
changeset
|
126 |
* Discontinued special treatment of hard tabulators, which are better |
717e96cf9527
discontinued special treatment of hard tabulators;
wenzelm
parents:
43627
diff
changeset
|
127 |
avoided in the first place. Implicit tab-width is 1. |
717e96cf9527
discontinued special treatment of hard tabulators;
wenzelm
parents:
43627
diff
changeset
|
128 |
|
42706 | 129 |
* Antiquotation @{rail} layouts railroad syntax diagrams, see also |
130 |
isar-ref manual. |
|
42633 | 131 |
|
43613
7afbaf5a406b
adding a minimalistic documentation of the value antiquotation in the Isar reference manual
bulwahn
parents:
43581
diff
changeset
|
132 |
* Antiquotation @{value} evaluates the given term and presents its result. |
7afbaf5a406b
adding a minimalistic documentation of the value antiquotation in the Isar reference manual
bulwahn
parents:
43581
diff
changeset
|
133 |
|
42514 | 134 |
* Localized \isabellestyle switch can be used within blocks or groups |
135 |
like this: |
|
136 |
||
137 |
\isabellestyle{it} %preferred default |
|
138 |
{\isabellestylett @{text "typewriter stuff"}} |
|
139 |
||
41685
e29ea98a76ce
term style 'isub': ad-hoc subscripting of variables that end with digits (x1, x23, ...)
krauss
parents:
41667
diff
changeset
|
140 |
* 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
|
141 |
subscripted form x\<^isub>1, y\<^isub>2\<^isub>3. |
41651 | 142 |
|
42484 | 143 |
* Predefined LaTeX macros for Isabelle symbols \<bind> and \<then> |
144 |
(e.g. see ~~/src/HOL/Library/Monad_Syntax.thy). |
|
145 |
||
41651 | 146 |
|
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
|
147 |
*** 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
|
148 |
|
43565 | 149 |
* Antiquotations for ML and document preparation are managed as theory |
150 |
data, which requires explicit setup. |
|
151 |
||
42897 | 152 |
* Isabelle_Process.is_active allows tools to check if the official |
153 |
process wrapper is running (Isabelle/Scala/jEdit) or the old TTY loop |
|
154 |
(better known as Proof General). |
|
155 |
||
42360 | 156 |
* Structure Proof_Context follows standard naming scheme. Old |
157 |
ProofContext is still available for some time as legacy alias. |
|
158 |
||
42015
7b6e72a1b7dd
NEWS: structure Timing provides various operations for timing;
wenzelm
parents:
41999
diff
changeset
|
159 |
* Structure Timing provides various operations for timing; supersedes |
7b6e72a1b7dd
NEWS: structure Timing provides various operations for timing;
wenzelm
parents:
41999
diff
changeset
|
160 |
former start_timing/end_timing etc. |
7b6e72a1b7dd
NEWS: structure Timing provides various operations for timing;
wenzelm
parents:
41999
diff
changeset
|
161 |
|
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
|
162 |
* 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
|
163 |
(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
|
164 |
|
42056
160a630b2c7e
enable inner syntax source positions by default (controlled via configuration option);
wenzelm
parents:
42015
diff
changeset
|
165 |
* 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
|
166 |
"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
|
167 |
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
|
168 |
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
|
169 |
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
|
170 |
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
|
171 |
"_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
|
172 |
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
|
173 |
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
|
174 |
|
42290
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
175 |
* Discontinued special status of various ML structures that contribute |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
176 |
to structure Syntax (Ast, Lexicon, Mixfix, Parser, Printer etc.): less |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
177 |
pervasive content, no inclusion in structure Syntax. INCOMPATIBILITY, |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
178 |
refer directly to Ast.Constant, Lexicon.is_identifier, |
b1f544c84040
discontinued special treatment of structure Lexicon;
wenzelm
parents:
42284
diff
changeset
|
179 |
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
|
180 |
|
42247
12fe41a92cd5
typed_print_translation: discontinued show_sorts argument;
wenzelm
parents:
42239
diff
changeset
|
181 |
* Typed print translation: discontinued show_sorts argument, which is |
12fe41a92cd5
typed_print_translation: discontinued show_sorts argument;
wenzelm
parents:
42239
diff
changeset
|
182 |
already available via context of "advanced" translation. |
12fe41a92cd5
typed_print_translation: discontinued show_sorts argument;
wenzelm
parents:
42239
diff
changeset
|
183 |
|
42370 | 184 |
* Refined PARALLEL_GOALS tactical: degrades gracefully for schematic |
185 |
goal states; body tactic needs to address all subgoals uniformly. |
|
186 |
||
42403
38b29c9fc742
slightly more special eq_list/eq_set, with shortcut involving pointer_eq;
wenzelm
parents:
42370
diff
changeset
|
187 |
* 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
|
188 |
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
|
189 |
|
42793 | 190 |
* Classical tactics use proper Proof.context instead of historic types |
191 |
claset/clasimpset. Old-style declarations like addIs, addEs, addDs |
|
192 |
operate directly on Proof.context. Raw type claset retains its use as |
|
193 |
snapshot of the classical context, which can be recovered via |
|
194 |
(put_claset HOL_cs) etc. Type clasimpset has been discontinued. |
|
195 |
INCOMPATIBILITY, classical tactics and derived proof methods require |
|
196 |
proper Proof.context. |
|
197 |
||
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
|
198 |
|
41703
d27950860514
parallelization of nested Isar proofs is subject to Goal.parallel_proofs_threshold;
wenzelm
parents:
41685
diff
changeset
|
199 |
|
41512 | 200 |
New in Isabelle2011 (January 2011) |
201 |
---------------------------------- |
|
37383 | 202 |
|
37536
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
203 |
*** General *** |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
204 |
|
41573 | 205 |
* Experimental Prover IDE based on Isabelle/Scala and jEdit (see |
41612 | 206 |
src/Tools/jEdit). This also serves as IDE for Isabelle/ML, with |
207 |
useful tooltips and hyperlinks produced from its static analysis. The |
|
208 |
bundled component provides an executable Isabelle tool that can be run |
|
209 |
like this: |
|
210 |
||
211 |
Isabelle2011/bin/isabelle jedit |
|
41573 | 212 |
|
40948 | 213 |
* Significantly improved Isabelle/Isar implementation manual. |
214 |
||
41594 | 215 |
* System settings: ISABELLE_HOME_USER now includes ISABELLE_IDENTIFIER |
41595 | 216 |
(and thus refers to something like $HOME/.isabelle/Isabelle2011), |
41594 | 217 |
while the default heap location within that directory lacks that extra |
218 |
suffix. This isolates multiple Isabelle installations from each |
|
219 |
other, avoiding problems with old settings in new versions. |
|
220 |
INCOMPATIBILITY, need to copy/upgrade old user settings manually. |
|
221 |
||
40947 | 222 |
* Source files are always encoded as UTF-8, instead of old-fashioned |
223 |
ISO-Latin-1. INCOMPATIBILITY. Isabelle LaTeX documents might require |
|
40948 | 224 |
the following package declarations: |
40947 | 225 |
|
226 |
\usepackage[utf8]{inputenc} |
|
227 |
\usepackage{textcomp} |
|
228 |
||
41440 | 229 |
* 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
|
230 |
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
|
231 |
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
|
232 |
contain symbols without further backslash escapes, Unicode can now be |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
233 |
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
|
234 |
consistent view on symbols, while raw explode (or String.explode) |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
235 |
merely give a byte-oriented representation. |
c62aa9281101
explicit treatment of UTF8 sequences as Isabelle symbols;
wenzelm
parents:
37484
diff
changeset
|
236 |
|
41594 | 237 |
* Theory loader: source files are primarily located via the master |
238 |
directory of each theory node (where the .thy file itself resides). |
|
239 |
The global load path is still partially available as legacy feature. |
|
240 |
Minor INCOMPATIBILITY due to subtle change in file lookup: use |
|
241 |
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
|
242 |
|
37939
965537d86fcc
discontinued special treatment of ML files -- no longer complete extensions on demand;
wenzelm
parents:
37868
diff
changeset
|
243 |
* 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
|
244 |
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
|
245 |
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
|
246 |
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
|
247 |
|
38980
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
248 |
* 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
|
249 |
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
|
250 |
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
|
251 |
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
|
252 |
|
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
|
253 |
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
|
254 |
|
39128
93a7365fb4ee
turned eta_contract into proper configuration option;
wenzelm
parents:
39126
diff
changeset
|
255 |
eta_contract eta_contract |
39137
ccb53edd59f0
turned show_brackets into proper configuration option;
wenzelm
parents:
39134
diff
changeset
|
256 |
show_brackets show_brackets |
39134
917b4b6ba3d2
turned show_sorts/show_types into proper configuration options;
wenzelm
parents:
39128
diff
changeset
|
257 |
show_sorts show_sorts |
917b4b6ba3d2
turned show_sorts/show_types into proper configuration options;
wenzelm
parents:
39128
diff
changeset
|
258 |
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
|
259 |
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
|
260 |
show_consts show_consts |
40879
ca132ef44944
configuration option "show_abbrevs" supersedes print mode "no_abbrevs", with inverted meaning;
wenzelm
parents:
40878
diff
changeset
|
261 |
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
|
262 |
|
41379 | 263 |
Syntax.ast_trace syntax_ast_trace |
264 |
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
|
265 |
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
|
266 |
|
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
|
267 |
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
|
268 |
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
|
269 |
|
41379 | 270 |
Method.rule_trace rule_trace |
271 |
||
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
|
272 |
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
|
273 |
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
|
274 |
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
|
275 |
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
|
276 |
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
|
277 |
|
41440 | 278 |
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
|
279 |
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
|
280 |
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
|
281 |
"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
|
282 |
|
40878
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
283 |
* More systematic naming of some configuration options. |
41294 | 284 |
INCOMPATIBILITY. |
40878
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
285 |
|
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
286 |
trace_simp ~> simp_trace |
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
287 |
debug_simp ~> simp_debug |
7695e4de4d86
renamed trace_simp to simp_trace, and debug_simp to simp_debug;
wenzelm
parents:
40866
diff
changeset
|
288 |
|
40291 | 289 |
* Support for real valued configuration options, using simplistic |
290 |
floating-point notation that coincides with the inner syntax for |
|
291 |
float_token. |
|
292 |
||
41594 | 293 |
* Support for real valued preferences (with approximative PGIP type): |
294 |
front-ends need to accept "pgint" values in float notation. |
|
295 |
INCOMPATIBILITY. |
|
41573 | 296 |
|
297 |
* The IsabelleText font now includes Cyrillic, Hebrew, Arabic from |
|
298 |
DejaVu Sans. |
|
299 |
||
41594 | 300 |
* Discontinued support for Poly/ML 5.0 and 5.1 versions. |
301 |
||
40948 | 302 |
|
303 |
*** Pure *** |
|
304 |
||
41249
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
305 |
* Command 'type_synonym' (with single argument) replaces somewhat |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
306 |
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
|
307 |
time. |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
308 |
|
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
309 |
* Command 'nonterminal' (with 'and' separated list of arguments) |
26f12f98f50a
Command 'type_synonym' (with single argument) supersedes 'types' (legacy feature);
wenzelm
parents:
41229
diff
changeset
|
310 |
replaces somewhat outdated 'nonterminals'. INCOMPATIBILITY. |
41229
d797baa3d57c
replaced command 'nonterminals' by slightly modernized version 'nonterminal';
wenzelm
parents:
41228
diff
changeset
|
311 |
|
40965
54b6c9e1c157
command 'notepad' replaces former 'example_proof';
wenzelm
parents:
40959
diff
changeset
|
312 |
* Command 'notepad' replaces former 'example_proof' for |
41020 | 313 |
experimentation in Isar without any result. INCOMPATIBILITY. |
40965
54b6c9e1c157
command 'notepad' replaces former 'example_proof';
wenzelm
parents:
40959
diff
changeset
|
314 |
|
41435 | 315 |
* Locale interpretation commands 'interpret' and 'sublocale' accept |
316 |
lists of equations to map definitions in a locale to appropriate |
|
317 |
entities in the context of the interpretation. The 'interpretation' |
|
318 |
command already provided this functionality. |
|
319 |
||
41594 | 320 |
* Diagnostic command 'print_dependencies' prints the locale instances |
321 |
that would be activated if the specified expression was interpreted in |
|
322 |
the current context. Variant "print_dependencies!" assumes a context |
|
323 |
without interpretations. |
|
38110 | 324 |
|
325 |
* Diagnostic command 'print_interps' prints interpretations in proofs |
|
326 |
in addition to interpretations in theories. |
|
327 |
||
38708
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
328 |
* Discontinued obsolete 'global' and 'local' commands to manipulate |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
329 |
the theory name space. Rare INCOMPATIBILITY. The ML functions |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
330 |
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
|
331 |
feature is still required for historical reasons. |
8915e3ce8655
discontinued obsolete 'global' and 'local' commands;
wenzelm
parents:
38656
diff
changeset
|
332 |
|
40948 | 333 |
* Discontinued obsolete 'constdefs' command. INCOMPATIBILITY, use |
39215 | 334 |
'definition' instead. |
335 |
||
41574 | 336 |
* The "prems" fact, which refers to the accidental collection of |
337 |
foundational premises in the context, is now explicitly marked as |
|
41594 | 338 |
legacy feature and will be discontinued soon. Consider using "assms" |
339 |
of the head statement or reference facts by explicit names. |
|
41574 | 340 |
|
40801 | 341 |
* Document antiquotations @{class} and @{type} print classes and type |
342 |
constructors. |
|
343 |
||
344 |
* Document antiquotation @{file} checks file/directory entries within |
|
345 |
the local file system. |
|
39305
d4fa19eb0822
'class' and 'type' are now antiquoations by default
haftmann
parents:
39277
diff
changeset
|
346 |
|
38110 | 347 |
|
37387
3581483cca6c
qualified types "+" and nat; qualified constants Ball, Bex, Suc, curry; modernized some specifications
haftmann
parents:
37383
diff
changeset
|
348 |
*** HOL *** |
3581483cca6c
qualified types "+" and nat; qualified constants Ball, Bex, Suc, curry; modernized some specifications
haftmann
parents:
37383
diff
changeset
|
349 |
|
41594 | 350 |
* Coercive subtyping: functions can be declared as coercions and type |
351 |
inference will add them as necessary upon input of a term. Theory |
|
352 |
Complex_Main declares real :: nat => real and real :: int => real as |
|
353 |
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
|
354 |
|
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
355 |
declare [[coercion f]] |
40866 | 356 |
|
41571 | 357 |
To lift coercions through type constructors (e.g. from nat => real to |
40866 | 358 |
nat list => real list), map functions can be declared, e.g. |
359 |
||
40939
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
360 |
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
|
361 |
|
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
362 |
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
|
363 |
real numbers, i.e. descendants of Complex_Main. This is controlled by |
41020 | 364 |
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
|
365 |
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
|
366 |
|
2c150063cd4d
setup subtyping/coercions once in HOL.thy, but enable it only later via configuration option;
wenzelm
parents:
40927
diff
changeset
|
367 |
declare [[coercion_enabled]] |
40866 | 368 |
|
41571 | 369 |
* Command 'partial_function' provides basic support for recursive |
370 |
function definitions over complete partial orders. Concrete instances |
|
40183 | 371 |
are provided for i) the option type, ii) tail recursion on arbitrary |
41571 | 372 |
types, and iii) the heap monad of Imperative_HOL. See |
373 |
src/HOL/ex/Fundefs.thy and src/HOL/Imperative_HOL/ex/Linked_Lists.thy |
|
374 |
for examples. |
|
40183 | 375 |
|
41571 | 376 |
* Function package: f.psimps rules are no longer implicitly declared |
377 |
as [simp]. INCOMPATIBILITY. |
|
41398 | 378 |
|
379 |
* Datatype package: theorems generated for executable equality (class |
|
41571 | 380 |
"eq") carry proper names and are treated as default code equations. |
381 |
||
41594 | 382 |
* Inductive package: now offers command 'inductive_simps' to |
383 |
automatically derive instantiated and simplified equations for |
|
384 |
inductive predicates, similar to 'inductive_cases'. |
|
385 |
||
41571 | 386 |
* Command 'enriched_type' allows to register properties of the |
387 |
functorial structure of types. |
|
39771 | 388 |
|
39644 | 389 |
* Improved infrastructure for term evaluation using code generator |
390 |
techniques, in particular static evaluation conversions. |
|
391 |
||
41594 | 392 |
* Code generator: Scala (2.8 or higher) has been added to the target |
393 |
languages. |
|
394 |
||
41398 | 395 |
* Code generator: globbing constant expressions "*" and "Theory.*" |
396 |
have been replaced by the more idiomatic "_" and "Theory._". |
|
397 |
INCOMPATIBILITY. |
|
398 |
||
399 |
* Code generator: export_code without explicit file declaration prints |
|
400 |
to standard output. INCOMPATIBILITY. |
|
401 |
||
402 |
* Code generator: do not print function definitions for case |
|
403 |
combinators any longer. |
|
404 |
||
41594 | 405 |
* Code generator: simplification with rules determined with |
41571 | 406 |
src/Tools/Code/code_simp.ML and method "code_simp". |
407 |
||
41594 | 408 |
* Code generator for records: more idiomatic representation of record |
40948 | 409 |
types. Warning: records are not covered by ancient SML code |
410 |
generation any longer. INCOMPATIBILITY. In cases of need, a suitable |
|
411 |
rep_datatype declaration helps to succeed then: |
|
38537 | 412 |
|
413 |
record 'a foo = ... |
|
414 |
... |
|
415 |
rep_datatype foo_ext ... |
|
38535 | 416 |
|
41594 | 417 |
* Records: logical foundation type for records does not carry a |
418 |
'_type' suffix any longer (obsolete due to authentic syntax). |
|
419 |
INCOMPATIBILITY. |
|
420 |
||
41398 | 421 |
* Quickcheck now by default uses exhaustive testing instead of random |
41571 | 422 |
testing. Random testing can be invoked by "quickcheck [random]", |
423 |
exhaustive testing by "quickcheck [exhaustive]". |
|
41398 | 424 |
|
425 |
* Quickcheck instantiates polymorphic types with small finite |
|
426 |
datatypes by default. This enables a simple execution mechanism to |
|
427 |
handle quantifiers and function equality over the finite datatypes. |
|
428 |
||
41571 | 429 |
* Quickcheck random generator has been renamed from "code" to |
430 |
"random". INCOMPATIBILITY. |
|
41398 | 431 |
|
432 |
* Quickcheck now has a configurable time limit which is set to 30 |
|
433 |
seconds by default. This can be changed by adding [timeout = n] to the |
|
434 |
quickcheck command. The time limit for Auto Quickcheck is still set |
|
435 |
independently. |
|
38461 | 436 |
|
437 |
* Quickcheck in locales considers interpretations of that locale for |
|
438 |
counter example search. |
|
439 |
||
40059
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
440 |
* Sledgehammer: |
41571 | 441 |
- Added "smt" and "remote_smt" provers based on the "smt" proof |
442 |
method. See the Sledgehammer manual for details ("isabelle doc |
|
443 |
sledgehammer"). |
|
40059
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
444 |
- Renamed commands: |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
445 |
sledgehammer atp_info ~> sledgehammer running_provers |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
446 |
sledgehammer atp_kill ~> sledgehammer kill_provers |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
447 |
sledgehammer available_atps ~> sledgehammer available_provers |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
448 |
INCOMPATIBILITY. |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
449 |
- Renamed options: |
6ad9081665db
use consistent terminology in Sledgehammer: "prover = ATP or SMT solver or ..."
blanchet
parents:
39993
diff
changeset
|
450 |
sledgehammer [atps = ...] ~> sledgehammer [provers = ...] |
40062 | 451 |
sledgehammer [atp = ...] ~> sledgehammer [prover = ...] |
40341
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
452 |
sledgehammer [timeout = 77 s] ~> sledgehammer [timeout = 77] |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
453 |
(and "ms" and "min" are no longer supported) |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
454 |
INCOMPATIBILITY. |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
455 |
|
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
456 |
* Nitpick: |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
457 |
- Renamed options: |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
458 |
nitpick [timeout = 77 s] ~> nitpick [timeout = 77] |
03156257040f
standardize on seconds for Nitpick and Sledgehammer timeouts
blanchet
parents:
40318
diff
changeset
|
459 |
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
|
460 |
INCOMPATIBILITY. |
40725 | 461 |
- Added support for partial quotient types. |
462 |
- Added local versions of the "Nitpick.register_xxx" functions. |
|
463 |
- Added "whack" option. |
|
464 |
- Allow registration of quotient types as codatatypes. |
|
465 |
- Improved "merge_type_vars" option to merge more types. |
|
466 |
- Removed unsound "fast_descrs" option. |
|
467 |
- Added custom symmetry breaking for datatypes, making it possible to reach |
|
468 |
higher cardinalities. |
|
469 |
- Prevent the expansion of too large definitions. |
|
39957
2f2d90cc31a2
document latest changes to Meson/Metis/Sledgehammer
blanchet
parents:
39910
diff
changeset
|
470 |
|
41571 | 471 |
* Proof methods "metis" and "meson" now have configuration options |
472 |
"meson_trace", "metis_trace", and "metis_verbose" that can be enabled |
|
473 |
to diagnose these tools. E.g. |
|
474 |
||
475 |
using [[metis_trace = true]] |
|
476 |
||
41398 | 477 |
* Auto Solve: Renamed "Auto Solve Direct". The tool is now available |
478 |
manually as command 'solve_direct'. |
|
479 |
||
41601 | 480 |
* The default SMT solver Z3 must be enabled explicitly (due to |
481 |
licensing issues) by setting the environment variable |
|
41603 | 482 |
Z3_NON_COMMERCIAL in etc/settings of the component, for example. For |
483 |
commercial applications, the SMT solver CVC3 is provided as fall-back; |
|
484 |
changing the SMT solver is done via the configuration option |
|
485 |
"smt_solver". |
|
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
486 |
|
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
487 |
* Remote SMT solvers need to be referred to by the "remote_" prefix, |
41571 | 488 |
i.e. "remote_cvc3" and "remote_z3". |
489 |
||
490 |
* Added basic SMT support for datatypes, records, and typedefs using |
|
491 |
the oracle mode (no proofs). Direct support of pairs has been dropped |
|
492 |
in exchange (pass theorems fst_conv snd_conv pair_collapse to the SMT |
|
493 |
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
|
494 |
|
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
|
495 |
* 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
|
496 |
- Renamed: |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
497 |
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
|
498 |
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
|
499 |
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
|
500 |
- 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
|
501 |
smt_verbose |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
502 |
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
|
503 |
smt_datatypes |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
504 |
smt_infer_triggers |
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
505 |
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
|
506 |
cvc3_options |
41432
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
507 |
remote_cvc3_options |
3214c39777ab
differentiate between local and remote SMT solvers (e.g., "z3" vs. "remote_z3");
boehmes
parents:
41430
diff
changeset
|
508 |
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
|
509 |
yices_options |
39957
2f2d90cc31a2
document latest changes to Meson/Metis/Sledgehammer
blanchet
parents:
39910
diff
changeset
|
510 |
|
40948 | 511 |
* Boogie output files (.b2i files) need to be declared in the theory |
512 |
header. |
|
40580
0592d3a39c08
require the b2i file ending in the boogie_open command (for consistency with the theory header)
boehmes
parents:
40424
diff
changeset
|
513 |
|
41594 | 514 |
* Simplification procedure "list_to_set_comprehension" rewrites list |
515 |
comprehensions applied to List.set to set comprehensions. Occasional |
|
516 |
INCOMPATIBILITY, may be deactivated like this: |
|
517 |
||
518 |
declare [[simproc del: list_to_set_comprehension]] |
|
519 |
||
41573 | 520 |
* Removed old version of primrec package. INCOMPATIBILITY. |
41398 | 521 |
|
522 |
* Removed simplifier congruence rule of "prod_case", as has for long |
|
523 |
been the case with "split". INCOMPATIBILITY. |
|
524 |
||
525 |
* String.literal is a type, but not a datatype. INCOMPATIBILITY. |
|
526 |
||
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
|
527 |
* 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
|
528 |
[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
|
529 |
|
41571 | 530 |
* Predicate "sorted" now defined inductively, with nice induction |
531 |
rules. INCOMPATIBILITY: former sorted.simps now named sorted_simps. |
|
41398 | 532 |
|
533 |
* Constant "contents" renamed to "the_elem", to free the generic name |
|
534 |
contents for other uses. INCOMPATIBILITY. |
|
535 |
||
536 |
* Renamed class eq and constant eq (for code generation) to class |
|
537 |
equal and constant equal, plus renaming of related facts and various |
|
538 |
tuning. INCOMPATIBILITY. |
|
539 |
||
540 |
* Dropped type classes mult_mono and mult_mono1. INCOMPATIBILITY. |
|
541 |
||
41571 | 542 |
* Removed output syntax "'a ~=> 'b" for "'a => 'b option". |
543 |
INCOMPATIBILITY. |
|
41398 | 544 |
|
545 |
* Renamed theory Fset to Cset, type Fset.fset to Cset.set, in order to |
|
546 |
avoid confusion with finite sets. INCOMPATIBILITY. |
|
547 |
||
548 |
* Abandoned locales equiv, congruent and congruent2 for equivalence |
|
549 |
relations. INCOMPATIBILITY: use equivI rather than equiv_intro (same |
|
550 |
for congruent(2)). |
|
551 |
||
552 |
* Some previously unqualified names have been qualified: |
|
553 |
||
554 |
types |
|
555 |
bool ~> HOL.bool |
|
556 |
nat ~> Nat.nat |
|
557 |
||
558 |
constants |
|
559 |
Trueprop ~> HOL.Trueprop |
|
560 |
True ~> HOL.True |
|
561 |
False ~> HOL.False |
|
562 |
op & ~> HOL.conj |
|
563 |
op | ~> HOL.disj |
|
564 |
op --> ~> HOL.implies |
|
565 |
op = ~> HOL.eq |
|
566 |
Not ~> HOL.Not |
|
567 |
The ~> HOL.The |
|
568 |
All ~> HOL.All |
|
569 |
Ex ~> HOL.Ex |
|
570 |
Ex1 ~> HOL.Ex1 |
|
571 |
Let ~> HOL.Let |
|
572 |
If ~> HOL.If |
|
573 |
Ball ~> Set.Ball |
|
574 |
Bex ~> Set.Bex |
|
575 |
Suc ~> Nat.Suc |
|
576 |
Pair ~> Product_Type.Pair |
|
577 |
fst ~> Product_Type.fst |
|
578 |
snd ~> Product_Type.snd |
|
579 |
curry ~> Product_Type.curry |
|
580 |
op : ~> Set.member |
|
581 |
Collect ~> Set.Collect |
|
582 |
||
583 |
INCOMPATIBILITY. |
|
584 |
||
585 |
* More canonical naming convention for some fundamental definitions: |
|
586 |
||
587 |
bot_bool_eq ~> bot_bool_def |
|
588 |
top_bool_eq ~> top_bool_def |
|
589 |
inf_bool_eq ~> inf_bool_def |
|
590 |
sup_bool_eq ~> sup_bool_def |
|
591 |
bot_fun_eq ~> bot_fun_def |
|
592 |
top_fun_eq ~> top_fun_def |
|
593 |
inf_fun_eq ~> inf_fun_def |
|
594 |
sup_fun_eq ~> sup_fun_def |
|
595 |
||
596 |
INCOMPATIBILITY. |
|
597 |
||
598 |
* More stylized fact names: |
|
599 |
||
600 |
expand_fun_eq ~> fun_eq_iff |
|
601 |
expand_set_eq ~> set_eq_iff |
|
602 |
set_ext ~> set_eqI |
|
603 |
nat_number ~> eval_nat_numeral |
|
604 |
||
605 |
INCOMPATIBILITY. |
|
606 |
||
41571 | 607 |
* Refactoring of code-generation specific operations in theory List: |
41398 | 608 |
|
609 |
constants |
|
610 |
null ~> List.null |
|
611 |
||
612 |
facts |
|
613 |
mem_iff ~> member_def |
|
614 |
null_empty ~> null_def |
|
615 |
||
616 |
INCOMPATIBILITY. Note that these were not supposed to be used |
|
617 |
regularly unless for striking reasons; their main purpose was code |
|
618 |
generation. |
|
619 |
||
620 |
Various operations from the Haskell prelude are used for generating |
|
621 |
Haskell code. |
|
622 |
||
41571 | 623 |
* Term "bij f" is now an abbreviation of "bij_betw f UNIV UNIV". Term |
624 |
"surj f" is now an abbreviation of "range f = UNIV". The theorems |
|
625 |
bij_def and surj_def are unchanged. INCOMPATIBILITY. |
|
41398 | 626 |
|
627 |
* Abolished some non-alphabetic type names: "prod" and "sum" replace |
|
628 |
"*" and "+" respectively. INCOMPATIBILITY. |
|
629 |
||
630 |
* Name "Plus" of disjoint sum operator "<+>" is now hidden. Write |
|
41571 | 631 |
"Sum_Type.Plus" instead. |
41398 | 632 |
|
633 |
* Constant "split" has been merged with constant "prod_case"; names of |
|
634 |
ML functions, facts etc. involving split have been retained so far, |
|
635 |
though. INCOMPATIBILITY. |
|
636 |
||
637 |
* Dropped old infix syntax "_ mem _" for List.member; use "_ : set _" |
|
638 |
instead. INCOMPATIBILITY. |
|
639 |
||
41571 | 640 |
* Removed lemma "Option.is_none_none" which duplicates "is_none_def". |
41398 | 641 |
INCOMPATIBILITY. |
642 |
||
41594 | 643 |
* Former theory Library/Enum is now part of the HOL-Main image. |
644 |
INCOMPATIBILITY: all constants of the Enum theory now have to be |
|
645 |
referred to by its qualified name. |
|
646 |
||
647 |
enum ~> Enum.enum |
|
648 |
nlists ~> Enum.nlists |
|
649 |
product ~> Enum.product |
|
650 |
||
651 |
* Theory Library/Monad_Syntax provides do-syntax for monad types. |
|
652 |
Syntax in Library/State_Monad has been changed to avoid ambiguities. |
|
653 |
INCOMPATIBILITY. |
|
654 |
||
655 |
* Theory Library/SetsAndFunctions has been split into |
|
656 |
Library/Function_Algebras and Library/Set_Algebras; canonical names |
|
657 |
for instance definitions for functions; various improvements. |
|
658 |
INCOMPATIBILITY. |
|
659 |
||
660 |
* Theory Library/Multiset provides stable quicksort implementation of |
|
661 |
sort_key. |
|
662 |
||
663 |
* Theory Library/Multiset: renamed empty_idemp ~> empty_neutral. |
|
664 |
INCOMPATIBILITY. |
|
665 |
||
666 |
* Session Multivariate_Analysis: introduced a type class for euclidean |
|
667 |
space. Most theorems are now stated in terms of euclidean spaces |
|
668 |
instead of finite cartesian products. |
|
669 |
||
670 |
types |
|
671 |
real ^ 'n ~> 'a::real_vector |
|
672 |
~> 'a::euclidean_space |
|
673 |
~> 'a::ordered_euclidean_space |
|
674 |
(depends on your needs) |
|
675 |
||
676 |
constants |
|
677 |
_ $ _ ~> _ $$ _ |
|
678 |
\<chi> x. _ ~> \<chi>\<chi> x. _ |
|
679 |
CARD('n) ~> DIM('a) |
|
680 |
||
681 |
Also note that the indices are now natural numbers and not from some |
|
682 |
finite type. Finite cartesian products of euclidean spaces, products |
|
683 |
of euclidean spaces the real and complex numbers are instantiated to |
|
684 |
be euclidean_spaces. INCOMPATIBILITY. |
|
685 |
||
686 |
* Session Probability: introduced pextreal as positive extended real |
|
687 |
numbers. Use pextreal as value for measures. Introduce the |
|
688 |
Radon-Nikodym derivative, product spaces and Fubini's theorem for |
|
689 |
arbitrary sigma finite measures. Introduces Lebesgue measure based on |
|
690 |
the integral in Multivariate Analysis. INCOMPATIBILITY. |
|
691 |
||
692 |
* Session Imperative_HOL: revamped, corrected dozens of inadequacies. |
|
693 |
INCOMPATIBILITY. |
|
694 |
||
695 |
* Session SPARK (with image HOL-SPARK) provides commands to load and |
|
696 |
prove verification conditions generated by the SPARK Ada program |
|
697 |
verifier. See also src/HOL/SPARK and src/HOL/SPARK/Examples. |
|
41567 | 698 |
|
40621 | 699 |
|
41433
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
700 |
*** HOL-Algebra *** |
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
701 |
|
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
702 |
* 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
|
703 |
descendants) are generated by interpretation from their multiplicative |
41434
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
704 |
counterparts. Names (in particular theorem names) have the mandatory |
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
705 |
qualifier 'add'. Previous theorem names are redeclared for |
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
706 |
compatibility. |
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
707 |
|
41571 | 708 |
* Structure "int_ring" is now an abbreviation (previously a |
41434
710cdb9e0d17
Documentation for 'interpret' and 'sublocale' with mixins.
ballarin
parents:
41433
diff
changeset
|
709 |
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
|
710 |
|
1b8ff770f02c
Abelian group facts obtained from group facts via interpretation (sublocale).
ballarin
parents:
41432
diff
changeset
|
711 |
|
40621 | 712 |
*** HOLCF *** |
713 |
||
714 |
* The domain package now runs in definitional mode by default: The |
|
41571 | 715 |
former command 'new_domain' is now called 'domain'. To use the domain |
40621 | 716 |
package in its original axiomatic mode, use 'domain (unsafe)'. |
717 |
INCOMPATIBILITY. |
|
718 |
||
41571 | 719 |
* The new class "domain" is now the default sort. Class "predomain" |
720 |
is an unpointed version of "domain". Theories can be updated by |
|
721 |
replacing sort annotations as shown below. INCOMPATIBILITY. |
|
40621 | 722 |
|
723 |
'a::type ~> 'a::countable |
|
724 |
'a::cpo ~> 'a::predomain |
|
725 |
'a::pcpo ~> 'a::domain |
|
726 |
||
41571 | 727 |
* The old type class "rep" has been superseded by class "domain". |
40621 | 728 |
Accordingly, users of the definitional package must remove any |
41571 | 729 |
"default_sort rep" declarations. INCOMPATIBILITY. |
40621 | 730 |
|
41401 | 731 |
* The domain package (definitional mode) now supports unpointed |
732 |
predomain argument types, as long as they are marked 'lazy'. (Strict |
|
41571 | 733 |
arguments must be in class "domain".) For example, the following |
41401 | 734 |
domain definition now works: |
735 |
||
736 |
domain natlist = nil | cons (lazy "nat discr") (lazy "natlist") |
|
737 |
||
738 |
* Theory HOLCF/Library/HOL_Cpo provides cpo and predomain class |
|
41571 | 739 |
instances for types from main HOL: bool, nat, int, char, 'a + 'b, |
740 |
'a option, and 'a list. Additionally, it configures fixrec and the |
|
741 |
domain package to work with these types. For example: |
|
41401 | 742 |
|
743 |
fixrec isInl :: "('a + 'b) u -> tr" |
|
744 |
where "isInl$(up$(Inl x)) = TT" | "isInl$(up$(Inr y)) = FF" |
|
745 |
||
746 |
domain V = VFun (lazy "V -> V") | VCon (lazy "nat") (lazy "V list") |
|
747 |
||
41571 | 748 |
* The "(permissive)" option of fixrec has been replaced with a |
749 |
per-equation "(unchecked)" option. See |
|
750 |
src/HOL/HOLCF/Tutorial/Fixrec_ex.thy for examples. INCOMPATIBILITY. |
|
751 |
||
752 |
* The "bifinite" class no longer fixes a constant "approx"; the class |
|
753 |
now just asserts that such a function exists. INCOMPATIBILITY. |
|
754 |
||
755 |
* 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
|
756 |
defines an embedding of type 'a defl into udom by default; instances |
41571 | 757 |
of "bifinite" and "domain" classes are available in |
758 |
src/HOL/HOLCF/Library/Defl_Bifinite.thy. |
|
759 |
||
760 |
* The syntax "REP('a)" has been replaced with "DEFL('a)". |
|
761 |
||
762 |
* The predicate "directed" has been removed. INCOMPATIBILITY. |
|
763 |
||
764 |
* The type class "finite_po" has been removed. INCOMPATIBILITY. |
|
765 |
||
766 |
* The function "cprod_map" has been renamed to "prod_map". |
|
41401 | 767 |
INCOMPATIBILITY. |
768 |
||
769 |
* The monadic bind operator on each powerdomain has new binder syntax |
|
41571 | 770 |
similar to sets, e.g. "\<Union>\<sharp>x\<in>xs. t" represents |
771 |
"upper_bind\<cdot>xs\<cdot>(\<Lambda> x. t)". |
|
41401 | 772 |
|
773 |
* The infix syntax for binary union on each powerdomain has changed |
|
41571 | 774 |
from e.g. "+\<sharp>" to "\<union>\<sharp>", for consistency with set |
775 |
syntax. INCOMPATIBILITY. |
|
776 |
||
777 |
* 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
|
778 |
still supported as an input translation. |
cf5f025bc3c7
renamed constant 'UU' to 'bottom', keeping 'UU' as alternative input syntax;
huffman
parents:
41414
diff
changeset
|
779 |
|
40621 | 780 |
* Renamed some theorems (the original names are also still available). |
41571 | 781 |
|
40621 | 782 |
expand_fun_below ~> fun_below_iff |
783 |
below_fun_ext ~> fun_belowI |
|
784 |
expand_cfun_eq ~> cfun_eq_iff |
|
785 |
ext_cfun ~> cfun_eqI |
|
786 |
expand_cfun_below ~> cfun_below_iff |
|
787 |
below_cfun_ext ~> cfun_belowI |
|
788 |
cont2cont_Rep_CFun ~> cont2cont_APP |
|
789 |
||
790 |
* The Abs and Rep functions for various types have changed names. |
|
40948 | 791 |
Related theorem names have also changed to match. INCOMPATIBILITY. |
41571 | 792 |
|
40621 | 793 |
Rep_CFun ~> Rep_cfun |
794 |
Abs_CFun ~> Abs_cfun |
|
795 |
Rep_Sprod ~> Rep_sprod |
|
796 |
Abs_Sprod ~> Abs_sprod |
|
797 |
Rep_Ssum ~> Rep_ssum |
|
798 |
Abs_Ssum ~> Abs_ssum |
|
799 |
||
800 |
* Lemmas with names of the form *_defined_iff or *_strict_iff have |
|
41571 | 801 |
been renamed to *_bottom_iff. INCOMPATIBILITY. |
40621 | 802 |
|
803 |
* Various changes to bisimulation/coinduction with domain package: |
|
41571 | 804 |
|
805 |
- Definitions of "bisim" constants no longer mention definedness. |
|
806 |
- With mutual recursion, "bisim" predicate is now curried. |
|
40621 | 807 |
- With mutual recursion, each type gets a separate coind theorem. |
808 |
- Variable names in bisim_def and coinduct rules have changed. |
|
41571 | 809 |
|
40621 | 810 |
INCOMPATIBILITY. |
811 |
||
41571 | 812 |
* Case combinators generated by the domain package for type "foo" are |
813 |
now named "foo_case" instead of "foo_when". INCOMPATIBILITY. |
|
40621 | 814 |
|
40771 | 815 |
* Several theorems have been renamed to more accurately reflect the |
41571 | 816 |
names of constants and types involved. INCOMPATIBILITY. |
817 |
||
40771 | 818 |
thelub_const ~> lub_const |
819 |
lub_const ~> is_lub_const |
|
820 |
thelubI ~> lub_eqI |
|
821 |
is_lub_lub ~> is_lubD2 |
|
822 |
lubI ~> is_lub_lub |
|
823 |
unique_lub ~> is_lub_unique |
|
824 |
is_ub_lub ~> is_lub_rangeD1 |
|
825 |
lub_bin_chain ~> is_lub_bin_chain |
|
41030
ff7d177128ef
rename lub_fun -> is_lub_fun, thelub_fun -> lub_fun
huffman
parents:
40965
diff
changeset
|
826 |
lub_fun ~> is_lub_fun |
ff7d177128ef
rename lub_fun -> is_lub_fun, thelub_fun -> lub_fun
huffman
parents:
40965
diff
changeset
|
827 |
thelub_fun ~> lub_fun |
41031 | 828 |
thelub_cfun ~> lub_cfun |
40771 | 829 |
thelub_Pair ~> lub_Pair |
830 |
lub_cprod ~> is_lub_prod |
|
831 |
thelub_cprod ~> lub_prod |
|
832 |
minimal_cprod ~> minimal_prod |
|
833 |
inst_cprod_pcpo ~> inst_prod_pcpo |
|
41430
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
834 |
UU_I ~> bottomI |
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
835 |
compact_UU ~> compact_bottom |
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
836 |
deflation_UU ~> deflation_bottom |
1aa23e9f2c87
change some lemma names containing 'UU' to 'bottom'
huffman
parents:
41429
diff
changeset
|
837 |
finite_deflation_UU ~> finite_deflation_bottom |
40771 | 838 |
|
41571 | 839 |
* Many legacy theorem names have been discontinued. INCOMPATIBILITY. |
840 |
||
40621 | 841 |
sq_ord_less_eq_trans ~> below_eq_trans |
842 |
sq_ord_eq_less_trans ~> eq_below_trans |
|
843 |
refl_less ~> below_refl |
|
844 |
trans_less ~> below_trans |
|
845 |
antisym_less ~> below_antisym |
|
846 |
antisym_less_inverse ~> po_eq_conv [THEN iffD1] |
|
847 |
box_less ~> box_below |
|
848 |
rev_trans_less ~> rev_below_trans |
|
849 |
not_less2not_eq ~> not_below2not_eq |
|
850 |
less_UU_iff ~> below_UU_iff |
|
851 |
flat_less_iff ~> flat_below_iff |
|
852 |
adm_less ~> adm_below |
|
853 |
adm_not_less ~> adm_not_below |
|
854 |
adm_compact_not_less ~> adm_compact_not_below |
|
855 |
less_fun_def ~> below_fun_def |
|
856 |
expand_fun_less ~> fun_below_iff |
|
857 |
less_fun_ext ~> fun_belowI |
|
858 |
less_discr_def ~> below_discr_def |
|
859 |
discr_less_eq ~> discr_below_eq |
|
860 |
less_unit_def ~> below_unit_def |
|
861 |
less_cprod_def ~> below_prod_def |
|
862 |
prod_lessI ~> prod_belowI |
|
863 |
Pair_less_iff ~> Pair_below_iff |
|
864 |
fst_less_iff ~> fst_below_iff |
|
865 |
snd_less_iff ~> snd_below_iff |
|
866 |
expand_cfun_less ~> cfun_below_iff |
|
867 |
less_cfun_ext ~> cfun_belowI |
|
868 |
injection_less ~> injection_below |
|
869 |
less_up_def ~> below_up_def |
|
870 |
not_Iup_less ~> not_Iup_below |
|
871 |
Iup_less ~> Iup_below |
|
872 |
up_less ~> up_below |
|
873 |
Def_inject_less_eq ~> Def_below_Def |
|
874 |
Def_less_is_eq ~> Def_below_iff |
|
875 |
spair_less_iff ~> spair_below_iff |
|
876 |
less_sprod ~> below_sprod |
|
877 |
spair_less ~> spair_below |
|
878 |
sfst_less_iff ~> sfst_below_iff |
|
879 |
ssnd_less_iff ~> ssnd_below_iff |
|
880 |
fix_least_less ~> fix_least_below |
|
881 |
dist_less_one ~> dist_below_one |
|
882 |
less_ONE ~> below_ONE |
|
883 |
ONE_less_iff ~> ONE_below_iff |
|
884 |
less_sinlD ~> below_sinlD |
|
885 |
less_sinrD ~> below_sinrD |
|
886 |
||
887 |
||
40948 | 888 |
*** FOL and ZF *** |
38522 | 889 |
|
41310 | 890 |
* All constant names are now qualified internally and use proper |
891 |
identifiers, e.g. "IFOL.eq" instead of "op =". INCOMPATIBILITY. |
|
892 |
||
38522 | 893 |
|
37868
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
894 |
*** ML *** |
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
895 |
|
41594 | 896 |
* Antiquotation @{assert} inlines a function bool -> unit that raises |
897 |
Fail if the argument is false. Due to inlining the source position of |
|
898 |
failed assertions is included in the error output. |
|
899 |
||
900 |
* Discontinued antiquotation @{theory_ref}, which is obsolete since ML |
|
901 |
text is in practice always evaluated with a stable theory checkpoint. |
|
902 |
Minor INCOMPATIBILITY, use (Theory.check_thy @{theory}) instead. |
|
903 |
||
904 |
* Antiquotation @{theory A} refers to theory A from the ancestry of |
|
905 |
the current context, not any accidental theory loader state as before. |
|
906 |
Potential INCOMPATIBILITY, subtle change in semantics. |
|
41228
e1fce873b814
renamed structure MetaSimplifier to raw_Simplifer, to emphasize its meaning;
wenzelm
parents:
41079
diff
changeset
|
907 |
|
40956 | 908 |
* Syntax.pretty_priority (default 0) configures the required priority |
909 |
of pretty-printed output and thus affects insertion of parentheses. |
|
910 |
||
40959 | 911 |
* Syntax.default_root (default "any") configures the inner syntax |
912 |
category (nonterminal symbol) for parsing of terms. |
|
913 |
||
40722
441260986b63
make two copies (!) of Library.UnequalLengths coincide with ListPair.UnequalLengths;
wenzelm
parents:
40712
diff
changeset
|
914 |
* Former exception Library.UnequalLengths now coincides with |
441260986b63
make two copies (!) of Library.UnequalLengths coincide with ListPair.UnequalLengths;
wenzelm
parents:
40712
diff
changeset
|
915 |
ListPair.UnequalLengths. |
441260986b63
make two copies (!) of Library.UnequalLengths coincide with ListPair.UnequalLengths;
wenzelm
parents:
40712
diff
changeset
|
916 |
|
41594 | 917 |
* Renamed structure MetaSimplifier to Raw_Simplifier. Note that the |
918 |
main functionality is provided by structure Simplifier. |
|
919 |
||
40627
becf5d5187cc
renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents:
40624
diff
changeset
|
920 |
* 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
|
921 |
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
|
922 |
almost all situations. |
becf5d5187cc
renamed raw "explode" function to "raw_explode" to emphasize its meaning;
wenzelm
parents:
40624
diff
changeset
|
923 |
|
40318
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
924 |
* Discontinued obsolete function sys_error and exception SYS_ERROR. |
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
925 |
See implementation manual for further details on exceptions in |
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
926 |
Isabelle/ML. |
035b2afbeb2e
discontinued obsolete function sys_error and exception SYS_ERROR;
wenzelm
parents:
40295
diff
changeset
|
927 |
|
39616
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents:
39557
diff
changeset
|
928 |
* 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
|
929 |
meaning. |
8052101883c3
renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents:
39557
diff
changeset
|
930 |
|
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
|
931 |
* 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
|
932 |
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
|
933 |
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
|
934 |
|
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
|
935 |
* 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
|
936 |
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
|
937 |
|
38980
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
938 |
* Configuration option show_question_marks only affects regular pretty |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
939 |
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
|
940 |
|
39164
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
941 |
* 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
|
942 |
INCOMPATIBILITY, superseded by static antiquotations @{thm} and |
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
943 |
@{thms} for most purposes. |
e7e12555e763
ML_Context.thm and ML_Context.thms no longer pervasive;
wenzelm
parents:
39154
diff
changeset
|
944 |
|
41594 | 945 |
* 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
|
946 |
interaction mode as before. Old Unsynchronized.set etc. have been |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
947 |
discontinued -- use plain := instead. This should be *rare* anyway, |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
948 |
since modern tools always work via official context data, notably |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
949 |
configuration options. |
af73cf0dc31f
turned show_question_marks into proper configuration option;
wenzelm
parents:
38864
diff
changeset
|
950 |
|
39239 | 951 |
* Parallel and asynchronous execution requires special care concerning |
952 |
interrupts. Structure Exn provides some convenience functions that |
|
953 |
avoid working directly with raw Interrupt. User code must not absorb |
|
954 |
interrupts -- intermediate handling (for cleanup etc.) needs to be |
|
955 |
followed by re-raising of the original exception. Another common |
|
956 |
source of mistakes are "handle _" patterns, which make the meaning of |
|
957 |
the program subject to physical effects of the environment. |
|
958 |
||
37868
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
959 |
|
59eed00bfd8e
ML antiquotations @{theory} and @{theory_ref} refer to the theory ancestry, not any accidental theory loader state;
wenzelm
parents:
37820
diff
changeset
|
960 |
|
37144 | 961 |
New in Isabelle2009-2 (June 2010) |
962 |
--------------------------------- |
|
33993 | 963 |
|
35260 | 964 |
*** General *** |
965 |
||
35436 | 966 |
* Authentic syntax for *all* logical entities (type classes, type |
967 |
constructors, term constants): provides simple and robust |
|
968 |
correspondence between formal entities and concrete syntax. Within |
|
969 |
the parse tree / AST representations, "constants" are decorated by |
|
970 |
their category (class, type, const) and spelled out explicitly with |
|
971 |
their full internal name. |
|
972 |
||
973 |
Substantial INCOMPATIBILITY concerning low-level syntax declarations |
|
974 |
and translations (translation rules and translation functions in ML). |
|
975 |
Some hints on upgrading: |
|
35260 | 976 |
|
977 |
- Many existing uses of 'syntax' and 'translations' can be replaced |
|
35436 | 978 |
by more modern 'type_notation', 'notation' and 'abbreviation', |
979 |
which are independent of this issue. |
|
35260 | 980 |
|
981 |
- 'translations' require markup within the AST; the term syntax |
|
982 |
provides the following special forms: |
|
983 |
||
984 |
CONST c -- produces syntax version of constant c from context |
|
35261 | 985 |
XCONST c -- literally c, checked as constant from context |
986 |
c -- literally c, if declared by 'syntax' |
|
987 |
||
988 |
Plain identifiers are treated as AST variables -- occasionally the |
|
989 |
system indicates accidental variables via the error "rhs contains |
|
990 |
extra variables". |
|
35260 | 991 |
|
35436 | 992 |
Type classes and type constructors are marked according to their |
993 |
concrete syntax. Some old translations rules need to be written |
|
994 |
for the "type" category, using type constructor application |
|
995 |
instead of pseudo-term application of the default category |
|
996 |
"logic". |
|
997 |
||
35260 | 998 |
- 'parse_translation' etc. in ML may use the following |
999 |
antiquotations: |
|
1000 |
||
35436 | 1001 |
@{class_syntax c} -- type class c within parse tree / AST |
1002 |
@{term_syntax c} -- type constructor c within parse tree / AST |
|
35260 | 1003 |
@{const_syntax c} -- ML version of "CONST c" above |
1004 |
@{syntax_const c} -- literally c (checked wrt. 'syntax' declarations) |
|
1005 |
||
35436 | 1006 |
- Literal types within 'typed_print_translations', i.e. those *not* |
1007 |
represented as pseudo-terms are represented verbatim. Use @{class |
|
1008 |
c} or @{type_name c} here instead of the above syntax |
|
1009 |
antiquotations. |
|
1010 |
||
35260 | 1011 |
Note that old non-authentic syntax was based on unqualified base |
35436 | 1012 |
names, so all of the above "constant" names would coincide. Recall |
1013 |
that 'print_syntax' and ML_command "set Syntax.trace_ast" help to |
|
1014 |
diagnose syntax problems. |
|
35260 | 1015 |
|
35351
7425aece4ee3
allow general mixfix syntax for type constructors;
wenzelm
parents:
35306
diff
changeset
|
1016 |
* Type constructors admit general mixfix syntax, not just infix. |
7425aece4ee3
allow general mixfix syntax for type constructors;
wenzelm
parents:
35306
diff
changeset
|
1017 |
|
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
|
1018 |
* 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
|
1019 |
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
|
1020 |
'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
|
1021 |
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
|
1022 |
|
37351 | 1023 |
* Discontinued unnamed infix syntax (legacy feature for many years) -- |
1024 |
need to specify constant name and syntax separately. Internal ML |
|
1025 |
datatype constructors have been renamed from InfixName to Infix etc. |
|
1026 |
Minor INCOMPATIBILITY. |
|
1027 |
||
1028 |
* Schematic theorem statements need to be explicitly markup as such, |
|
1029 |
via commands 'schematic_lemma', 'schematic_theorem', |
|
1030 |
'schematic_corollary'. Thus the relevance of the proof is made |
|
1031 |
syntactically clear, which impacts performance in a parallel or |
|
1032 |
asynchronous interactive environment. Minor INCOMPATIBILITY. |
|
1033 |
||
35613 | 1034 |
* Use of cumulative prems via "!" in some proof methods has been |
37351 | 1035 |
discontinued (old legacy feature). |
35613 | 1036 |
|
35979
12bb31230550
replaced references 'trace_simp' and 'debug_simp' by configuration options stored in the context
boehmes
parents:
35845
diff
changeset
|
1037 |
* References 'trace_simp' and 'debug_simp' have been replaced by |
36857 | 1038 |
configuration options stored in the context. Enabling tracing (the |
1039 |
case of debugging is similar) in proofs works via |
|
1040 |
||
1041 |
using [[trace_simp = true]] |
|
1042 |
||
1043 |
Tracing is then active for all invocations of the simplifier in |
|
1044 |
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
|
1045 |
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
|
1046 |
|
36177
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
1047 |
* Separate commands 'hide_class', 'hide_type', 'hide_const', |
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
1048 |
'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
|
1049 |
INCOMPATIBILITY. |
8e0770d2e499
separate commands 'hide_class', 'hide_type', 'hide_const', 'hide_fact';
wenzelm
parents:
36162
diff
changeset
|
1050 |
|
37298
1f3ca94ccb84
improved parallelism of proof term normalization;
wenzelm
parents:
37273
diff
changeset
|
1051 |
* Improved parallelism of proof term normalization: usedir -p2 -q0 is |
1f3ca94ccb84
improved parallelism of proof term normalization;
wenzelm
parents:
37273
diff
changeset
|
1052 |
more efficient than combinations with -q1 or -q2. |
1f3ca94ccb84
improved parallelism of proof term normalization;
wenzelm
parents:
37273
diff
changeset
|
1053 |
|
35260 | 1054 |
|
34170
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
1055 |
*** Pure *** |
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
1056 |
|
37351 | 1057 |
* Proofterms record type-class reasoning explicitly, using the |
1058 |
"unconstrain" operation internally. This eliminates all sort |
|
1059 |
constraints from a theorem and proof, introducing explicit |
|
1060 |
OFCLASS-premises. On the proof term level, this operation is |
|
1061 |
automatically applied at theorem boundaries, such that closed proofs |
|
1062 |
are always free of sort constraints. INCOMPATIBILITY for tools that |
|
1063 |
inspect proof terms. |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
36096
diff
changeset
|
1064 |
|
35765
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
1065 |
* Local theory specifications may depend on extra type variables that |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
1066 |
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
|
1067 |
are added internally. For example: |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
1068 |
|
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
1069 |
definition unitary :: bool where "unitary = (ALL (x::'a) y. x = y)" |
09e238561460
local theory specifications handle hidden polymorphism implicitly;
wenzelm
parents:
35763
diff
changeset
|
1070 |
|
37351 | 1071 |
* Predicates of locales introduced by classes carry a mandatory |
1072 |
"class" prefix. INCOMPATIBILITY. |
|
1073 |
||
1074 |
* Vacuous class specifications observe default sort. INCOMPATIBILITY. |
|
1075 |
||
1076 |
* Old 'axclass' command has been discontinued. INCOMPATIBILITY, use |
|
1077 |
'class' instead. |
|
1078 |
||
1079 |
* Command 'code_reflect' allows to incorporate generated ML code into |
|
1080 |
runtime environment; replaces immature code_datatype antiquotation. |
|
1081 |
INCOMPATIBILITY. |
|
1082 |
||
1083 |
* Code generator: simple concept for abstract datatypes obeying |
|
1084 |
invariants. |
|
1085 |
||
36857 | 1086 |
* Code generator: details of internal data cache have no impact on the |
1087 |
user space functionality any longer. |
|
1088 |
||
37351 | 1089 |
* Methods "unfold_locales" and "intro_locales" ignore non-locale |
1090 |
subgoals. This is more appropriate for interpretations with 'where'. |
|
36857 | 1091 |
INCOMPATIBILITY. |
34170
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
1092 |
|
36356
5ab0f8859f9f
command 'example_proof' opens an empty proof body;
wenzelm
parents:
36348
diff
changeset
|
1093 |
* 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
|
1094 |
experiment with Isar, without producing any persistent result. |
5ab0f8859f9f
command 'example_proof' opens an empty proof body;
wenzelm
parents:
36348
diff
changeset
|
1095 |
|
35413 | 1096 |
* Commands 'type_notation' and 'no_type_notation' declare type syntax |
1097 |
within a local theory context, with explicit checking of the |
|
1098 |
constructors involved (in contrast to the raw 'syntax' versions). |
|
1099 |
||
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
|
1100 |
* 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
|
1101 |
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
|
1102 |
assumptions, which is not possible in Isabelle/Pure. |
35681 | 1103 |
|
36857 | 1104 |
* Command 'defaultsort' has been renamed to 'default_sort', it works |
1105 |
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
|
1106 |
|
34170
254ac75e4c38
reduced code generator cache to the baremost minimum; corrected spelling
haftmann
parents:
34076
diff
changeset
|
1107 |
|
33993 | 1108 |
*** HOL *** |
1109 |
||
37351 | 1110 |
* Command 'typedef' now works within a local theory context -- without |
1111 |
introducing dependencies on parameters or assumptions, which is not |
|
1112 |
possible in Isabelle/Pure/HOL. Note that the logical environment may |
|
1113 |
contain multiple interpretations of local typedefs (with different |
|
1114 |
non-emptiness proofs), even in a global theory context. |
|
1115 |
||
1116 |
* New package for quotient types. Commands 'quotient_type' and |
|
1117 |
'quotient_definition' may be used for defining types and constants by |
|
1118 |
quotient constructions. An example is the type of integers created by |
|
1119 |
quotienting pairs of natural numbers: |
|
37380 | 1120 |
|
37351 | 1121 |
fun |
37380 | 1122 |
intrel :: "(nat * nat) => (nat * nat) => bool" |
37351 | 1123 |
where |
1124 |
"intrel (x, y) (u, v) = (x + v = u + y)" |
|
1125 |
||
37380 | 1126 |
quotient_type int = "nat * nat" / intrel |
37351 | 1127 |
by (auto simp add: equivp_def expand_fun_eq) |
37380 | 1128 |
|
37351 | 1129 |
quotient_definition |
1130 |
"0::int" is "(0::nat, 0::nat)" |
|
1131 |
||
1132 |
The method "lifting" can be used to lift of theorems from the |
|
1133 |
underlying "raw" type to the quotient type. The example |
|
1134 |
src/HOL/Quotient_Examples/FSet.thy includes such a quotient |
|
1135 |
construction and provides a reasoning infrastructure for finite sets. |
|
1136 |
||
1137 |
* Renamed Library/Quotient.thy to Library/Quotient_Type.thy to avoid |
|
1138 |
clash with new theory Quotient in Main HOL. |
|
1139 |
||
1140 |
* Moved the SMT binding into the main HOL session, eliminating |
|
1141 |
separate HOL-SMT session. |
|
1142 |
||
37020 | 1143 |
* List membership infix mem operation is only an input abbreviation. |
1144 |
INCOMPATIBILITY. |
|
1145 |
||
37144 | 1146 |
* Theory Library/Word.thy has been removed. Use library Word/Word.thy |
1147 |
for future developements; former Library/Word.thy is still present in |
|
1148 |
the AFP entry RSAPPS. |
|
36963
9a017146675f
dropped old Library/Word.thy and toy example ex/Adder.thy
haftmann
parents:
36953
diff
changeset
|
1149 |
|
36857 | 1150 |
* Theorem Int.int_induct renamed to Int.int_of_nat_induct and is no |
1151 |
longer shadowed. INCOMPATIBILITY. |
|
36808
cbeb3484fa07
theorem Presburger.int_induct has been renamed to Int.int_bidirectional_induct
haftmann
parents:
36714
diff
changeset
|
1152 |
|
36836
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1153 |
* 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
|
1154 |
INCOMPATIBILITY. |
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1155 |
|
49156805321c
removed lemma real_sq_order; use power2_le_imp_le instead
huffman
parents:
36830
diff
changeset
|
1156 |
* 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
|
1157 |
INCOMPATIBILITY. |
36714 | 1158 |
|
36857 | 1159 |
* Dropped normalizing_semiring etc; use the facts in semiring classes |
1160 |
instead. INCOMPATIBILITY. |
|
1161 |
||
36979
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1162 |
* Dropped several real-specific versions of lemmas about floor and |
37351 | 1163 |
ceiling; use the generic lemmas from theory "Archimedean_Field" |
1164 |
instead. INCOMPATIBILITY. |
|
36979
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1165 |
|
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1166 |
floor_number_of_eq ~> floor_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1167 |
le_floor_eq_number_of ~> number_of_le_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1168 |
le_floor_eq_zero ~> zero_le_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1169 |
le_floor_eq_one ~> one_le_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1170 |
floor_less_eq_number_of ~> floor_less_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1171 |
floor_less_eq_zero ~> floor_less_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1172 |
floor_less_eq_one ~> floor_less_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1173 |
less_floor_eq_number_of ~> number_of_less_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1174 |
less_floor_eq_zero ~> zero_less_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1175 |
less_floor_eq_one ~> one_less_floor |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1176 |
floor_le_eq_number_of ~> floor_le_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1177 |
floor_le_eq_zero ~> floor_le_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1178 |
floor_le_eq_one ~> floor_le_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1179 |
floor_subtract_number_of ~> floor_diff_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1180 |
floor_subtract_one ~> floor_diff_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1181 |
ceiling_number_of_eq ~> ceiling_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1182 |
ceiling_le_eq_number_of ~> ceiling_le_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1183 |
ceiling_le_zero_eq ~> ceiling_le_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1184 |
ceiling_le_eq_one ~> ceiling_le_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1185 |
less_ceiling_eq_number_of ~> number_of_less_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1186 |
less_ceiling_eq_zero ~> zero_less_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1187 |
less_ceiling_eq_one ~> one_less_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1188 |
ceiling_less_eq_number_of ~> ceiling_less_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1189 |
ceiling_less_eq_zero ~> ceiling_less_zero |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1190 |
ceiling_less_eq_one ~> ceiling_less_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1191 |
le_ceiling_eq_number_of ~> number_of_le_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1192 |
le_ceiling_eq_zero ~> zero_le_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1193 |
le_ceiling_eq_one ~> one_le_ceiling |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1194 |
ceiling_subtract_number_of ~> ceiling_diff_number_of |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1195 |
ceiling_subtract_one ~> ceiling_diff_one |
da7c06ab3169
remove several redundant lemmas about floor and ceiling
huffman
parents:
36972
diff
changeset
|
1196 |
|
37144 | 1197 |
* Theory "Finite_Set": various folding_XXX locales facilitate the |
36857 | 1198 |
application of the various fold combinators on finite sets. |
1199 |
||
1200 |
* Library theory "RBT" renamed to "RBT_Impl"; new library theory "RBT" |
|
1201 |
provides abstract red-black tree type which is backed by "RBT_Impl" as |
|
1202 |
implementation. INCOMPATIBILTY. |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
36096
diff
changeset
|
1203 |
|
36830 | 1204 |
* 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
|
1205 |
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
|
1206 |
|
36829 | 1207 |
* Theory PReal, including the type "preal" and related operations, has |
1208 |
been removed. INCOMPATIBILITY. |
|
1209 |
||
37380 | 1210 |
* Real: new development using Cauchy Sequences. |
1211 |
||
37351 | 1212 |
* Split off theory "Big_Operators" containing setsum, setprod, |
1213 |
Inf_fin, Sup_fin, Min, Max from theory Finite_Set. INCOMPATIBILITY. |
|
36857 | 1214 |
|
1215 |
* Theory "Rational" renamed to "Rat", for consistency with "Nat", |
|
1216 |
"Int" etc. INCOMPATIBILITY. |
|
1217 |
||
37351 | 1218 |
* Constant Rat.normalize needs to be qualified. INCOMPATIBILITY. |
37143 | 1219 |
|
36857 | 1220 |
* New set of rules "ac_simps" provides combined assoc / commute |
1221 |
rewrites for all interpretations of the appropriate generic locales. |
|
1222 |
||
1223 |
* Renamed theory "OrderedGroup" to "Groups" and split theory |
|
1224 |
"Ring_and_Field" into theories "Rings" and "Fields"; for more |
|
1225 |
appropriate and more consistent names suitable for name prefixes |
|
1226 |
within the HOL theories. INCOMPATIBILITY. |
|
35050
9f841f20dca6
renamed OrderedGroup to Groups; split theory Ring_and_Field into Rings Fields
haftmann
parents:
35042
diff
changeset
|
1227 |
|
35084 | 1228 |
* Some generic constants have been put to appropriate theories: |
36857 | 1229 |
- less_eq, less: Orderings |
1230 |
- zero, one, plus, minus, uminus, times, abs, sgn: Groups |
|
1231 |
- inverse, divide: Rings |
|
35084 | 1232 |
INCOMPATIBILITY. |
1233 |
||
36857 | 1234 |
* More consistent naming of type classes involving orderings (and |
1235 |
lattices): |
|
35027
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1236 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1237 |
lower_semilattice ~> semilattice_inf |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1238 |
upper_semilattice ~> semilattice_sup |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1239 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1240 |
dense_linear_order ~> dense_linorder |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1241 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1242 |
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
|
1243 |
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
|
1244 |
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
|
1245 |
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
|
1246 |
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
|
1247 |
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
|
1248 |
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
|
1249 |
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
|
1250 |
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
|
1251 |
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
|
1252 |
pordered_ring ~> ordered_ring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1253 |
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
|
1254 |
pordered_semiring ~> ordered_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1255 |
|
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1256 |
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
|
1257 |
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
|
1258 |
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
|
1259 |
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
|
1260 |
ordered_field ~> linordered_field |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1261 |
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
|
1262 |
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
|
1263 |
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
|
1264 |
ordered_idom ~> linordered_idom |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1265 |
ordered_ring ~> linordered_ring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1266 |
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
|
1267 |
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
|
1268 |
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
|
1269 |
ordered_semidom ~> linordered_semidom |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1270 |
ordered_semiring ~> linordered_semiring |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1271 |
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
|
1272 |
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
|
1273 |
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
|
1274 |
|
36857 | 1275 |
The following slightly odd type classes have been moved to a |
37351 | 1276 |
separate theory Library/Lattice_Algebras: |
35032
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1277 |
|
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1278 |
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
|
1279 |
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
|
1280 |
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
|
1281 |
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
|
1282 |
lordered_ring ~> lattice_ring |
7efe662e41b4
separate library theory for type classes combining lattices with various algebraic structures
haftmann
parents:
35027
diff
changeset
|
1283 |
|
35027
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1284 |
INCOMPATIBILITY. |
ed7d12bcf8f8
more consistent naming of type classes involving orderings (and lattices) -- c.f. NEWS
haftmann
parents:
34974
diff
changeset
|
1285 |
|
36416 | 1286 |
* Refined field classes: |
36857 | 1287 |
- classes division_ring_inverse_zero, field_inverse_zero, |
1288 |
linordered_field_inverse_zero include rule inverse 0 = 0 -- |
|
1289 |
subsumes former division_by_zero class; |
|
1290 |
- numerous lemmas have been ported from field to division_ring. |
|
1291 |
INCOMPATIBILITY. |
|
36416 | 1292 |
|
1293 |
* Refined algebra theorem collections: |
|
36857 | 1294 |
- dropped theorem group group_simps, use algebra_simps instead; |
1295 |
- dropped theorem group ring_simps, use field_simps instead; |
|
1296 |
- proper theorem collection field_simps subsumes former theorem |
|
1297 |
groups field_eq_simps and field_simps; |
|
1298 |
- dropped lemma eq_minus_self_iff which is a duplicate for |
|
1299 |
equal_neg_zero. |
|
1300 |
INCOMPATIBILITY. |
|
35009 | 1301 |
|
1302 |
* 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
|
1303 |
sets to lattices: |
e3daf3c07381
Subgoal.FOCUS (and variants): resulting goal state is normalized as usual for resolution;
wenzelm
parents:
34062
diff
changeset
|
1304 |
|
34007
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1305 |
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
|
1306 |
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
|
1307 |
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
|
1308 |
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
|
1309 |
Inter_fold_inter ~> Inf_fold_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1310 |
Union_fold_union ~> Sup_fold_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1311 |
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
|
1312 |
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
|
1313 |
INTER_fold_inter ~> INFI_fold_inf |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1314 |
UNION_fold_union ~> SUPR_fold_sup |
aea892559fc5
tuned lattices theory fragements; generlized some lemmas from sets to lattices
haftmann
parents:
33994
diff
changeset
|
1315 |
|
37351 | 1316 |
* Theory "Complete_Lattice": lemmas top_def and bot_def have been |
36416 | 1317 |
replaced by the more convenient lemmas Inf_empty and Sup_empty. |
1318 |
Dropped lemmas Inf_insert_simp and Sup_insert_simp, which are subsumed |
|
1319 |
by Inf_insert and Sup_insert. Lemmas Inf_UNIV and Sup_UNIV replace |
|
1320 |
former Inf_Univ and Sup_Univ. Lemmas inf_top_right and sup_bot_right |
|
1321 |
subsume inf_top and sup_bot respectively. INCOMPATIBILITY. |
|
1322 |
||
36857 | 1323 |
* Reorganized theory Multiset: swapped notation of pointwise and |
1324 |
multiset order: |
|
37351 | 1325 |
|
36857 | 1326 |
- pointwise ordering is instance of class order with standard syntax |
1327 |
<= and <; |
|
1328 |
- multiset ordering has syntax <=# and <#; partial order properties |
|
1329 |
are provided by means of interpretation with prefix |
|
1330 |
multiset_order; |
|
1331 |
- less duplication, less historical organization of sections, |
|
1332 |
conversion from associations lists to multisets, rudimentary code |
|
1333 |
generation; |
|
1334 |
- use insert_DiffM2 [symmetric] instead of elem_imp_eq_diff_union, |
|
1335 |
if needed. |
|
37351 | 1336 |
|
36903 | 1337 |
Renamed: |
37351 | 1338 |
|
1339 |
multiset_eq_conv_count_eq ~> multiset_ext_iff |
|
1340 |
multi_count_ext ~> multiset_ext |
|
1341 |
diff_union_inverse2 ~> diff_union_cancelR |
|
1342 |
||
36857 | 1343 |
INCOMPATIBILITY. |
36416 | 1344 |
|
36903 | 1345 |
* Theory Permutation: replaced local "remove" by List.remove1. |
1346 |
||
36416 | 1347 |
* Code generation: ML and OCaml code is decorated with signatures. |
1348 |
||
35009 | 1349 |
* Theory List: added transpose. |
1350 |
||
35810 | 1351 |
* Library/Nat_Bijection.thy is a collection of bijective functions |
1352 |
between nat and other types, which supersedes the older libraries |
|
1353 |
Library/Nat_Int_Bij.thy and HOLCF/NatIso.thy. INCOMPATIBILITY. |
|
1354 |
||
1355 |
Constants: |
|
1356 |
Nat_Int_Bij.nat2_to_nat ~> prod_encode |
|
1357 |
Nat_Int_Bij.nat_to_nat2 ~> prod_decode |
|
1358 |
Nat_Int_Bij.int_to_nat_bij ~> int_encode |
|
1359 |
Nat_Int_Bij.nat_to_int_bij ~> int_decode |
|
1360 |
Countable.pair_encode ~> prod_encode |
|
1361 |
NatIso.prod2nat ~> prod_encode |
|
1362 |
NatIso.nat2prod ~> prod_decode |
|
1363 |
NatIso.sum2nat ~> sum_encode |
|
1364 |
NatIso.nat2sum ~> sum_decode |
|
1365 |
NatIso.list2nat ~> list_encode |
|
1366 |
NatIso.nat2list ~> list_decode |
|
1367 |
NatIso.set2nat ~> set_encode |
|
1368 |
NatIso.nat2set ~> set_decode |
|
1369 |
||
1370 |
Lemmas: |
|
1371 |
Nat_Int_Bij.bij_nat_to_int_bij ~> bij_int_decode |
|
1372 |
Nat_Int_Bij.nat2_to_nat_inj ~> inj_prod_encode |
|
1373 |
Nat_Int_Bij.nat2_to_nat_surj ~> surj_prod_encode |
|
1374 |
Nat_Int_Bij.nat_to_nat2_inj ~> inj_prod_decode |
|
1375 |
Nat_Int_Bij.nat_to_nat2_surj ~> surj_prod_decode |
|
1376 |
Nat_Int_Bij.i2n_n2i_id ~> int_encode_inverse |
|
1377 |
Nat_Int_Bij.n2i_i2n_id ~> int_decode_inverse |
|
1378 |
Nat_Int_Bij.surj_nat_to_int_bij ~> surj_int_encode |
|
1379 |
Nat_Int_Bij.surj_int_to_nat_bij ~> surj_int_decode |
|
1380 |
Nat_Int_Bij.inj_nat_to_int_bij ~> inj_int_encode |
|
1381 |
Nat_Int_Bij.inj_int_to_nat_bij ~> inj_int_decode |
|
1382 |
Nat_Int_Bij.bij_nat_to_int_bij ~> bij_int_encode |
|
1383 |
Nat_Int_Bij.bij_int_to_nat_bij ~> bij_int_decode |
|
1384 |
||
36929 | 1385 |
* Sledgehammer: |
1386 |
- Renamed ATP commands: |
|
1387 |
atp_info ~> sledgehammer running_atps |
|
1388 |
atp_kill ~> sledgehammer kill_atps |
|
1389 |
atp_messages ~> sledgehammer messages |
|
1390 |
atp_minimize ~> sledgehammer minimize |
|
1391 |
print_atps ~> sledgehammer available_atps |
|
1392 |
INCOMPATIBILITY. |
|
1393 |
- Added user's manual ("isabelle doc sledgehammer"). |
|
1394 |
- Added option syntax and "sledgehammer_params" to customize |
|
1395 |
Sledgehammer's behavior. See the manual for details. |
|
1396 |
- Modified the Isar proof reconstruction code so that it produces |
|
1397 |
direct proofs rather than proofs by contradiction. (This feature |
|
1398 |
is still experimental.) |
|
1399 |
- Made Isar proof reconstruction work for SPASS, remote ATPs, and in |
|
1400 |
full-typed mode. |
|
1401 |
- Added support for TPTP syntax for SPASS via the "spass_tptp" ATP. |
|
1402 |
||
36928 | 1403 |
* Nitpick: |
1404 |
- Added and implemented "binary_ints" and "bits" options. |
|