-
Notifications
You must be signed in to change notification settings - Fork 1.1k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[new release] alt-ergo (4 packages) (2.6.0) #26609
Merged
Merged
Conversation
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
CHANGES: ### Command-line interface - Enable FPA theory by default (OCamlPro/alt-ergo#1177) - Remove deprecated output channels (OCamlPro/alt-ergo#782) - Deprecate the --use-underscore since it produces models that are not SMT-LIB compliant (OCamlPro/alt-ergo#805) - Add --dump-models-on to dump models on a specific output channel (OCamlPro/alt-ergo#838) - Use consistent return codes (OCamlPro/alt-ergo#842) - Add --continue-on-error flag to set the SMT-LIB error behavior (OCamlPro/alt-ergo#853) - Make dolmen the default value for the --frontend option (OCamlPro/alt-ergo#857) - Restore functionality to broken `--profiling` option (OCamlPro/alt-ergo#947) - Add bare-bones support for interactive input in SMT-LIB format (OCamlPro/alt-ergo#949) - Less confusing behavior on timeout (OCamlPro/alt-ergo#982, OCamlPro/alt-ergo#984) - Add `--strict` option for SMT-LIB compliant mode (OCamlPro/alt-ergo#916, OCamlPro/alt-ergo#1133) - Deprecate `sum`, `typing` and `warnings` debug flags (OCamlPro/alt-ergo#1204) ### SMT-LIB support - Add support for the many new SMT-LIB commands (OCamlPro/alt-ergo#837, OCamlPro/alt-ergo#848, OCamlPro/alt-ergo#852, OCamlPro/alt-ergo#863, OCamlPro/alt-ergo#911, OCamlPro/alt-ergo#942, OCamlPro/alt-ergo#945, OCamlPro/alt-ergo#961, OCamlPro/alt-ergo#975, OCamlPro/alt-ergo#1069) - Expose the FPA rounding builtin in the SMT-LIB format (OCamlPro/alt-ergo#876, OCamlPro/alt-ergo#1135) - Allow changing the SAT solver using (set-option) (OCamlPro/alt-ergo#880) - Add support for the `:named` attribute (OCamlPro/alt-ergo#957) - Add support for quoted identifiers (OCamlPro/alt-ergo#909, OCamlPro/alt-ergo#972) - Add support for naming lemmas in SMT-LIB syntax (OCamlPro/alt-ergo#1141, OCamlPro/alt-ergo#1143) ### Model generation - Use post-solve SAT environment in model generation, fixing issues where incorrect models were generated (OCamlPro/alt-ergo#789) - Restore support for records in models (OCamlPro/alt-ergo#793) - Use abstract values instead of dummy values in models where the actual value does not matter (OCamlPro/alt-ergo#804, OCamlPro/alt-ergo#835) - Use fresh names for all abstract values to prevent accidental captures (OCamlPro/alt-ergo#811) - Add support for model generation with the default CDCL solver (OCamlPro/alt-ergo#829) - Support model generation for the BV theory (OCamlPro/alt-ergo#841, OCamlPro/alt-ergo#968) - Add support for optimization (MaxSMT / OptiSMT) with lexicographic Int and Real objectives (OCamlPro/alt-ergo#861, OCamlPro/alt-ergo#921) - Add a SMT-LIB printer for expressions (OCamlPro/alt-ergo#952, OCamlPro/alt-ergo#981, OCamlPro/alt-ergo#1082, OCamlPro/alt-ergo#931, OCamlPro/alt-ergo#932) - Ensure models have a value for all constants in the problem (OCamlPro/alt-ergo#1019) - Fix a rare soundness issue with integer constraints when model generation is enabled (OCamlPro/alt-ergo#1025) - Support model generation for the ADT theory (OCamlPro/alt-ergo#1093, OCamlPro/alt-ergo#1153) ### Theory reasoning - Add word-level propagators for the BV theory (OCamlPro/alt-ergo#944, OCamlPro/alt-ergo#1004, OCamlPro/alt-ergo#1007, OCamlPro/alt-ergo#1010, OCamlPro/alt-ergo#1011, OCamlPro/alt-ergo#1012, OCamlPro/alt-ergo#1040, OCamlPro/alt-ergo#1044, OCamlPro/alt-ergo#1054, OCamlPro/alt-ergo#1055, OCamlPro/alt-ergo#1056, OCamlPro/alt-ergo#1057, OCamlPro/alt-ergo#1065, OCamlPro/alt-ergo#1073, OCamlPro/alt-ergo#1144, OCamlPro/alt-ergo#1152) - Add interval domains and arithmetic propagators for the BV theory (OCamlPro/alt-ergo#1058, OCamlPro/alt-ergo#1083, OCamlPro/alt-ergo#1084, OCamlPro/alt-ergo#1085) - Native support for bv2nat of bit-vector normal forms (OCamlPro/alt-ergo#1154) - Fix incompleteness issues in the BV solver (OCamlPro/alt-ergo#978, OCamlPro/alt-ergo#979) - Abstract more arguments of AC symbols to avoid infinite loops when they contain other AC symbols (OCamlPro/alt-ergo#990) - Do not make irrelevant decisions in CDCL solver, improving performance slightly (OCamlPro/alt-ergo#1041) - Rewrite the ADT theory to use domains and integrate the enum theory into the ADT theory (OCamlPro/alt-ergo#1078, OCamlPro/alt-ergo#1086, OCamlPro/alt-ergo#1087, OCamlPro/alt-ergo#1091, OCamlPro/alt-ergo#1094, OCamlPro/alt-ergo#1138) - Rewrite the Intervals module entirely (OCamlPro/alt-ergo#1108) - Add maximize/minimize terms for matching (OCamlPro/alt-ergo#1166) - Internalize `sign_extend` and `repeat` (OCamlPro/alt-ergo#1192) - Run cross-propagators to completion (OCamlPro/alt-ergo#1221) - Support binary distinct on arbitrary bit-widths (OCamlPro/alt-ergo#1222) - Only perform optimization when building a model (OCamlPro/alt-ergo#1224) - Make sure domains do not overflow the default domain (OCamlPro/alt-ergo#1225) - Do not build unnormalized values in `zero_extend` (OCamlPro/alt-ergo#1226) ### Internal/library changes - Rewrite the Vec module (OCamlPro/alt-ergo#607) - Move printer definitions closer to type definitions (OCamlPro/alt-ergo#808) - Mark proxy names as reserved (OCamlPro/alt-ergo#836) - Use a Zarith-based representation for numbers and bit-vectors (OCamlPro/alt-ergo#850, OCamlPro/alt-ergo#943) - Add native support for (bvnot) in the BV solver (OCamlPro/alt-ergo#856) - Add constant propagators for partially interpreted functions (OCamlPro/alt-ergo#869) - Remove `Util.failwith` in favor of `Fmt.failwith` (OCamlPro/alt-ergo#872) - Add more `Expr` smart constructors (OCamlPro/alt-ergo#877, OCamlPro/alt-ergo#878) - Do not use existential variables for integer division (OCamlPro/alt-ergo#881) - Preserve `Subst` literals to prevent accidental incompleteness (OCamlPro/alt-ergo#886) - Properly start timers (OCamlPro/alt-ergo#924) - Compute a concrete representation of a model instead of performing (OCamlPro/alt-ergo#925) - Allow direct access to the SAT API in the Alt-Ergo library computations during printing (OCamlPro/alt-ergo#927) - Better handling for step limit (OCamlPro/alt-ergo#936) - Add a generic option manager to deal with the dolmen state (OCamlPro/alt-ergo#951) - Expose an imperative SAT API in the Alt-Ergo library (OCamlPro/alt-ergo#962) - Keep track of the SMT-LIB mode (OCamlPro/alt-ergo#971) - Add ability to decide on semantic literals (OCamlPro/alt-ergo#1027, OCamlPro/alt-ergo#1118) - Preserve trigger order when parsing quantifiers with multiple trigger (OCamlPro/alt-ergo#1046). - Store domains inside the union-find module (OCamlPro/alt-ergo#1119) - Remove some polymorphic hashtables (OCamlPro/alt-ergo#1219) ### Build and integration - Drop support for OCaml <4.08.1 (OCamlPro/alt-ergo#803) - Use dune-site for the inequalities plugins. External pluginsm ust now be registered through the dune-site plugin mechanism in the `(alt-ergo plugins)` site to be picked up by Alt-Ergo (OCamlPro/alt-ergo#1049). - Add a release workflow (OCamlPro/alt-ergo#827) - Add a Windows workflow (OCamlPro/alt-ergo#1203) - Mark the dune.inc file as linguist-generated to avoid huge diffs (OCamlPro/alt-ergo#830) - Use GitHub Actions badges in the README (OCamlPro/alt-ergo#882) - Use `dune build @check` to build the project (OCamlPro/alt-ergo#887) - Enable warnings as errors on the CI (OCamlPro/alt-ergo#888) - Uniformization of internal identifiers generation (OCamlPro/alt-ergo#905, OCamlPro/alt-ergo#918) - Use an efficient `String.starts_with` implementation (OCamlPro/alt-ergo#912) - Fix the Makefile (OCamlPro/alt-ergo#914) - Add `Logs` dependency (OCamlPro/alt-ergo#1206) - Use `dynamic_include` to include the generated file `dune.inc` (OCamlPro/alt-ergo#1199) - Support Windows (OCamlPro/alt-ergo#1184,OCamlPro/alt-ergo#1189,OCamlPro/alt-ergo#1195,OCamlPro/alt-ergo#1199,OCamlPro/alt-ergo#1200) - Wrap the library `Alt_ergo_prelude` (OCamlPro/alt-ergo#1223) ### Testing - Use --enable-assertions in tests (OCamlPro/alt-ergo#809) - Add a test for push/pop (OCamlPro/alt-ergo#843) - Use the CDCL solver when testing model generation (OCamlPro/alt-ergo#938) - Do not test .smt2 files with the legacy frontend (OCamlPro/alt-ergo#939) - Restore automatic creation of .expected files (OCamlPro/alt-ergo#941) ### Documentation - Add a new example for model generation (OCamlPro/alt-ergo#826) - Add a Pygments lexer for the Alt-Ergo native language (OCamlPro/alt-ergo#862) - Update the current authors (OCamlPro/alt-ergo#865) - Documentation of the `Enum` theory (OCamlPro/alt-ergo#871) - Document `Th_util.lit_origin` (OCamlPro/alt-ergo#915) - Document the CDCL-Tableaux solver (OCamlPro/alt-ergo#995) - Document Windows support (OCamlPro/alt-ergo#1216) - Remove instructions to install Alt-Ergo on Debian (OCamlPro/alt-ergo#1217) - Document optimization feature (OCamlPro/alt-ergo#1231)
Dependencies should be fixed now. The Frama-C reverse-dependency failures seem unrelated. One mentions:
and the other:
|
Thanks, the remain issues are unrelated. It's not the first time I see those failures, I think they are related to some concurrency bug while installing certain libraries with deopots |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
The Alt-Ergo SMT prover
CHANGES:
Command-line interface
compliant (Deprecate the option --use-underscore OCamlPro/alt-ergo#805)
--profiling
option (fix: Make --profiling not crash OCamlPro/alt-ergo#947)--strict
option for SMT-LIB compliant mode (feat: Option --optimize OCamlPro/alt-ergo#916, fix(CLI): Remove--optimize
option in favor of--strict
OCamlPro/alt-ergo#1133)sum
,typing
andwarnings
debug flags (Deprecate debug flags OCamlPro/alt-ergo#1204)SMT-LIB support
Make get_value sound by not stating a formula is false when it is absent from the environment OCamlPro/alt-ergo#942, feat: Steps on :all-statistics command OCamlPro/alt-ergo#945, Fixed get-value OCamlPro/alt-ergo#961, Print unknown reason in SMT-LIB syntax OCamlPro/alt-ergo#975, fix(smt-lib): Respect
reproducible-resource-limit
specification OCamlPro/alt-ergo#1069)set-option
OCamlPro/alt-ergo#880):named
attribute (Dolmen named formulae OCamlPro/alt-ergo#957)Model generation
incorrect models were generated (Use post-solve SAT environment for model generation OCamlPro/alt-ergo#789)
actual value does not matter (Replace dummy values in Model by abstract values OCamlPro/alt-ergo#804, Use a separated counter for abstract value OCamlPro/alt-ergo#835)
lexicographic Int and Real objectives (feat: OptimAE OCamlPro/alt-ergo#861, Clean up OptimAE OCamlPro/alt-ergo#921)
Expr
OCamlPro/alt-ergo#952, Simplify numerical expressions in SMT-LIB printers OCamlPro/alt-ergo#981, feat(BV): Display BV constants using hexadecimal OCamlPro/alt-ergo#1082, Fix issue 926 OCamlPro/alt-ergo#931, Bubble printing model OCamlPro/alt-ergo#932)enabled (fix(arith): Do not overly tighten bounds over infinite domains OCamlPro/alt-ergo#1025)
Theory reasoning
Congruence
andConstraints
OCamlPro/alt-ergo#1010,fix(BV): Actually propagate freshness change OCamlPro/alt-ergo#1011, feat: Count steps for constraint propagation OCamlPro/alt-ergo#1012, cleanup(CP): Simplify constraint handling OCamlPro/alt-ergo#1040, CP: Support for domains on non-leaves OCamlPro/alt-ergo#1044, feat(BV,CP): Use a FIFO queue for constraint propagation OCamlPro/alt-ergo#1054, feat(BV,CP): Ephemeral API for domain updates OCamlPro/alt-ergo#1055, feat(BV,CP): Explicit constraint simplification OCamlPro/alt-ergo#1056, feat(BV): Generic constraint representation OCamlPro/alt-ergo#1057, fix(CP): Do not add unnecessary explanations to domains OCamlPro/alt-ergo#1065, fix(BV): Properly set fully interpreted operators OCamlPro/alt-ergo#1073, feat(BV): Do not store width in Bitlist OCamlPro/alt-ergo#1144,
feat(BV): Only store domains on variable parts OCamlPro/alt-ergo#1152)
feat(BV, CP): Propagators for addition and multiplication OCamlPro/alt-ergo#1083, feat(BV, CP): Add propagators for bvudiv and bvurem OCamlPro/alt-ergo#1084, feat(BV, CP): Add propagators for bvshl and bvlshr OCamlPro/alt-ergo#1085)
they contain other AC symbols (fix(AC): Abstract AC arguments that contain other AC symbols OCamlPro/alt-ergo#990)
performance slightly (feat(CDCL-Tableaux): Do not make irrelevant decisions OCamlPro/alt-ergo#1041)
ADT theory (Refactoring
Enum_rel
using domains on class representatives only OCamlPro/alt-ergo#1078, ADT destructors are delayed functions OCamlPro/alt-ergo#1086, RefactoringAdt_rel
using domains on class representatives only OCamlPro/alt-ergo#1087, Fix soudness bug in Enum OCamlPro/alt-ergo#1091, MergeEnum
theory intoADT
theory OCamlPro/alt-ergo#1094, Case splits on enum domains OCamlPro/alt-ergo#1138)sign_extend
andrepeat
(fix(BV): Internalize sign_extend and repeat OCamlPro/alt-ergo#1192)zero_extend
(fix(BV): Do not build unnormalized values in zero_extend OCamlPro/alt-ergo#1226)Internal/library changes
Util.failwith
in favor ofFmt.failwith
(RemoveUtil.failwith
OCamlPro/alt-ergo#872)Expr
smart constructors (Use ZArith convention for~$
and~$$
OCamlPro/alt-ergo#877, AddExpr
constructors for theReals
SMT-LIB theory OCamlPro/alt-ergo#878)Subst
literals to prevent accidental incompleteness (PreserveSubst
literals OCamlPro/alt-ergo#886)during printing (SAT API avaiable without process_decl in Frontend OCamlPro/alt-ergo#927)
(fix(dolmen): Preserve trigger order OCamlPro/alt-ergo#1046).
Build and integration
registered through the dune-site plugin mechanism in the
(alt-ergo plugins)
site to be picked up by Alt-Ergo (feat(plugins): Use dune-site for inequalities plugins OCamlPro/alt-ergo#1049).dune build @check
to build the project (Usingdune build @check
to build the project OCamlPro/alt-ergo#887)String.starts_with
implementation (Use efficientString.starts_with
implementation OCamlPro/alt-ergo#912)all
of the Makefile OCamlPro/alt-ergo#914)Logs
dependency (MinimalLogs
integration OCamlPro/alt-ergo#1206)dynamic_include
to include the generated filedune.inc
(Usedynamic_include
to include the generated file dune.inc OCamlPro/alt-ergo#1199)gen_link_flags
in OCaml OCamlPro/alt-ergo#1189,Do not use lock file for all OCaml versions OCamlPro/alt-ergo#1195,Usedynamic_include
to include the generated file dune.inc OCamlPro/alt-ergo#1199,Ignore :reproducible-resource-limit on non-Unix plateform OCamlPro/alt-ergo#1200)Alt_ergo_prelude
(Wrap the library Alt_ergo_prelude OCamlPro/alt-ergo#1223)Testing
Documentation
Enum
theory (Documentation of the Enum theory OCamlPro/alt-ergo#871)Th_util.lit_origin
(DocumentTh_util.lit_origin
OCamlPro/alt-ergo#915)