Documentation

Mathlib.Algebra.FreeMonoid.Count

List.count as a bundled homomorphism #

In this file we define FreeMonoid.countP, FreeMonoid.count, FreeAddMonoid.countP, and FreeAddMonoid.count. These are List.countP and List.count bundled as multiplicative and additive homomorphisms from FreeMonoid and FreeAddMonoid.

We do not use to_additive because it can't map Multiplicative to .

TODO #

There is lots of defeq abuse here of FreeAddMonoid α = List α, e.g. in statements like

theorem countP_apply (l : FreeAddMonoid α) : countP p l = List.countP p l := rfl

This needs cleaning up.

def FreeAddMonoid.countP {α : Type u_1} (p : αProp) [DecidablePred p] :

List.countP as a bundled additive monoid homomorphism.

Equations
Instances For
    theorem FreeAddMonoid.countP_of {α : Type u_1} (p : αProp) [DecidablePred p] (x : α) :
    (countP p) (of x) = if p x = (true = true) then 1 else 0
    theorem FreeAddMonoid.countP_apply {α : Type u_1} (p : αProp) [DecidablePred p] (l : FreeAddMonoid α) :
    (countP p) l = List.countP (fun (b : α) => decide (p b)) l
    def FreeAddMonoid.count {α : Type u_1} [DecidableEq α] (x : α) :

    List.count as a bundled additive monoid homomorphism.

    Equations
    Instances For
      theorem FreeAddMonoid.count_of {α : Type u_1} [DecidableEq α] (x y : α) :
      (count x) (of y) = Pi.single x 1 y
      theorem FreeAddMonoid.count_apply {α : Type u_1} [DecidableEq α] (x : α) (l : FreeAddMonoid α) :
      (count x) l = List.count x l

      List.countP as a bundled multiplicative monoid homomorphism.

      Equations
      Instances For
        theorem FreeMonoid.countP_of' {α : Type u_1} (p : αProp) [DecidablePred p] (x : α) :
        (countP p) (of x) = if p x then Multiplicative.ofAdd 1 else Multiplicative.ofAdd 0
        theorem FreeMonoid.countP_of {α : Type u_1} (p : αProp) [DecidablePred p] (x : α) :
        (countP p) (of x) = if p x then Multiplicative.ofAdd 1 else 1
        theorem FreeMonoid.countP_apply {α : Type u_1} (p : αProp) [DecidablePred p] (l : FreeAddMonoid α) :
        (countP p) l = Multiplicative.ofAdd (List.countP (fun (b : α) => decide (p b)) l)

        List.count as a bundled additive monoid homomorphism.

        Equations
        Instances For
          theorem FreeMonoid.count_apply {α : Type u_1} [DecidableEq α] (x : α) (l : FreeAddMonoid α) :
          (count x) l = Multiplicative.ofAdd (List.count x l)
          theorem FreeMonoid.count_of {α : Type u_1} [DecidableEq α] (x y : α) :
          (count x) (of y) = Pi.mulSingle x (Multiplicative.ofAdd 1) y