Leonardo de Moura
4134fdd925
feat(library/blast/strategies/rec_strategy): give priority to user defined recursors
2015-12-31 14:55:00 -08:00
Leonardo de Moura
76677c4535
feat(library/blast/actions/assert_cc_action): add target_cc_action
2015-12-31 14:53:55 -08:00
Leonardo de Moura
fdcdfbf385
feat(library/blast/simplifier/simplifier_actions): only add symplified hypothesis if it is not "true"
2015-12-31 14:25:38 -08:00
Leonardo de Moura
b35abcc6a8
refactor(library): rename strategy "msimp" ==> "inst_simp"
...
"inst_simp" means "instantiate simplification lemmas"
The idea is to make it clear that this strategy is *not* a simplifier.
2015-12-31 12:45:48 -08:00
Leonardo de Moura
4cf5c77575
feat(library/blast/strategies): add strategy for applying recursors
2015-12-31 12:35:16 -08:00
Leonardo de Moura
20b585c432
feat(library/blast/forward/ematch): use blast.event.ematch for ematch module abnormal behavior
2015-12-31 12:28:22 -08:00
Leonardo de Moura
935a2536ec
fix(library/blast/actions/recursor_action): must normalize target for each subgoal
2015-12-31 12:25:17 -08:00
Leonardo de Moura
ba2cdc848a
feat(library/util, library/pp_options): add pp.goal.max_hypotheses
...
This commit also renames pp.compact_goals ==> pp.goal.compact
2015-12-30 12:43:03 -08:00
Leonardo de Moura
23836f53bb
feat(library/blast): do not display inactive hypotheses when displaying failure states
2015-12-30 12:08:33 -08:00
Leonardo de Moura
f2d4e81889
fix(library/blast/state): inactive hypotheses should be printed "after" active ones
2015-12-30 11:46:41 -08:00
Leonardo de Moura
2a454ce791
chore(library/blast/state): do not display set of active hypotheses
...
This is just "noise" in error messages
2015-12-30 11:31:59 -08:00
Leonardo de Moura
dc6a3e30c0
refactor(library): test simp and msimp in the standard library
2015-12-30 11:22:58 -08:00
Leonardo de Moura
251b53c669
refactor(library/blast/strategies): rename 'debug_action_strategy' to 'action_strategy'
...
Now, we can also provide a "name" for tracing purposes when
instantiating action_strategy.
2015-12-29 20:45:24 -08:00
Leonardo de Moura
41a01bb606
feat(library/blast/forward/ematch): add option 'blast.ematch.max_instances'
2015-12-29 20:36:11 -08:00
Leonardo de Moura
0148bb08fd
feat(library/blast): add 'ematch_simp' strategy for blast and msimp
shortcut for it.
...
This strategy is based on ematching and congruence closure, but it uses
the [simp] lemmas instead of [forward] lemmas.
2015-12-29 20:04:31 -08:00
Leonardo de Moura
8c87f90a29
feat(frontends/lean/elaborator): avoid redudant "don't know how to synthesize placeholder" when using flycheck
2015-12-29 18:00:19 -08:00
Leonardo de Moura
86a5379a96
feat(library/blast): include strategies failure states in the tactic_exception
...
Reason: better flycheck error messages
2015-12-29 17:14:55 -08:00
Leonardo de Moura
b92416d66c
refactor(library/error_handling): move error_handling to library main dir
2015-12-29 15:31:40 -08:00
Leonardo de Moura
3557bd36e7
refactor(library/algebra/group): cleanup proofs using simp and add [simp] attribute
2015-12-29 10:48:47 -08:00
Leonardo de Moura
b117a10f82
refactor(library/blast/simplifier): use priority_queue to store simp/congr lemmas, use name convention used at forward/backward lemmas, normalize lemmas when blast starts, cache get_simp_lemmas
2015-12-28 17:52:57 -08:00
Leonardo de Moura
5b7dc31ad1
chore(library/blast/backward): remove unnecessary include
2015-12-28 14:26:18 -08:00
Leonardo de Moura
079a25f770
refactor(library/blast/forward): make sure backward and forward modules use same naming convention
2015-12-28 12:37:16 -08:00
Leonardo de Moura
482ffe4242
fix(library/attribute_manager): memory leak
2015-12-28 12:31:38 -08:00
Leonardo de Moura
c8b9c98eb6
refactor(library/blast/backward): use priority_queue, make sure head is normalized when building index
2015-12-28 12:26:06 -08:00
Leonardo de Moura
26d0a62052
refactor(*): make sure we use LEAN_DEFAULT_PRIORITY
...
We recently implemented the attribute manager.
2015-12-28 10:47:56 -08:00
Leonardo de Moura
f177082c3b
refactor(*): normalize metaclass names
...
@avigad and @fpvandoorn, I changed the metaclasses names. They
were not uniform:
- The plural was used in some cases (e.g., [coercions]).
- In other cases a cryptic name was used (e.g., [brs]).
Now, I tried to use the attribute name as the metaclass name whenever
possible. For example, we write
definition foo [coercion] ...
definition bla [forward] ...
and
open [coercion] nat
open [forward] nat
It is easier to remember and is uniform.
2015-12-28 10:39:15 -08:00
Leonardo de Moura
96bec8b4f9
fix(frontends/lean/builtin_cmds): allow token and metaclass to have the same name
2015-12-28 09:57:45 -08:00
Leonardo de Moura
89a5d00714
chore(library/blast): style
2015-12-28 09:08:18 -08:00
Leonardo de Moura
f679ce0da9
refactor(frontends/lean): move 'print_cmd' to separate module
2015-12-28 09:08:18 -08:00
Leonardo de Moura
cac10aa728
fix(frontends/lean/parser): allow '...' token to be used in imports
...
Before this commit, we could not write
import ...foo.b
We had to write
import .. .foo.b
or
import . ..foo.b
2015-12-28 09:08:18 -08:00
Leonardo de Moura
2a5a904416
feat(library/blast/discr_tree): remove hack for setting m_fn flag
2015-12-28 09:08:18 -08:00
Leonardo de Moura
93b912ec89
feat(library/blast): use discrimination trees instead of head_map for indexing hypotheses
2015-12-28 09:08:18 -08:00
Leonardo de Moura
1f1fafd535
feat(library/blast/discr_tree): erase operation
2015-12-28 09:08:18 -08:00
Leonardo de Moura
45c29d422f
feat(library/blast/discr_tree): set edge m_fn flag
2015-12-28 09:08:18 -08:00
Leonardo de Moura
43e1292f22
feat(library/blast): add discrimination trees
2015-12-28 09:08:17 -08:00
Jeremy Avigad
dc8cad10bf
feat(src/emacs/README.md): add header
2015-12-22 16:39:13 -05:00
Jeremy Avigad
68ecdc4c26
feat(src/emacs/README.md): expand instructions slightly
2015-12-22 16:39:13 -05:00
Soonho Kong
f911747b60
fix(util/file_lock.cpp): add 'include <fcntl.h>'
...
@wizardbc found that this is needed while working on lean.js.
I think it's because of the use of O_CREAT in open system call.
Related issue: leanprover/lean.js#10
2015-12-19 07:51:00 -05:00
Soonho Kong
c5223d2d19
fix(emacs/load-lean.el): proceed even if logo image is not created
...
On OSX + emacs-24.5, pgm file is not supported in the terminal.
This patch ignores the error and does not show the Lean logo if it fails to create one.
2015-12-18 14:29:51 -05:00
Leonardo de Moura
a7d1625765
fix(library/blast/forward/forward_lemma_set): check pattern inference when setting attribute
2015-12-17 22:50:14 -08:00
Leonardo de Moura
9a6bd96d6b
chore(frontends/lean/decl_attributes): style
2015-12-17 22:50:01 -08:00
Leonardo de Moura
40b7cf3ad4
chore(frontends/lean): remove unnecessary tokens
2015-12-17 22:35:12 -08:00
Leonardo de Moura
128b557d37
refactor(frontends/lean): use attribute_manager to simplify decl_attributes
2015-12-17 22:28:53 -08:00
Leonardo de Moura
d81b2d0f29
feat(library/attribute_manager, frontends/lean/builtin_cmds): use attribute manager information when pretty print definitions
2015-12-17 21:16:31 -08:00
Leonardo de Moura
45dbf76df9
refactor(library): add attribute manager
2015-12-17 20:58:15 -08:00
Floris van Doorn
da5f10ce63
feat(hott): minor fixes. allow the usage of numerals for trunc_index
2015-12-17 12:46:16 -08:00
Leonardo de Moura
61ecf018e9
feat(frontends/lean,library/tactic): add easy tactic parsing support for at ...
and with ...
2015-12-17 12:18:32 -08:00
Leonardo de Moura
c824a0e050
chore(library,hott): enforce naming conventions
2015-12-17 11:36:58 -08:00
Leonardo de Moura
2502039a5c
fix(frontends/lean/parser): tactic notation that may take numerical parameters
2015-12-17 11:27:31 -08:00
Leonardo de Moura
70f71a18c8
doc(library/type_context): explain why we need tmp_local_generator
2015-12-15 18:58:07 -08:00
Leonardo de Moura
73b28c91a6
fix(library/type_context): local constant management bug
2015-12-15 18:49:26 -08:00
Leonardo de Moura
1387cdfa0f
feat(library/type_context): add eta-expansion to type_context
2015-12-15 17:24:53 -08:00
Leonardo de Moura
10273bf176
feat(library/blast/forward/pattern): improve pattern inference heuristic
2015-12-15 12:55:43 -08:00
Leonardo de Moura
c07345d47f
fix(util/file_lock): handle permission denied at lock creation
...
see #925
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
2015-12-15 09:48:20 -08:00
Rob Lewis
ec5990f4de
fix(library/norm_num): fix incorrect assert
2015-12-14 14:09:54 -05:00
Leonardo de Moura
521657914c
chore(util/file_lock): style
2015-12-14 10:20:33 -08:00
Sebastian Ullrich
2185ee7e95
feat(library/tactic): make let tactic transparent, introduce new opaque note tactic
...
The new let tactic is semantically equivalent to let terms, while `note`
preserves its old opaque behavior.
2015-12-14 10:14:02 -08:00
Leonardo de Moura
31c9a76777
feat(util/file_lock): add support for Windows
...
Remark: the lock are not being erased on Windows.
I tried different solutions based on MoveFileEx and DeleteFile.
None of them worked. The one based on MoveFileEx
MoveFileEx(m_fname.c_str(), NULL, MOVEFILE_DELAY_UNTIL_REBOOT);
seems to delete the file after REBOOT.
But, this is not very useful.
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
2015-12-14 10:07:26 -08:00
Leonardo de Moura
95fba3dba6
chore(library/constants): sort constant decls
2015-12-13 21:39:45 -08:00
Leonardo de Moura
193a9d8cde
refactor(library/norm_num): avoid manual constant name initialization
...
@rlewis1988 We group all Lean constants used in the C++ code at
src/library/constants.txt
Jeremy and Floris check this file before renaming constants in the
library. So, they can quickly decide whether C++ code will be affected
or not.
We also have a python script for initializing the C++ name objects.
To use the script:
- go to src/library
- execute
python ../../script/gen_constants_cpp.py constants.txt
It will create the boring initialization and finalization code, and
declare a procedure get_<id>_name() for each constant in the file constants.txt.
I also move the norm_num1.lean to the set of unit tests that are
executed whenever we push a commit to the main branch.
I found an assertion violation at line 606. Could you take a look?
Best,
Leo
2015-12-13 21:38:59 -08:00
Leonardo de Moura
e3a35ba4fd
feat(frontends/lean): add 'with_attributes' tactical
...
closes #494
2015-12-13 18:27:44 -08:00
Leonardo de Moura
727a4f5a3a
feat(library/tactic/intros_tactic): use '_' to say that some names are irrelevant in the intro tactic
...
See #695
2015-12-13 16:47:31 -08:00
Leonardo de Moura
d4e49a8434
feat(library/tactic/intros_tactic): intro without argument should introduce a single variable
...
see #695
2015-12-13 16:28:39 -08:00
Leonardo de Moura
894875dc5c
feat(library/tactic/congruence_tactic): closes #855
2015-12-13 15:03:25 -08:00
Leonardo de Moura
999f23cbc0
feat(kernel/expr_eq_fn): take names into account when CompareBinderInfo is true
...
This is the correct fix for the id declaration pretty printing
discrepancy reported by Daniel.
TODO: decide whether we need another eq-mode where names are ignored.
For example, in blast, it makes sense to increase sharing by ignoring
binder names.
2015-12-13 14:47:11 -08:00
Leonardo de Moura
ce622e9179
feat(frontends/lean): add auto-include for structures and inductive decls
2015-12-13 13:39:34 -08:00
Leonardo de Moura
20de22a8ad
feat(frontends/lean): automatically include anonymous instance implicit variables/parameters (whenever their parameters have been included)
2015-12-13 13:20:54 -08:00
Leonardo de Moura
9a4a12899a
fix(frontends/lean/pp): make sure pp doesn't group [] arguments
2015-12-13 12:23:22 -08:00
Leonardo de Moura
a9b567296c
feat(frontends/lean/parser): add anonymous inst implicit name generator
2015-12-13 11:46:48 -08:00
Leonardo de Moura
d26a83da02
feat(frontends/lean/parser): allow anonymous instance implicit arguments
2015-12-13 11:46:48 -08:00
Leonardo de Moura
edad31a9b1
feat(shell/lean): use locking also for the index file
2015-12-12 21:50:08 -08:00
Leonardo de Moura
4dc3764a02
feat(util,library,shell): basic locking mechanism
...
We still have to test on Windows.
see issue #925
2015-12-12 21:26:13 -08:00
Leonardo de Moura
b7de10a6d2
feat(library/trace): allow user to disable subclasses of a trace class
...
Example:
set_option trace.blast true -- enables trace.blast class and all subclasses
set_option trace.blast.action false -- disables the given subclass
Result: all blast classes are traced but blast.action
2015-12-11 11:03:16 -08:00
Leonardo de Moura
7f1800962a
feat(frontends/lean/pp): allow user to override pp.all setting
...
see #922
2015-12-11 10:40:48 -08:00
Leonardo de Moura
ac0bd539b0
feat(frontends/lean/notation_cmd): allow 'abstract ... end' to be used in notation declarations
...
helps #825
2015-12-11 09:55:27 -08:00
Leonardo de Moura
eda26a9099
fix(emacs/lean-company): candidate fix for #846
2015-12-11 08:12:43 -08:00
Daniel Selsam
2b1e7e7759
feat(frontends/lean/pp): all disables numerals
2015-12-10 23:31:40 -08:00
Leonardo de Moura
abbb2cfbbd
feat(library/export): take binder labels into account when max-sharing expression during .olean generation
2015-12-10 23:27:44 -08:00
Leonardo de Moura
3057dde885
fix(library/class,library/coercion): fixes #852
2015-12-10 22:52:02 -08:00
Leonardo de Moura
cf61adc5d5
feat(frontends/lean): identifiers starting with '_' are now reserved
2015-12-10 22:32:03 -08:00
Leonardo de Moura
7b29ee1666
fix(library/tactic/induction_tactic): fixes #892
2015-12-10 10:52:57 -08:00
Leonardo de Moura
8094ca1c70
fix(library/blast/backward): crash when pretty printing backward rule set
...
We make sure it doesn't depend on the blast state.
2015-12-10 10:38:53 -08:00
Leonardo de Moura
1abaa9eb71
fix(frontends/lean/parser): fixes #858
2015-12-10 10:31:14 -08:00
Leonardo de Moura
8b3cbb8fdd
fix(library/tactic/induction_tactic): apply substitution to hypothesis type (it may contain metavars)
...
closes #876
2015-12-10 10:11:55 -08:00
Leonardo de Moura
c9ff175cf4
fix(library/tactic/induction_tactic): fixes #893
2015-12-10 10:11:55 -08:00
Leonardo de Moura
1f8de7b50b
feat(library/blast): refine trace messages
2015-12-09 18:38:20 -08:00
Leonardo de Moura
34e85be970
feat(library/blast): add 'blast.deadend' tracing option
2015-12-09 17:45:36 -08:00
Leonardo de Moura
1502248d30
feat(library/blast): trace strategy name
2015-12-09 17:13:28 -08:00
Leonardo de Moura
725101c777
chore(frontends/lean): cleaup
2015-12-09 12:43:44 -08:00
Floris van Doorn
46739c8b70
feat(hott/algebra): port abstract structures
2015-12-09 12:34:06 -08:00
Leonardo de Moura
6abf2fd975
feat(library/blast/congruence_closure): avoid unnecessary propagations in the congruence closure module
2015-12-09 12:17:51 -08:00
Leonardo de Moura
6bbbc3d50e
feat(library/blast): improve trace messages
2015-12-09 11:38:39 -08:00
Leonardo de Moura
a7f5d6603a
feat(library/blast/actions/recursor_action): trace recursor name
2015-12-09 11:25:05 -08:00
Leonardo de Moura
3f9549485f
feat(frontends/lean/parser): restore config options in the end of sections/namespaces
2015-12-09 11:24:37 -08:00
Leonardo de Moura
f9a669665a
feat(library/blast/backward/backward_action): display lemma name in backward action
2015-12-09 11:07:53 -08:00
Leonardo de Moura
cbc3c0cf4f
feat(frontends/lean): suppress profiling information for declarations that take less than 0.01 secs to be processed
2015-12-09 10:48:36 -08:00
Leonardo de Moura
0acdcd487b
feat(frontends/lean): add 'print aliases' command
2015-12-09 10:39:40 -08:00
Leonardo de Moura
53a05e845e
chore(library/blast/trace): fix style
2015-12-09 09:35:46 -08:00
Leonardo de Moura
fbaa3e13ab
chore(library/blast/simplifier/simplifier): use '-->' for tracing a rewrite
2015-12-09 08:06:05 -08:00
Leonardo de Moura
6b91505c0e
feat(library/blast/trace): improve trace depth
2015-12-09 08:04:02 -08:00
Leonardo de Moura
e9d6326b88
feat(library/blast/trace): do not show common prefix between states when tracing
2015-12-09 07:55:12 -08:00
Leonardo de Moura
c1a4e0ee4f
feat(library/blast): trace target
2015-12-09 07:34:15 -08:00
Leonardo de Moura
36f3549c44
fix(library/blast/blast): make sure blast uses the given ios options for tracing
...
They might have been updated using the with_options tactic
2015-12-09 07:21:18 -08:00
Leonardo de Moura
a3346e997b
fix(library/class_instance_resolution): signature has changed
2015-12-09 07:14:39 -08:00
Leonardo de Moura
c6fc18a8d1
chore(library/blast/simplifier/simplifier): remove "dead" field
2015-12-09 07:13:54 -08:00
Leonardo de Moura
aed0c7cccf
chore(library/blast/state): trace msg
2015-12-09 07:13:19 -08:00
Leonardo de Moura
08052c1988
feat(library/blast): improve tracing
2015-12-08 19:53:25 -08:00
Leonardo de Moura
429527eb72
refactor(library/blast): move to new tracing infrastructure
2015-12-08 19:37:06 -08:00
Leonardo de Moura
370f9a6eec
fix(library/trace): use null output channel when trace environment is not set
...
This is important when multiple threads are being used, and the trace
environment is not set for a child thread
2015-12-08 18:37:57 -08:00
Leonardo de Moura
3c1f49de8f
fix(library/io_state): typo
2015-12-08 18:28:54 -08:00
Leonardo de Moura
78533cde0a
chore(library/blast/blast): reorg blast tracing
2015-12-08 15:57:25 -08:00
Leonardo de Moura
f0c42defc8
feat(library/blast/grinder): add tracing for suspicious event
2015-12-08 15:53:43 -08:00
Leonardo de Moura
81b093271d
fix(library/io_state_stream): option kind when pretty printing
2015-12-08 15:48:10 -08:00
Leonardo de Moura
34b944a71e
refactor(frontends/lean): remove broken 'migrate' command
2015-12-08 15:40:49 -08:00
Leonardo de Moura
b145a7332a
feat(library/blast/congruence_closure): use new tracing infrastructure
2015-12-08 15:18:21 -08:00
Leonardo de Moura
7da64a768f
refactor(library/type_context): with the new tracing infrastructure, type_context doesn't need an io_state
2015-12-08 14:58:08 -08:00
Leonardo de Moura
58ab526d44
feat(library/type_context): use new tracing infrastructure in new type class resolution procedure
2015-12-08 14:34:20 -08:00
Leonardo de Moura
9b69ccd2f8
feat(library/app_builder): add trace messages to app_builder
2015-12-08 13:43:15 -08:00
Leonardo de Moura
9df10a4048
feat(library): add tracing messages to app_builder and congr_lemma_manager
2015-12-08 13:36:11 -08:00
Leonardo de Moura
e5a6bc5b85
feat(library/blast/simplifier/simplifier): move to new tracing framework
2015-12-08 12:59:30 -08:00
Leonardo de Moura
6b1469264d
feat(library/trace): add new tracing infrastructure
2015-12-08 11:58:03 -08:00
Leonardo de Moura
a2ef818ff3
chore(*): remove old tracing framework
2015-12-08 09:06:10 -08:00
Leonardo de Moura
50df6b5698
feat(frontends/lean): rename '[intro]' ==> '[intro!]' and '[backward]' ==> '[intro]'
2015-12-07 21:33:35 -08:00
Leonardo de Moura
041c1cbb17
feat(library/blast): add strategies "grind" and "core_grind"
2015-12-07 20:30:59 -08:00
Leonardo de Moura
be99d5f26f
fix(library/blast/strategies/preprocess_strategy): do not show failure state again
2015-12-07 19:31:34 -08:00
Leonardo de Moura
6bfc22de11
feat(library/blast/grinder): add grinder strategy
2015-12-07 19:09:10 -08:00
Leonardo de Moura
eefc57af2f
feat(library/blast/grinder): add grinder actions
2015-12-07 18:43:15 -08:00
Leonardo de Moura
48bc18d492
feat(library/blast/grinder/intro_elim_lemmas): add intro/elim lemmas validation
2015-12-07 18:43:15 -08:00
Leonardo de Moura
295b1d21f5
feat(frontends/lean): add '[intro]' and '[elim]' annotations
2015-12-07 18:43:15 -08:00
Leonardo de Moura
5f5e4fe7fb
feat(library/blast/grinder): add intro/elim lemmas
2015-12-07 18:43:12 -08:00
Leonardo de Moura
e417581e4c
feat(util): add priority_queue
2015-12-07 17:05:01 -08:00
Leonardo de Moura
c3b5ce0785
feat(frontends/lean/builtin_cmds): show metavariable arguments when pretty printing patterns
2015-12-07 12:39:51 -08:00
Daniel Selsam
18f224c420
fix(library/blast/actions/simple_actions): fix assert
2015-12-07 12:32:22 -08:00
Daniel Selsam
a9aeb69789
feat(frontends/lean/builtin_cmds): print metas for patterns
2015-12-07 12:32:22 -08:00
Leonardo de Moura
121648dda6
fix(library/congr_lemma_manager): issue with reducible annotation when generating congruence lemmas
2015-12-07 12:09:30 -08:00
Leonardo de Moura
f31553d916
feat(library/blast/strategies/portfolio): add more strategies for debugging purposes
2015-12-07 11:59:21 -08:00
Leonardo de Moura
54c0921bbb
feat(library/blast/forward/pattern): consider patterns with nested lambdas in the pattern inference procedure
2015-12-07 10:39:42 -08:00
Leonardo de Moura
752f027705
chore(library/blast/state): style
2015-12-07 09:48:00 -08:00
Leonardo de Moura
f5fcd12f3f
feat(library/blast/simplifier/simplifier): use pretty printer when generating tracing messages
2015-12-07 09:46:28 -08:00
Leonardo de Moura
85379b7706
feat(library/blast/actions/simple_actions): make sure contradiction action works even if classical logic support is not enabled
...
not (not (not a)) -> not a
2015-12-07 09:30:14 -08:00
Leonardo de Moura
3c66e65a63
feat(library/blast/strategies/portfolio): throw exception for unknown strategy
2015-12-07 09:27:48 -08:00
Leonardo de Moura
d7fda94686
fix(library/blast/strategies/portfolio): typo
2015-12-07 08:47:14 -08:00
Leonardo de Moura
c7390684ba
feat(library/blast/strategies/portfolio): add 'unit' strategy for testing unit propagation
2015-12-07 08:45:54 -08:00
Leonardo de Moura
964bb140be
feat(library/blast): add 'blast.trace_preprocessor'
2015-12-07 08:38:11 -08:00
Leonardo de Moura
2d007c7c23
feat(library/blast/simplifier/simp_rule_set): rename metaclass to '[simps]'
...
The previous name [rrs] was too cryptic.
2015-12-06 20:49:27 -08:00
Leonardo de Moura
1eb28b842e
feat(library/blast/simplifier): add eta-reduction to simplifier
2015-12-06 20:41:25 -08:00
Leonardo de Moura
7eb1525ba5
feat(shell/lean): add option '--debug=tag' for activating conditional assertions in the command line in debug mode
2015-12-06 15:47:26 -08:00
Leonardo de Moura
b7c96722c7
perf(util/rb_tree): mark check_invariant as a conditional/tagged assertion
...
This assertion is proportional to the tree size. So, it is too expensive
to check when we import many declarations.
2015-12-06 15:45:55 -08:00
Leonardo de Moura
4cd4b6236d
fix(library/tactic/with_options_tactic): make sure we can load the standard library containing the auxiliary macro options_expr with trust level 0
2015-12-06 15:17:10 -08:00
Leonardo de Moura
b044f9e8c1
feat(library/blast/strategies): add "ematch" strategy for testing ematching
2015-12-06 15:01:49 -08:00
Leonardo de Moura
67e291ac84
feat(library/blast/strategies): add strategy for testing congruence closure module
2015-12-06 14:33:21 -08:00
Leonardo de Moura
39dbbd687b
feat(library/blast/strategy): add 'orelse' combinator
2015-12-06 14:12:44 -08:00
Leonardo de Moura
732a92de05
feat(frontends/lean): add 'simp' as shortcut for 'with_options [blast.strategy "simp"] blast'
2015-12-06 13:14:04 -08:00
Leonardo de Moura
c105d2fe47
feat(library/blast): add simp strategies
2015-12-06 13:04:41 -08:00
Leonardo de Moura
80725cc416
fix(library): references to algebra in the source code
2015-12-05 23:50:26 -08:00
Leonardo de Moura
61b3c7c655
chore(library/blast): disable spurious style warnings
2015-12-05 21:48:50 -08:00
Leonardo de Moura
648f6c5f82
fix(library/blast/strategies): constructor action was being applied too soon
2015-12-05 19:44:07 -08:00
Leonardo de Moura
20d7727a9c
fix(library/blast/forward/pattern): pattern inference bug
2015-12-05 19:38:24 -08:00
Leonardo de Moura
aa998bfad3
fix(library/fun_info_manager): reducibility issue
2015-12-05 19:26:06 -08:00
Leonardo de Moura
6193816f6a
fix(library/tmp_type_context): bug at pop()
2015-12-05 19:14:33 -08:00
Leonardo de Moura
df567717f8
feat(library/blast/strategies): add 'blast.strategy "preprocess"'
2015-12-05 18:17:15 -08:00
Leonardo de Moura
11400edd4a
refactor(library/blast): blast strategy framework
2015-12-05 16:55:23 -08:00
Leonardo de Moura
eeae5d1b6c
feat(library/blast/options): add 'blast.strategy' option
2015-12-05 16:54:21 -08:00
Leonardo de Moura
6102938717
fix(library/blast/hypothesis): incorrect method being invoked
2015-12-05 16:53:47 -08:00
Leonardo de Moura
b409720ac7
feat(util/sexpr/option_declarations): add register_string_option
2015-12-05 16:53:16 -08:00
Leonardo de Moura
d7150f210c
fix(library/blast/trace): avoid unnecessary trace information
2015-12-05 16:52:41 -08:00
Leonardo de Moura
96b37241bd
feat(util/list): add is_suffix_eqp
2015-12-05 16:52:18 -08:00
Leonardo de Moura
3b40b09a36
refactor(library/blast): rename strategy to strategy_fn
2015-12-05 13:25:20 -08:00
Leonardo de Moura
fa938bb94c
feat(frontends/lean/decl_cmds): allow modifier to be provided after the 'attribute' keyword, test 'at' keyword
2015-12-05 11:50:08 -08:00
Leonardo de Moura
07419617b0
fix(library/scoped_ext): assertion
2015-12-05 11:36:52 -08:00
Leonardo de Moura
e5aab3fd63
feat(library/scoped_ext,frontends/lean): add support for setting attributes into different namespaces
2015-12-05 11:15:02 -08:00
Daniel Selsam
08e0fc796b
feat(library/blast/actions): by_contradiction action
2015-12-04 20:19:05 -08:00
Leonardo de Moura
78b1749c2c
feat(library/blast): make sure blast can be interrupted
2015-12-04 18:44:04 -08:00
Daniel Selsam
a04c28d4c9
refactor(library/algebra): construct simplifier sets incrementally
2015-12-04 18:28:56 -08:00
Leonardo de Moura
2682fe9525
feat(library/blast/blast): force 'ne' to be always transparent
2015-12-04 18:24:36 -08:00
Leonardo de Moura
af01e7fea8
chore(library/blast): remove "leftover" file used in the old blast architecture
2015-12-04 17:34:56 -08:00
Leonardo de Moura
5da1b52e47
feat(library/blast/unit/unit_propagate): make sure unif_propagate works even if 'not' is marked as '[reducible]'
2015-12-04 16:49:21 -08:00
Leonardo de Moura
00e34683f2
feat(library/app_builder): (try to) address not-issue and other reducibility annotation related issues in the app_builder
2015-12-04 16:03:06 -08:00
Leonardo de Moura
a8b6a286dd
fix(library/app_builder): make sure app_builder works even if iff
is marked as reducible
2015-12-04 13:51:56 -08:00
Leonardo de Moura
93b17e2ec1
refactor(kernel/ext_exception): add ext_exception
...
Now, any exception that requires pretty printing support should be a
subclass of ext_exception
2015-12-04 13:22:42 -08:00
Leonardo de Moura
4bf9fc2cf5
refactor(library/blast): move simple_strategy to strategies folder
...
We will add more strategies in the future.
2015-12-04 11:46:56 -08:00
Leonardo de Moura
73622150a6
refactor(library/blast): move actions to actions folder
...
to make Daniel happy.
2015-12-04 10:00:04 -08:00
Leonardo de Moura
07cb35fd3c
fix(library/abstract_expr_manager): incorrect handling of de-Bruijn variables
2015-12-04 09:27:21 -08:00
Leonardo de Moura
769da9c95a
fix(library/unifier): missing occurs check
2015-12-04 09:14:55 -08:00
Leonardo de Moura
8c431bdb20
chore(library/blast/imp_extension): fix unused argument warning
2015-12-04 08:34:20 -08:00
Daniel Selsam
9689085834
fix(library/abstract_expr_manager): instantiate before calling mk_congr
2015-12-04 08:31:38 -08:00
Daniel Selsam
d729302718
fix(library/abstract_expr_manager): remove unnecessary include
2015-12-04 08:31:38 -08:00
Daniel Selsam
25a3cff54e
refactor(library/abstract_expr_manager): remove fun_info_manager
2015-12-04 08:31:38 -08:00
Daniel Selsam
7854158751
fix(library/abstract_expr_manager): only squash Cast subsingletons
2015-12-04 08:31:38 -08:00
Daniel Selsam
6e478696d2
feat(library/blast/unit): preprocessor placeholder
2015-12-04 08:30:04 -08:00
Daniel Selsam
0df4556eb5
feat(library/blast/unit): quantified and non-Prop facts
2015-12-04 08:30:03 -08:00
Daniel Selsam
c604333af2
fix(library/blast/unit): typo
2015-12-04 08:30:03 -08:00
Daniel Selsam
2bf9989bd9
refactor(library/blast/unit): simplify module
2015-12-04 08:30:03 -08:00
Leonardo de Moura
61db311227
chore(library/blast/imp_extension): style
2015-12-04 08:26:03 -08:00
Daniel Selsam
606e28ca99
refactor(library/blast/imp_extension): buffer instead of list
2015-12-04 08:22:46 -08:00
Daniel Selsam
601dc544b6
feat(library/blast/imp_extension): imperative branch extensions
2015-12-04 08:22:46 -08:00
Leonardo de Moura
83b9769225
fix(library/blast): init_classical_flag
...
The procedure get_namespaces does not return the set of opened
namespaces. I added a comment there to clarify that.
2015-12-04 08:13:19 -08:00
Daniel Selsam
0dfac6d07e
feat(library/blast): classical flag
2015-12-04 07:53:05 -08:00
Leonardo de Moura
fe020b49c1
chore(library/scoped_ext): add comment
2015-12-04 07:52:28 -08:00
Leonardo de Moura
6bbe72190d
fix(library/congr_lemma_manager): bug in congruence lemma generator
2015-12-03 14:21:30 -08:00
Leonardo de Moura
038369533e
fix(library/blast/recursor_action): indexed families
2015-12-02 23:43:15 -08:00
Leonardo de Moura
87995b96e3
fix(library/blast/congruence_closure): is_relation_app ==> is_equivalence_relation_app
2015-12-02 23:28:57 -08:00
Daniel Selsam
42dcbebd1c
fix(library/blast/forward/ematch): typo
2015-12-02 23:17:24 -08:00
Daniel Selsam
139536896c
feat(library/light_lt_manager): light wrappers for ordered rewriting
2015-12-02 22:56:54 -08:00
Daniel Selsam
c064f0cd82
fix(library/blast/simplifier/ceqv): typos
2015-12-02 22:56:00 -08:00
Daniel Selsam
aac50873fe
fix(library/num): fix memory leak
2015-12-02 22:55:18 -08:00
Leonardo de Moura
acb5b969c6
fix(library/blast/subst_action): missing occurs check
2015-12-02 22:52:55 -08:00
Leonardo de Moura
d2054bb65c
chore(library/blast): fix style
2015-12-02 22:52:55 -08:00
Leonardo de Moura
028ef47c84
feat(frontends/lean,library/blast/forward/pattern): check whether patterns can be inferred at declaration time
2015-12-02 22:52:55 -08:00
Leonardo de Moura
f84c6a6cfa
fix(library/blast,frontends/lean): handling pattern hints after unfolding
2015-12-02 22:52:55 -08:00
Leonardo de Moura
950f356d9a
refactor(library/blast,frontends/lean): forward pattern index
2015-12-02 22:52:55 -08:00
Leonardo de Moura
562d7b3e4a
feat(library/blast/blast): add support in blast for controlling whether macros are unfolded or not at whnf/normalize
2015-12-02 22:52:55 -08:00
Leonardo de Moura
24e4dbe353
feat(src/library/type_context): add support for preserving macros at type_context whnf
2015-12-02 22:52:55 -08:00
Leonardo de Moura
39429251c6
chore(library/blast/forward/ematch): fix style
2015-12-02 22:52:55 -08:00
Leonardo de Moura
af9180b35c
fix(library/blast/forward/qcf): compilation warning
2015-12-02 22:52:55 -08:00
Leonardo de Moura
a83a7f8356
feat(library/blast/forward/pattern): remove redundant multi-patterns
2015-12-02 22:52:55 -08:00
Leonardo de Moura
ec7c38d847
feat(library/blast/forward/pattern): add minimal pattern validation
2015-12-02 22:52:55 -08:00
Leonardo de Moura
72bd4a8f5a
fix(library/blast/options): typo
2015-12-02 22:52:54 -08:00
Leonardo de Moura
32ad59adc1
feat(library/blast/forward/ematch): add support for multi-patterns
2015-12-02 22:52:54 -08:00
Leonardo de Moura
9260be01b2
feat(library/blast): add blast.backward option for disabling/enabling backward chaining
2015-12-02 22:52:54 -08:00
Leonardo de Moura
a8bb4ba109
fix(library/blast/congruence_closure): bug in congruence closure proof extraction
2015-12-02 22:52:54 -08:00
Leonardo de Moura
08bb966581
feat(library/blast/forward/ematch): generate new instances
2015-12-02 22:52:54 -08:00
Leonardo de Moura
d5b2efc74f
feat(library/idx_metavar): add has_idx_metavar
2015-12-02 22:52:54 -08:00
Leonardo de Moura
4d63a27f13
feat(library/blast/forward/ematch): use type class resolution to infer missing arguments
2015-12-02 22:52:54 -08:00
Leonardo de Moura
37ad850455
fix(library/type_context): improve on_is_def_eq_failure
2015-12-02 22:52:54 -08:00
Leonardo de Moura
3d7831284b
fix(library/blast/forward/ematch): extract lemma using target expression instead of pattern
...
Reason: pattern contains temporary universe meta-variables.
2015-12-02 22:52:54 -08:00
Leonardo de Moura
9f3f24b46c
fix(src/library/blast/forward/ematch): use head_index at m_apps
2015-12-02 22:52:54 -08:00
Leonardo de Moura
2296168bda
feat(library/blast): add blast.ematch option, and ematching search procedure
2015-12-02 22:52:54 -08:00
Leonardo de Moura
4c624206f4
feat(library/blast/forward/pattern): save meta-variables
2015-12-02 22:52:54 -08:00
Leonardo de Moura
7fa2b7cace
feat(library/blast/forward/ematch): ematching skeleton
2015-12-02 22:52:54 -08:00
Leonardo de Moura
001f8084a9
chore(library/blast/forward/forward_extension): rename procedure
2015-12-02 22:52:54 -08:00
Leonardo de Moura
4129b398da
fix(frontends/lean/builtin_cmds): private constants in the print command
2015-12-02 22:52:54 -08:00
Leonardo de Moura
e4e9c30e66
fix(frontends/lean/builtin_cmds): print patterns
2015-12-02 22:52:54 -08:00
Leonardo de Moura
05477d34bb
fix(library/blast/forward/pattern): missing case
2015-12-02 22:52:54 -08:00
Leonardo de Moura
fdd442bd38
feat(frontends/lean/decl_attributes): turn on [forward]
if pattern hints have been provided
2015-12-02 22:52:54 -08:00
Soonho Kong
c75e037b3c
doc(emacs/README.md): mention issue 906 in Known Issues
...
see #906
[skip ci]
2015-12-02 17:37:10 -05:00
Soonho Kong
ff8f24a29b
fix(library/blast/backward/backward_rule_set.cpp): fully annotate the use of map2
...
Close #904
2015-12-01 13:42:25 -05:00
Leonardo de Moura
41ff4bc193
feat(library/blast/forward/pattern): pattern inference and heuristic instantiation index
2015-11-25 23:45:08 -08:00
Leonardo de Moura
0ceaf0b4fe
feat(frontends/lean/builtin_cmds): display '[forward]' annotation for heuristic instantiation lemmas
2015-11-25 17:53:13 -08:00
Leonardo de Moura
996a660de8
feat(library/blast): add is_hi_lemma
2015-11-25 17:52:59 -08:00
Leonardo de Moura
d395a54165
feat(frontends/lean): add '[forward]' annotation
2015-11-25 17:44:58 -08:00
Leonardo de Moura
2becc0367d
feat(library/blast/forward/pattern): add add_hi_lemma
2015-11-25 17:44:27 -08:00
Leonardo de Moura
87c31acf8c
feat(library/blast/forward/pattern): basic indexing for heuristic instantiation
2015-11-25 17:30:24 -08:00
Leonardo de Moura
30214af15c
fix(util/rb_multi_map): missing include
2015-11-25 14:26:08 -08:00
Leonardo de Moura
3335c1782d
feat(library/blast/forward/pattern): extract trackable and residue hypotheses
2015-11-25 13:43:27 -08:00
Leonardo de Moura
edd1b34143
doc(library/blast/forward/pattern): describe pattern inference heuristic
2015-11-25 11:57:30 -08:00
Daniel Selsam
ca71a2eb12
feat(library/blast/unit): conjunctive conclusions
2015-11-24 22:45:39 -08:00
Daniel Selsam
eac1ebbf72
feat(library/blast/unit): propagate clauses
2015-11-24 21:16:01 -08:00
Daniel Selsam
8f4bc7e0ba
fix(util/rb_multi_map): no duplicate values
2015-11-24 20:19:46 -08:00
Leonardo de Moura
c923120db5
feat(library/blast/congruence_closure): expose mk_ext_congr_lemma
2015-11-24 18:48:23 -08:00
Leonardo de Moura
651e3834ba
feat(library/blast/congruence_closure): allow meta-variables in the congruence closure module after partitions have been frozen
2015-11-24 18:48:23 -08:00
Leonardo de Moura
67a4cd3972
feat(frontends/lean): add print [no_pattern]
command
2015-11-24 18:48:22 -08:00
Leonardo de Moura
017abdfb6a
feat(frontends/lean): add notation for providing patterns
2015-11-24 18:48:22 -08:00
Leonardo de Moura
a2f43212d6
feat(frontends/lean): add '[no_pattern]' attribute
2015-11-24 18:48:22 -08:00
Leonardo de Moura
8c729d1620
feat(library/blast/forward): start 'pattern' module
2015-11-24 18:48:22 -08:00
Soonho Kong
27cec52770
doc(emacs/README.md): update unicode instructions
2015-11-24 11:30:33 -05:00
Jeremy Avigad
e8ee91f59d
refactor(src/emacs/README.md): clarify setup instructions
2015-11-23 22:05:41 -05:00
Leonardo de Moura
c50d7ac4b8
feat(library/blast/congruence_closure): add add/assume API
2015-11-23 15:21:28 -08:00
Leonardo de Moura
f0ccffe968
feat(library/blast/congruence_closure): track mod-time
2015-11-23 15:03:46 -08:00
Leonardo de Moura
712f60d003
feat(library/blast/congruence_closure): expose get_cc()
2015-11-23 14:41:22 -08:00
Leonardo de Moura
11f838c13a
perf(library/blast/congruence_closure): only copy parents that are still congruence roots
2015-11-23 14:38:31 -08:00
Leonardo de Moura
f4a7268bd7
fix(library/blast/congruence_closure): bug in add_eqv_step
2015-11-23 14:26:33 -08:00
Leonardo de Moura
f1a3f8ec9d
feat(library/blast/congruence_closure): add blast.trace_cc option
2015-11-23 14:24:59 -08:00
Daniel Selsam
46e60abda6
feat(library/blast/forward): branch extension
2015-11-23 13:58:13 -08:00
Daniel Selsam
a8700e6778
refactor(library/blast/unit): rename unit propagation module
2015-11-23 13:58:13 -08:00
Leonardo de Moura
20cfe9e02e
feat(library/blast/state): improve lazy initialization
2015-11-23 11:32:45 -08:00
Leonardo de Moura
3ee32c02d8
feat(library/blast/congruence_closure): add freeze_partitions API for qcf procedure
2015-11-23 11:26:15 -08:00
Leonardo de Moura
565a294489
fix(library/blast/congruence_closure): bug at is_congr_root
2015-11-23 11:25:58 -08:00
Floris van Doorn
c44ad80e4e
feat(homotopy/torus): give recursion and induction principle for the torus
...
also change the surface of the torus to a square instead of an equality between paths
2015-11-22 18:29:37 -08:00
Leonardo de Moura
8632b7ae27
chore(library/blast/backward/backward_strategy): remove unused param
2015-11-22 18:27:23 -08:00
Leonardo de Moura
b442fe66b2
chore(library/blast/simple_strategy): fix style
2015-11-22 18:24:59 -08:00
Leonardo de Moura
0fcf8ed7d2
refactor(library/blast): hypothesis activation protocol
2015-11-22 18:22:26 -08:00
Leonardo de Moura
1bd827dffc
feat(library/blast/simplifier/simplifier_actions): add simplify_hypothesis_action
2015-11-22 17:49:00 -08:00
Leonardo de Moura
8681b34129
fix(library/blast/simplifier/simplifier_actions): update target when simplifier produces a definitionally equal output that is not structurally equal
...
This update also uses the even target_updated to decide when the target
needs to be updated.
2015-11-22 17:25:54 -08:00
Leonardo de Moura
0c4fb6b3d5
feat(library/blast): add option 'blast.recursor' for disabling recursor action
2015-11-22 17:15:38 -08:00
Leonardo de Moura
56282a11f6
feat(library/blast/blast): use type_context normalizer
2015-11-22 17:04:04 -08:00
Leonardo de Moura
6b248f44eb
feat(library/blast): add option for showing the blast failure state
2015-11-22 16:32:07 -08:00
Leonardo de Moura
fc461ce832
feat(library/app_builder): avoid redundant proof terms at mk_of_iff_true and mk_not_of_iff_false
2015-11-22 15:49:17 -08:00
Leonardo de Moura
94f7b7f95d
feat(library/blast/congruence_closure): add support for propagating units in the congruence closure module
...
See blast_cc12.lean for example.
2015-11-22 15:39:44 -08:00
Leonardo de Moura
f326e731a0
fix(library/blast/subst_action): do not apply subst to (H : a = a), let the discard_action to get rid of it
2015-11-22 15:37:32 -08:00
Leonardo de Moura
6fc0e41439
fix(library/blast/congruence_closure): proof generation for congruences such as (a = b) <-> (b = a)
...
The congruence closure module treats these two terms as the same thing.
So, we should take this into account when building proofs
2015-11-21 19:50:59 -08:00
Leonardo de Moura
5e9914ef45
feat(library/blast/congruence_closure): avoid eq.rec if major premise is eq.refl
2015-11-21 19:00:16 -08:00
Leonardo de Moura
607552e51f
feat(library/blast): add target_updated event
2015-11-21 17:58:21 -08:00
Leonardo de Moura
091b0f0cc7
feat(library/blast): add option for disabling congruence closure
2015-11-21 17:45:25 -08:00
Leonardo de Moura
c4328aad3a
feat(library/blast/congruence_closure): missing case
2015-11-21 17:40:15 -08:00
Leonardo de Moura
c49caf3740
feat(library/blast/congruence_closure): add support for user-defined congruence lemmas in the congruence closure module
2015-11-21 14:43:51 -08:00
Leonardo de Moura
a61869ba1a
feat(library/blast): add option for disabling simplifier
2015-11-21 12:19:55 -08:00
Leonardo de Moura
85601c5a83
chore(library/blast/congruence_closure): fix style
2015-11-20 16:46:28 -08:00
Leonardo de Moura
8f368cebbf
feat(library/blast/congruence_closure): lift equalities
2015-11-20 13:48:22 -08:00
Leonardo de Moura
28970ef717
feat(library/blast/congruence_closure): proof extraction
2015-11-20 12:23:32 -08:00
Leonardo de Moura
1e3f549c39
feat(library/blast/subst_action): add option for disabling subst action
2015-11-20 10:53:02 -08:00
Leonardo de Moura
028a2ab785
feat(library/blast): add get_config()
2015-11-20 10:39:26 -08:00
Leonardo de Moura
c76b04719c
feat(library/app_builder): add lift_from_eq
2015-11-20 10:27:58 -08:00
Leonardo de Moura
f6ba746b03
chore(library/blast/trace): fix signature
2015-11-20 08:55:44 -08:00
Leonardo de Moura
ffacf70230
chore(library/io_state_stream): remove unused variable
2015-11-20 08:20:29 -08:00
Leonardo de Moura
628608ca7d
chore(library/blast/congruence_closure): fix style
2015-11-19 19:49:59 -08:00
Leonardo de Moura
d5b0a45aa4
chore(library/blast/simplifier/simplifier_actions): fix warnings
2015-11-19 19:47:04 -08:00
Daniel Selsam
21cb409e6c
refactor(library/blast/simplifier): move simplifier module into blast
2015-11-19 19:43:04 -08:00
Daniel Selsam
2c72f46adc
feat(library/blast/forward): opportunistically delete dead hypotheses
2015-11-19 19:40:40 -08:00
Leonardo de Moura
2d93fe4b76
feat(library/blast/congruence_closure): implement congruence closure
...
Proof extraction is still missing
2015-11-19 19:37:11 -08:00