completed revision of Relations
This commit is contained in:
parent
67689be194
commit
6538feeda5
1 changed files with 27 additions and 21 deletions
|
@ -14,7 +14,7 @@ import Relation.Binary.PropositionalEquality as Eq
|
||||||
open Eq using (_≡_; refl; cong; sym)
|
open Eq using (_≡_; refl; cong; sym)
|
||||||
open Eq.≡-Reasoning using (begin_; _≡⟨⟩_; _≡⟨_⟩_; _∎)
|
open Eq.≡-Reasoning using (begin_; _≡⟨⟩_; _≡⟨_⟩_; _∎)
|
||||||
open import Data.Nat using (ℕ; zero; suc; _+_; _*_; _∸_)
|
open import Data.Nat using (ℕ; zero; suc; _+_; _*_; _∸_)
|
||||||
open import Data.Nat.Properties.Simple using (+-comm)
|
open import Data.Nat.Properties using (+-comm)
|
||||||
\end{code}
|
\end{code}
|
||||||
|
|
||||||
## Defining relations
|
## Defining relations
|
||||||
|
@ -157,9 +157,9 @@ such relations?)
|
||||||
The first property to prove about comparison is that it is reflexive:
|
The first property to prove about comparison is that it is reflexive:
|
||||||
for any natural `n`, the relation `n ≤ n` holds.
|
for any natural `n`, the relation `n ≤ n` holds.
|
||||||
\begin{code}
|
\begin{code}
|
||||||
≤-refl : ∀ (n : ℕ) → n ≤ n
|
≤-refl : ∀ {n : ℕ} → n ≤ n
|
||||||
≤-refl zero = z≤n
|
≤-refl {zero} = z≤n
|
||||||
≤-refl (suc n) = s≤s (≤-refl n)
|
≤-refl {suc n} = s≤s (≤-refl {n})
|
||||||
\end{code}
|
\end{code}
|
||||||
The proof is a straightforward induction on `n`. In the base case,
|
The proof is a straightforward induction on `n`. In the base case,
|
||||||
`zero ≤ zero` holds by `z≤n`. In the inductive case, the inductive
|
`zero ≤ zero` holds by `z≤n`. In the inductive case, the inductive
|
||||||
|
@ -199,8 +199,6 @@ that `m ≤ p`, and our goal follows by applying `s≤s`.
|
||||||
|
|
||||||
In the base case, `m ≤ n` holds by `z≤n`, so it must be that
|
In the base case, `m ≤ n` holds by `z≤n`, so it must be that
|
||||||
`m` is `zero`, in which case `m ≤ p` also holds by `z≤n`. In this
|
`m` is `zero`, in which case `m ≤ p` also holds by `z≤n`. In this
|
||||||
|
|
||||||
|
|
||||||
case, the fact that `n ≤ p` is irrelevant, and we write `_` as the
|
case, the fact that `n ≤ p` is irrelevant, and we write `_` as the
|
||||||
pattern to indicate that the corresponding evidence is unused.
|
pattern to indicate that the corresponding evidence is unused.
|
||||||
|
|
||||||
|
@ -422,9 +420,9 @@ Invoking `+-monoˡ-≤ m n p m≤n` proves `m + p ≤ n + p` and invoking
|
||||||
transitivity proves `m + p ≤ n + q`, as was to be shown.
|
transitivity proves `m + p ≤ n + q`, as was to be shown.
|
||||||
|
|
||||||
|
|
||||||
## Exercises
|
### Exercise (`<-irrefl`, `<-trans`, `trichotomy`, `+-mono-<`)
|
||||||
|
|
||||||
We can define strict comparison similarly to comparison.
|
We can define strict inequality similarly to inequality.
|
||||||
\begin{code}
|
\begin{code}
|
||||||
data _<_ : ℕ → ℕ → Set where
|
data _<_ : ℕ → ℕ → Set where
|
||||||
z<s : ∀ {n : ℕ} → zero < suc n
|
z<s : ∀ {n : ℕ} → zero < suc n
|
||||||
|
@ -436,19 +434,17 @@ infix 4 _<_
|
||||||
+ *Irreflexivity* Show that `n < n` never holds
|
+ *Irreflexivity* Show that `n < n` never holds
|
||||||
for any natural `n`. (This requires negation,
|
for any natural `n`. (This requires negation,
|
||||||
introduced in the chapter on Logic.)
|
introduced in the chapter on Logic.)
|
||||||
Name your proof `<-irrefl`.
|
|
||||||
|
|
||||||
+ *Transitivity* Show that
|
+ *Transitivity* Show that
|
||||||
|
|
||||||
> if `m < n` and `n < p` then `m < p`
|
> if `m < n` and `n < p` then `m < p`
|
||||||
|
|
||||||
for all naturals `m`, `n`, and `p`. Name your proof `<-trans`.
|
for all naturals `m`, `n`, and `p`.
|
||||||
|
|
||||||
+ *Trichotomy* Corresponding to anti-symmetry and totality
|
+ *Trichotomy* Corresponding to anti-symmetry and totality
|
||||||
of comparison, we have trichotomy for strict comparison.
|
of comparison, we have trichotomy for strict comparison.
|
||||||
Show that for any given any naturals `m` and `n` that
|
Show that for any given any naturals `m` and `n` that
|
||||||
`Trichotomy m n` holds, using the defintions below.
|
`Trichotomy m n` holds, using the defintions below.
|
||||||
Name your proof `trichotomy`.
|
|
||||||
|
|
||||||
\begin{code}
|
\begin{code}
|
||||||
_>_ : ℕ → ℕ → Set
|
_>_ : ℕ → ℕ → Set
|
||||||
|
@ -471,7 +467,7 @@ data Trichotomy : ℕ → ℕ → Set where
|
||||||
+ *Relate strict comparison to comparison*
|
+ *Relate strict comparison to comparison*
|
||||||
Show that `m < n` if and only if `suc m ≤ n`.
|
Show that `m < n` if and only if `suc m ≤ n`.
|
||||||
Name the two parts of your proof
|
Name the two parts of your proof
|
||||||
`<-implies-≤` and `≤-implies-<`
|
`<-implies-≤` and `≤-implies-<`.
|
||||||
|
|
||||||
To confirm your understanding, you should prove transitivity, trichotomy,
|
To confirm your understanding, you should prove transitivity, trichotomy,
|
||||||
and monotonicity for `<` directly by modifying
|
and monotonicity for `<` directly by modifying
|
||||||
|
@ -479,7 +475,9 @@ data Trichotomy : ℕ → ℕ → Set where
|
||||||
the proofs exploiting the last exercise, so each property of `<` becomes
|
the proofs exploiting the last exercise, so each property of `<` becomes
|
||||||
an easy consequence of the corresponding property for `≤`.
|
an easy consequence of the corresponding property for `≤`.
|
||||||
|
|
||||||
+ *Even and odd* Another example of a useful relation is to define
|
### Exercise
|
||||||
|
|
||||||
|
*Even and odd* Another example of a useful relation is to define
|
||||||
even and odd numbers, as done below. Using these definitions, show
|
even and odd numbers, as done below. Using these definitions, show
|
||||||
- the sum of two even numbers is even
|
- the sum of two even numbers is even
|
||||||
- the sum of an even and an odd number is odd
|
- the sum of an even and an odd number is odd
|
||||||
|
@ -488,10 +486,10 @@ data Trichotomy : ℕ → ℕ → Set where
|
||||||
\begin{code}
|
\begin{code}
|
||||||
mutual
|
mutual
|
||||||
data even : ℕ → Set where
|
data even : ℕ → Set where
|
||||||
ev-zero : even zero
|
even-zero : even zero
|
||||||
ev-suc : ∀ {n : ℕ} → odd n → even (suc n)
|
even-suc : ∀ {n : ℕ} → odd n → even (suc n)
|
||||||
data odd : ℕ → Set where
|
data odd : ℕ → Set where
|
||||||
od-suc : ∀ {n : ℕ} → even n → odd (suc n)
|
odd-suc : ∀ {n : ℕ} → even n → odd (suc n)
|
||||||
\end{code}
|
\end{code}
|
||||||
The keyword `mutual` indicates that the nested definitions
|
The keyword `mutual` indicates that the nested definitions
|
||||||
are mutually recursive.
|
are mutually recursive.
|
||||||
|
@ -502,6 +500,14 @@ Because the two defintions are mutually recursive, the type
|
||||||
declaration just repeats the first line of the definition, but without
|
declaration just repeats the first line of the definition, but without
|
||||||
the keyword `where`. -->
|
the keyword `where`. -->
|
||||||
|
|
||||||
|
## Standard prelude
|
||||||
|
|
||||||
|
Definitions from this chapter can be found in the standard library.
|
||||||
|
\begin{code}
|
||||||
|
import Data.Nat using (_≤_; z≤n; s≤s)
|
||||||
|
import Data.Nat.Properties using (≤-refl; ≤-trans; ≤-antisym; ≤-total; +-mono-≤)
|
||||||
|
\end{code}
|
||||||
|
|
||||||
|
|
||||||
## Unicode
|
## Unicode
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue