Skip to content

Commit

Permalink
Some links in elementary number theory (#1199)
Browse files Browse the repository at this point in the history
Adds a bunch of links in elementary number theory and a little bit of
prose. Also fix capitalization of "MathWorld" with a capital "W".
  • Loading branch information
fredrik-bakke authored Oct 16, 2024
1 parent df14f7e commit c1a469f
Show file tree
Hide file tree
Showing 62 changed files with 334 additions and 120 deletions.
4 changes: 2 additions & 2 deletions src/elementary-number-theory/absolute-value-integers.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,8 +28,8 @@ open import foundation.unit-type

## Idea

The absolute value of an integer is the natural number with the same distance
from `0`.
The {{#concept "absolute value" Disambiguation="of an integer" Agda=abs-ℤ}} of
an integer is the natural number with the same distance from `0`.

## Definition

Expand Down
5 changes: 3 additions & 2 deletions src/elementary-number-theory/ackermann-function.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@ open import elementary-number-theory.natural-numbers

## Idea

The Ackermann function is a fast growing binary operation on the natural
numbers.
The
{{#concept "Ackermann function" WD="Ackermann function" WDID=Q341835 Agda=ackermann}}
is a fast growing binary operation on the natural numbers.

## Definition

Expand Down
21 changes: 19 additions & 2 deletions src/elementary-number-theory/binomial-coefficients.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,12 @@ open import univalent-combinatorics.standard-finite-types

## Idea

The binomial coefficient `(n choose k)` measures how many decidable subsets of
`Fin n` there are of size `k`.
The
{{#concept "binomial coefficient" WD="binomial coefficient" WDID=Q209875 Agda=binomial-coefficient-ℕ}}
`(n choose k)` measures
[how many decidable subsets](univalent-combinatorics.counting-decidable-subtypes.md)
of size `k` there are of a
[finite type](univalent-combinatorics.finite-types.md) of size `n`.

## Definition

Expand Down Expand Up @@ -68,3 +72,16 @@ is-one-on-diagonal-binomial-coefficient-ℕ (succ-ℕ n) =
( is-one-on-diagonal-binomial-coefficient-ℕ n)
( is-zero-binomial-coefficient-ℕ n (succ-ℕ n) (succ-le-ℕ n))
```

## See also

- [Binomial types](univalent-combinatorics.binomial-types.md)

## External links

- [Binomial coefficients](https://www.britannica.com/science/binomial-coefficient)
at Britannica
- [Binomial coefficient](https://en.wikipedia.org/wiki/Binomial_coefficient) at
Wikipedia
- [Binomial Coefficient](https://mathworld.wolfram.com/BinomialCoefficient.html)
at Wolfram MathWorld
67 changes: 64 additions & 3 deletions src/elementary-number-theory/catalan-numbers.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,15 +22,46 @@ open import univalent-combinatorics.standard-finite-types

## Idea

The Catalan numbers are a sequence of natural numbers that occur in several
combinatorics problems.
The
{{#concept "Catalan numbers" WD="Catalan number" WDID=Q270513 OEIS=A000108 Agda=catalan-numbers}}
$C_n$ is a [sequence](foundation.sequences.md) of
[natural numbers](elementary-number-theory.natural-numbers.md) that occur in
several combinatorics problems. The sequence starts

```text
n 0 1 2 3 4 5 6
Cₙ 1 1 2 5 14 42 132
```

The Catalan numbers may be defined by any of the formulas

1. $C_{n + 1} = \sum_{k = 0}^n C_k C_{n-k}$, with $C_0 = 1$,
2. $C_n = {2n \choose n} - {2n \choose n + 1}$,
3. $C_{n+1} = \frac{2(2n+1)}{n+2}C_n$, with $C_0 = 1$,
4. $C_{n} = \frac{1}{n+1}{2n \choose n}$,
5. $C_{n} = \frac{(2n)!}{(n+1)!n!}$.

Where $n \choose k$ are
[binomial coefficients](elementary-number-theory.binomial-coefficients.md) and
$n!$ is the [factorial function](elementary-number-theory.factorials.md).

## Definitions

### Inductive sum formula for the Catalan numbers

The Catalan numbers may be defined to be the sequence satisfying $C_0 = 1$ and
the recurrence relation

$$
C_{n + 1} = \sum_{k = 0}^n C_k C_{n-k}.
$$

```agda
catalan-numbers :
catalan-numbers =
strong-ind-ℕ (λ _ ℕ) (succ-ℕ zero-ℕ)
strong-ind-ℕ
( λ _ ℕ)
( 1)
( λ k C
sum-Fin-ℕ k
( λ i
Expand All @@ -45,10 +76,40 @@ catalan-numbers =
( nat-Fin k i)
( k)
( strict-upper-bound-nat-Fin k i))))))
```

### Binomial difference formula for the Catalan numbers

The Catalan numbers may be computed as a
[distance](elementary-number-theory.distance-natural-numbers.md) between two
consecutive binomial coefficients

$$
C_n = \lvert{2n \choose n} - {2n \choose n + 1}\rvert.
$$

Since ${2n \choose n}$ in general is larger than or equal to
${2n \choose n + 1}$, this distance is equal to the difference

$$
C_n = {2n \choose n} - {2n \choose n + 1}.
$$

However, we prefer the use of the distance binary operation on natural numbers
in general at it is a total function on natural numbers, and allows us to skip
proving this inequality.

```agda
catalan-numbers-binomial :
catalan-numbers-binomial n =
dist-ℕ
( binomial-coefficient-ℕ (2 *ℕ n) n)
( binomial-coefficient-ℕ (2 *ℕ n) (succ-ℕ n))
```

## External links

- [Catalan number](https://en.wikipedia.org/wiki/Catalan_number) at Wikipedia
- [Catalan Number](https://mathworld.wolfram.com/CatalanNumber.html) at Wolfram
MathWorld
- [A000108](https://oeis.org/A000108) in the OEIS
13 changes: 10 additions & 3 deletions src/elementary-number-theory/cofibonacci.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,13 +30,20 @@ open import foundation.universe-levels

## Idea

The [**cofibonacci sequence**][1] is the unique function G : ℕ satisfying
the property that
The {{#concept "cofibonacci sequence" Agda=cofibonacci}} is the unique function
`G : ℕ` satisfying the property that

```text
div-ℕ (G m) n ↔ div-ℕ m (Fibonacci-ℕ n).
```

The sequence starts

```text
n 0 1 2 3 4 5 6 7 8 9 10 11 12 13
Gₙ 1 3 4 6 5 12 8 6 12 15 10 12 7 24
```

## Definitions

### The predicate of being a multiple of the `m`-th cofibonacci number
Expand Down Expand Up @@ -141,4 +148,4 @@ is-left-adjoint-cofibonacci m n = {!!}

## External links

[1]: https://oeis.org/A001177
- [A001177](https://oeis.org/A001177) in the OEIS
Original file line number Diff line number Diff line change
Expand Up @@ -28,9 +28,11 @@ open import foundation.universe-levels

## Idea

The distance function between natural numbers measures how far two natural
numbers are apart. In the agda-unimath library we often prefer to work with
`dist-ℕ` over the partially defined subtraction operation.
The
{{#concept "distance function" Disambiguation="between natural numbers" Agda=dist-ℕ}}
between [natural numbers](elementary-number-theory.natural-numbers.md) measures
how far two natural numbers are apart. In the agda-unimath library we often
prefer to work with `dist-ℕ` over the partially defined subtraction operation.

## Definition

Expand Down
10 changes: 9 additions & 1 deletion src/elementary-number-theory/eulers-totient-function.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,8 @@ open import univalent-combinatorics.standard-finite-types

## Idea

**Euler's totient function** `φ : ℕ` is the function that maps a
{{#concept "Euler's totient function" WD="Euler's totient function" WDID=Q190026 Agda=eulers-totient-function-relatively-prime}}
: ℕ` is the function that maps a
[natural number](elementary-number-theory.natural-numbers.md) `n` to the number
of
[multiplicative units modulo `n`](elementary-number-theory.multiplicative-units-standard-cyclic-rings.md).
Expand Down Expand Up @@ -57,3 +58,10 @@ eulers-totient-function-relatively-prime n =
### Table of files related to cyclic types, groups, and rings

{{#include tables/cyclic-types.md}}

## External links

- [Euler's totient function](https://en.wikipedia.org/wiki/Euler%27s_totient_function)
at Wikipedia
- [Totient Function](https://mathworld.wolfram.com/TotientFunction.html) at
Wolfram MathWorld
11 changes: 11 additions & 0 deletions src/elementary-number-theory/factorials.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,12 @@ open import foundation.identity-types

</details>

## Idea

The {{#concept "factorial" WD="factorial" WDID=Q120976 Agda=factorial-ℕ}} `n!`
of a number `n`, counts the number of ways to linearly order `n` distinct
objects.

## Definition

```agda
Expand Down Expand Up @@ -66,3 +72,8 @@ leq-factorial-ℕ (succ-ℕ n) =
( succ-ℕ n)
( is-nonzero-factorial-ℕ n)
```

## External links

- [Factorial](https://en.wikipedia.org/wiki/Factorial) at Wikipedia
- [A000142](https://oeis.org/A000142) in the OEIS
9 changes: 7 additions & 2 deletions src/elementary-number-theory/fermat-numbers.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,8 @@ open import univalent-combinatorics.standard-finite-types

## Idea

{{#concept "Fermat numbers"}} are numbers of the form $F_n := 2^{2^n}+1$. The
first five Fermat numbers are
{{#concept "Fermat numbers" WD="Fermat number" WDID=Q207264 Agda=fermat-number-ℕ}}
are numbers of the form $F_n := 2^{2^n}+1$. The first five Fermat numbers are

```text
3, 5, 17, 257, and 65537.
Expand Down Expand Up @@ -72,3 +72,8 @@ recursive-fermat-number-ℕ =
( λ i f (nat-Fin (succ-ℕ n) i) (upper-bound-nat-Fin n i)))
( 2))
```

## External link

- [Fermat number](https://en.wikipedia.org/wiki/Fermat_number) at Wikipedia
- [A000215](https://oeis.org/A000215) in the OEIS
83 changes: 55 additions & 28 deletions src/elementary-number-theory/fibonacci-sequence.lagda.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,27 @@ open import foundation.transport-along-identifications

</details>

## Idea

The
{{#concept "Fibonacci sequence" WD="Fibonacci sequence" WDID=Q23835349 Agda=Fibonacci-ℕ}}
is a recursively defined [sequence](foundation.sequences.md) of
[natural numbers](elementary-number-theory.natural-numbers.md) given by the
equations

```text
Fₙ₊₂ = Fₙ₊₁ + Fₙ, where F₀ = 0 and F₁ = 1
```

A number in this sequence is called a
{{#concept "Fibonacci number" WD="Fibonacci number" WDID=Q47577}}. The first few
Fibonacci numbers are

```text
n 0 1 2 3 4 5 6 7 8 9
Fₙ 0 1 1 2 3 5 8 13 21 34
```

## Definitions

### The standard definition using pattern matching
Expand Down Expand Up @@ -93,34 +114,34 @@ Fibonacci-add-ℕ m zero-ℕ =
( inv (right-zero-law-mul-ℕ (Fibonacci-ℕ m)))
Fibonacci-add-ℕ m (succ-ℕ n) =
( ap Fibonacci-ℕ (inv (left-successor-law-add-ℕ m (succ-ℕ n)))) ∙
( ( Fibonacci-add-ℕ (succ-ℕ m) n) ∙
( ( ap
( _+ℕ ((Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n)))
( right-distributive-mul-add-ℕ
( Fibonacci-ℕ (succ-ℕ m))
( Fibonacci-ℕ m)
( Fibonacci-ℕ (succ-ℕ n)))) ∙
( ( associative-add-ℕ
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n))) ∙
( ( ap
( ((Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ (succ-ℕ n))) +ℕ_)
( commutative-add-ℕ
( (Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n)))) ∙
( ( inv
( associative-add-ℕ
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n))
( (Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n))))) ∙
( ap
( _+ℕ ((Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n))))
( inv
( left-distributive-mul-add-ℕ
( Fibonacci-ℕ (succ-ℕ m))
( Fibonacci-ℕ (succ-ℕ n))
( Fibonacci-ℕ n)))))))))
( Fibonacci-add-ℕ (succ-ℕ m) n) ∙
( ap
( _+ℕ ((Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n)))
( right-distributive-mul-add-ℕ
( Fibonacci-ℕ (succ-ℕ m))
( Fibonacci-ℕ m)
( Fibonacci-ℕ (succ-ℕ n)))) ∙
( associative-add-ℕ
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n))) ∙
( ap
( ((Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ (succ-ℕ n))) +ℕ_)
( commutative-add-ℕ
( (Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n)))) ∙
( inv
( associative-add-ℕ
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ (succ-ℕ n)))
( (Fibonacci-ℕ (succ-ℕ m)) *ℕ (Fibonacci-ℕ n))
( (Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n))))) ∙
( ap
( _+ℕ ((Fibonacci-ℕ m) *ℕ (Fibonacci-ℕ (succ-ℕ n))))
( inv
( left-distributive-mul-add-ℕ
( Fibonacci-ℕ (succ-ℕ m))
( Fibonacci-ℕ (succ-ℕ n))
( Fibonacci-ℕ n))))
```

### Consecutive Fibonacci numbers are relatively prime
Expand Down Expand Up @@ -204,3 +225,9 @@ preserves-div-Fibonacci-ℕ :
preserves-div-Fibonacci-ℕ m n H =
div-Fibonacci-div-ℕ (Fibonacci-ℕ m) m n H (refl-div-ℕ (Fibonacci-ℕ m))
```

## External links

- [Fibonacci sequence](https://en.wikipedia.org/wiki/Fibonacci_sequence) at
Wikipedia
- [A000045](https://oeis.org/A000045) in the OEIS
Loading

0 comments on commit c1a469f

Please sign in to comment.