Skip to content

Releases: leanprover/lean4-nightly

nightly-2024-12-15

15 Dec 08:33
a8a160b
Compare
Choose a tag to compare
nightly-2024-12-15 Pre-release
Pre-release

Changes since nightly-2024-12-14:

Full commit log

  • a8a160b fix: revertAll must clear auxiliary declarations (#6386)
  • e08d35c fix: type incorrect term produced by contradiction (#6387)
  • 94641e8 fix: simp_all? local declarations (#6385)
  • b721c0f test: add test for issue #4585 (#6384)
  • f790b19 fix: new code generator must generate code for opaque declarations that are not @[extern] (#6383)
  • 6571bc0 fix: withTrackingZetaDelta must reset cache (#6381)
  • 37122c3 chore: move implementation details of mergeSort into namespace (#6380)

nightly-2024-12-14

14 Dec 08:37
280fcc9
Compare
Choose a tag to compare
nightly-2024-12-14 Pre-release
Pre-release

Changes since nightly-2024-12-13:

Full commit log

  • 280fcc9 feat: lean --error=kind (#6362)
  • 19eac5f fix: propagate Simp.Config when reducing terms and checking definitional equality in simp (#6123)
  • aa00725 chore: stop running compiler twice during tests (#6321)
  • 7530fd6 chore: remove Lean.Compiler.LCNF.ForEachExpr (#6313)
  • 58ffd15 doc: fix typo reference in doc of lazy discrimination tree (#6377)

nightly-2024-12-13

13 Dec 08:36
bac34c7
Compare
Choose a tag to compare
nightly-2024-12-13 Pre-release
Pre-release

Changes since nightly-2024-12-12:

Full commit log

  • bac34c7 feat: theorems about == on Vector (#6376)
  • db354d2 chore: run Batteries linter on Lean (#6364)
  • 945abe0 fix: unused let_fun elimination in simp (#6375)

nightly-2024-12-12

12 Dec 08:38
48be424
Compare
Choose a tag to compare
nightly-2024-12-12 Pre-release
Pre-release

Changes since nightly-2024-12-11:

Full commit log

  • 48be424 feat: lemmas about Vector.any/all/set (#6369)
  • 58f8e21 feat: labeled and unique sorries (#5757)
  • a64a17e feat: Nat.shiftRight_bitwise_distrib (#6334)
  • b862e2d chore: preserve reported messages in MessageLog (#6307)

nightly-2024-12-11

11 Dec 08:35
8709ca3
Compare
Choose a tag to compare
nightly-2024-12-11 Pre-release
Pre-release

Changes since nightly-2024-12-10:

Full commit log

  • 8709ca3 chore: DecidableRel allows a heterogeneous relation (#6341)
  • 19fb1fb feat: do not propagate pretty printer errors through messages (#3696)
  • cb31ddc feat: lemmas about indexing and membership for Vector (#6367)
  • 633c825 feat: add Float32 support (#6366)
  • c83ce02 feat: alignment of Array.set lemmas with List lemmas (#6365)
  • cd909b0 fix: when pretty printing constant names, do not use aliases from "non-API exports" (#5689)
  • d27c5af refactor: ArgsPacker.unpack to return Option (#6359)
  • 9386511 refactor: elabWFRel to take names, not PreDefinition (#6358)
  • a9b6a9a refactor: WF.EqnInfo.hasInduct (#6357)
  • d5b565e refactor: make mkInhabitantFor error message configurable (#6356)
  • 27c2323 chore: alignment of Array.any/all lemmas with List (#6353)
  • 1786539 feat: BitVec.[toInt|toFin|getMsbD]_ofBool (#6317)
  • a805946 chore: adjust CODEOWNERS (#6327)

nightly-2024-12-10

10 Dec 08:37
Compare
Choose a tag to compare
nightly-2024-12-10 Pre-release
Pre-release

Changes since nightly-2024-12-09:

Full commit log

  • 8a3a806 chore: update stage0
  • 5c333ef fix: Float32 runtime support (#6350)
  • e69bcb0 chore: improve BitVec ext lemmas (#6349)
  • c5b82e0 feat: BitVec.[toFin|getMsbD]_setWidth and [getMsbD|msb]_signExtend (#6338)
  • b6177ba chore: update stage0
  • 2e11b8a feat: add support for Float32 to the Lean runtime (#6348)
  • ff3d12c doc: clarify difference between Expr.hasLooseBVars and Expr.hasLooseBVar (#6344)
  • 520d4b6 chore: cleanup of Array lemmas (#6343)
  • c7b8c5c chore: alignment of Array and List lemmas (#6342)

nightly-2024-12-09

09 Dec 08:35
3f79193
Compare
Choose a tag to compare
nightly-2024-12-09 Pre-release
Pre-release

Changes since nightly-2024-12-08:

Full Changelog: leanprover/lean4@v4.13.0...v4.14.0

Language features, tactics, and metaprograms

  • structure and inductive commands

    • #5517 improves universe level inference for the resulting type of an inductive or structure. Recall that a Prop-valued inductive type is a syntactic subsingleton if it has at most one constructor and all the arguments to the constructor are in Prop. Such types have large elimination, so they could be defined in Type or Prop without any trouble. The way inference has changed is that if a type is a syntactic subsingleton with exactly one constructor, and the constructor has at least one parameter/field, then the inductive/structure command will prefer creating a Prop instead of a Type. The upshot is that the : Prop in structure S : Prop is often no longer needed. (With @arthur-adjedj).
    • #5842 and #5783 implement a feature where the structure command can now define recursive inductive types:
      structure Tree where
        n : Nat
        children : Fin n → Tree
      
      def Tree.size : Tree → Nat
        | {n, children} => Id.run do
          let mut s := 0
          for h : i in [0 : n] do
            s := s + (children ⟨i, h.2⟩).size
          pure s
    • #5814 fixes a bug where Mathlib's Type* elaborator could lead to incorrect universe parameters with the inductive command.
    • #3152 and #5844 fix bugs in default value processing for structure instance notation (with @arthur-adjedj).
    • #5399 promotes instance synthesis order calculation failure from a soft error to a hard error.
    • #5542 deprecates := variants of inductive and structure (see breaking changes).
  • Application elaboration improvements

    • #5671 makes @[elab_as_elim] require at least one discriminant, since otherwise there is no advantage to this alternative elaborator.
    • #5528 enables field notation in explicit mode. The syntax @x.f elaborates as @S.f with x supplied to the appropriate parameter.
    • #5692 modifies the dot notation resolution algorithm so that it can apply CoeFun instances. For example, Mathlib has Multiset.card : Multiset α →+ Nat, and now with m : Multiset α, the notation m.card resolves to ⇑Multiset.card m.
    • #5658 fixes a bug where 'don't know how to synthesize implicit argument' errors might have the incorrect local context when the eta arguments feature is activated.
    • #5933 fixes a bug where .. ellipses in patterns made use of optparams and autoparams.
    • #5770 makes dot notation for structures resolve using all ancestors. Adds a resolution order for generalized field notation. This is the order of namespaces visited during resolution when trying to resolve names. The algorithm to compute a resolution order is the commonly used C3 linearization (used for example by Python), which when successful ensures that immediate parents' namespaces are considered before more distant ancestors' namespaces. By default we use a relaxed version of the algorithm that tolerates inconsistencies, but using set_option structure.strictResolutionOrder true makes inconsistent parent orderings into warnings.
  • Recursion and induction principles

    • #5619 fixes functional induction principle generation to avoid over-eta-expanding in the preprocessing step.
    • #5766 fixes structural nested recursion so that it is not confused when a nested type appears first.
    • #5803 fixes a bug in functional induction principle generation when there are let bindings.
    • #5904 improves functional induction principle generation to unfold aux definitions more carefully.
    • #5850 refactors code for Predefinition.Structural.
  • Error messages

    • #5276 fixes a bug in "type mismatch" errors that would structurally assign metavariables during the algorithm to expose differences.
    • #5919 makes "type mismatch" errors add type ascriptions to expose differences for numeric literals.
    • #5922 makes "type mismatch" errors expose differences in the bodies of functions and pi types.
    • #5888 improves the error message for invalid induction alternative names in match expressions (@josojo).
    • #5719 improves calc error messages.
  • #5627 and #5663 improve the #eval command and introduce some new features.

    • Now results can be pretty printed if there is a ToExpr instance, which means hoverable output. If ToExpr fails, it then tries looking for a Repr or ToString instance like before. Setting set_option eval.pp false disables making use of ToExpr instances.
    • There is now auto-derivation of Repr instances, enabled with the pp.derive.repr option (default to true). For example:
      inductive Baz
      | a | b
      
      #eval Baz.a
      -- Baz.a
      It simply does deriving instance Repr for Baz when there's no way to represent Baz.
    • The option eval.type controls whether or not to include the type in the output. For now the default is false.
    • Now expressions such as #eval do return 2, where monad is unknown, work. It tries unifying the monad with CommandElabM, TermElabM, or IO.
    • The classes Lean.Eval and Lean.MetaEval have been removed. These each used to be responsible for adapting monads and printing results. Now the MonadEval class is responsible for adapting monads for evaluation (it is similar to MonadLift, but instances are allowed to use default data when initializing state), and representing results is handled through a separate process.
    • Error messages about failed instance synthesis are now more precise. Once it detects that a MonadEval class applies, then the error message will be specific about missing ToExpr/Repr/ToString instances.
    • Fixes bugs where evaluating MetaM and CoreM wouldn't collect log messages.
    • Fixes a bug where let rec could not be used in #eval.
  • partial definitions

    • #5780 improves the error message when partial fails to prove a type is inhabited. Add delta deriving.
    • #5821 gives partial inhabitation the ability to create local Inhabited instances from parameters.
  • New tactic configuration syntax. The configuration syntax for all core tactics has been given an upgrade. Rather than simp (config := { contextual := true, maxSteps := 22}), one can now write simp +contextual (maxSteps := 22). Tactic authors can migrate by switching from (config)? to optConfig in tactic syntaxes and potentially deleting mkOptionalNode in elaborators. #5883, #5898, #5928, and #5932. (Tactic authors, see breaking changes.)

  • simp tactic

    • #5632 fixes the simpproc for Fin literals to reduce more consistently.
    • #5648 fixes a bug in simpa ... using t where metavariables in t were not properly accounted for, and also improves the type mismatch error.
    • #5838 fixes the docstring of simp! to actually talk about simp!.
    • #5870 adds support for attribute [simp ←] (note the reverse direction). This adds the reverse of a theorem as a global simp theorem.
  • decide tactic

    • #5665 adds decide! tactic for using kernel reduction (warning: this is renamed to decide +kernel in a future release).
  • bv_decide tactic

    • #5714 adds inequality regression tests (@alexkeizer).
    • #5608 adds bv_toNat tag for toNat_ofInt (@bollu).
    • #5618 adds support for at in ac_nf and uses it in bv_normalize (@tobiasgrosser).
    • #5628 adds udiv support.
    • #5635 adds auxiliary bitblasters for negation and subtraction.
    • #5637 adds more getLsbD bitblaster theory.
    • #5652 adds umod support.
    • #5653 adds performance benchmark for modulo.
    • #5655 reduces error on bv_check to warning.
    • [#5670...
Read more

nightly-2024-12-08

08 Dec 08:35
4dd182c
Compare
Choose a tag to compare
nightly-2024-12-08 Pre-release
Pre-release

Changes since nightly-2024-12-07:

Full commit log

  • 4dd182c chore: remove deprecated aliases for Int.tdiv and Int.tmod (#6322)
  • 762c575 doc: missing (type := true) in reader monad example (#6196)

nightly-2024-12-07

07 Dec 08:16
Compare
Choose a tag to compare
nightly-2024-12-07 Pre-release
Pre-release

Changes since nightly-2024-12-06:

Full commit log

  • 6447fda feat: FunInd: omit unused parameters (#6330)
  • 279f36b chore: update stage0
  • d2853ec feat: FunInd: omit unused parameters (#6330)

nightly-2024-12-06

06 Dec 08:34
6e60d13
Compare
Choose a tag to compare
nightly-2024-12-06 Pre-release
Pre-release

Changes since nightly-2024-12-05:

Full commit log

  • 6e60d13 feat: getElem lemmas for Vector operations (#6324)