Falling factorials
Content created by Fredrik Bakke, Jonathan Prieto-Cubides and Egbert Rijke.
Created on 2022-02-15.
Last modified on 2024-02-06.
module elementary-number-theory.falling-factorials where
Imports
open import elementary-number-theory.multiplication-natural-numbers open import elementary-number-theory.natural-numbers
Idea
The falling factorial (n)_m is the number n(n-1)⋯(n-m+1)
Definition
falling-factorial-ℕ : ℕ → ℕ → ℕ falling-factorial-ℕ zero-ℕ zero-ℕ = 1 falling-factorial-ℕ zero-ℕ (succ-ℕ m) = 0 falling-factorial-ℕ (succ-ℕ n) zero-ℕ = 1 falling-factorial-ℕ (succ-ℕ n) (succ-ℕ m) = (succ-ℕ n) *ℕ (falling-factorial-ℕ n m) {- Fin-falling-factorial-ℕ : (n m : ℕ) → Fin (falling-factorial-ℕ n m) ≃ (Fin m ↪ Fin n) Fin-falling-factorial-ℕ n m = {!!} -} {- Fin-falling-factorial-ℕ : (n m : ℕ) → Fin (falling-factorial-ℕ n m) ≃ (Fin m ↪ Fin n) Fin-falling-factorial-ℕ zero-ℕ zero-ℕ = equiv-is-contr ( is-contr-Fin-one-ℕ) ( is-contr-equiv ( is-emb id) ( left-unit-law-Σ-is-contr ( universal-property-empty' empty) ( id)) ( dependent-universal-property-empty' ( λ x → (y : empty) → is-equiv (ap id)))) Fin-falling-factorial-ℕ zero-ℕ (succ-ℕ m) = equiv-is-empty id (λ f → map-emb f (inr star)) Fin-falling-factorial-ℕ (succ-ℕ n) zero-ℕ = equiv-is-contr ( is-contr-Fin-one-ℕ) ( is-contr-equiv ( is-emb ex-falso) ( left-unit-law-Σ-is-contr ( universal-property-empty' (Fin (succ-ℕ n))) ( ex-falso)) ( dependent-universal-property-empty' ( λ x → (y : empty) → is-equiv (ap ex-falso)))) Fin-falling-factorial-ℕ (succ-ℕ n) (succ-ℕ m) = ( ( ( right-unit-law-Σ-is-contr { B = λ f → is-decidable (fiber (map-emb f) (inr star))} ( λ f → is-proof-irrelevant-is-prop ( is-prop-is-decidable ( is-prop-map-is-emb (is-emb-map-emb f) (inr star))) ( is-decidable-Σ-Fin ( λ x → has-decidable-equality-Fin (map-emb f x) (inr star))))) ∘e ( ( inv-equiv ( left-distributive-Σ-coproduct ( Fin (succ-ℕ m) ↪ Fin (succ-ℕ n)) ( λ f → fiber (map-emb f) (inr star)) ( λ f → ¬ (fiber (map-emb f) (inr star))))) ∘e {!!})) ∘e ( equiv-coproduct ( Fin-falling-factorial-ℕ n m) ( Fin-falling-factorial-ℕ n (succ-ℕ m)))) ∘e ( Fin-add-ℕ (falling-factorial-ℕ n m) (falling-factorial-ℕ n (succ-ℕ m))) -}
Recent changes
- 2024-02-06. Fredrik Bakke. Rename
(co)prod
to(co)product
(#1017). - 2023-09-11. Fredrik Bakke and Egbert Rijke. Some computations for different notions of equivalence (#711).
- 2023-05-13. Fredrik Bakke. Refactor to use infix binary operators for arithmetic (#620).
- 2023-05-01. Fredrik Bakke. Refactor 2, the sequel to refactor (#581).
- 2023-03-13. Jonathan Prieto-Cubides. More maintenance (#506).