Built with Alectryon, running Coq+SerAPI v8.10.0+0.7.0. Coq sources are in this panel; goals and messages will appear in the other. Bubbles () indicate interactive fragments: hover for details, tap to reveal contents. Use Ctrl+↑ Ctrl+↓ to navigate, Ctrl+🖱️ to focus.
(************************************************************************)
(*         *   The Coq Proof Assistant / The Coq Development Team       *)
(*  v      *   INRIA, CNRS and contributors - Copyright 1999-2018       *)
(* <O___,, *       (see CREDITS file for the list of authors)           *)
(*   \VV/  **************************************************************)
(*    //   *    This file is distributed under the terms of the         *)
(*         *     GNU Lesser General Public License Version 2.1          *)
(*         *     (see LICENSE file for the text of the license)         *)
(************************************************************************)

Require Import ZAxioms ZMulOrder GenericMinMax.

Properties of minimum and maximum specific to integer numbers

Module Type ZMaxMinProp (Import Z : ZAxiomsMiniSig').
Include ZMulOrderProp Z.
The following results are concrete instances of max_monotone and similar lemmas.
Succ

forall n m : t, S (max n m) == max (S n) (S m)

forall n m : t, S (max n m) == max (S n) (S m)
n, m:t

S (max n m) == max (S n) (S m)
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; now rewrite <- ?succ_le_mono. Qed.

forall n m : t, S (min n m) == min (S n) (S m)

forall n m : t, S (min n m) == min (S n) (S m)
n, m:t

S (min n m) == min (S n) (S m)
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; now rewrite <- ?succ_le_mono. Qed.
Pred

forall n m : t, P (max n m) == max (P n) (P m)

forall n m : t, P (max n m) == max (P n) (P m)
n, m:t

P (max n m) == max (P n) (P m)
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; now rewrite <- ?pred_le_mono. Qed.

forall n m : t, P (min n m) == min (P n) (P m)

forall n m : t, P (min n m) == min (P n) (P m)
n, m:t

P (min n m) == min (P n) (P m)
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; now rewrite <- ?pred_le_mono. Qed.
Add

forall n m p : t, max (p + n) (p + m) == p + max n m

forall n m p : t, max (p + n) (p + m) == p + max n m
n, m, p:t

max (p + n) (p + m) == p + max n m
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; now rewrite <- ?add_le_mono_l. Qed.

forall n m p : t, max (n + p) (m + p) == max n m + p

forall n m p : t, max (n + p) (m + p) == max n m + p
n, m, p:t

max (n + p) (m + p) == max n m + p
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; now rewrite <- ?add_le_mono_r. Qed.

forall n m p : t, min (p + n) (p + m) == p + min n m

forall n m p : t, min (p + n) (p + m) == p + min n m
n, m, p:t

min (p + n) (p + m) == p + min n m
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; now rewrite <- ?add_le_mono_l. Qed.

forall n m p : t, min (n + p) (m + p) == min n m + p

forall n m p : t, min (n + p) (m + p) == min n m + p
n, m, p:t

min (n + p) (m + p) == min n m + p
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; now rewrite <- ?add_le_mono_r. Qed.
Opp

forall n m : t, - max n m == min (- n) (- m)

forall n m : t, - max n m == min (- n) (- m)
n, m:t

- max n m == min (- n) (- m)
n, m:t
H:n <= m

- max n m == min (- n) (- m)
n, m:t
H:m <= n
- max n m == min (- n) (- m)
n, m:t
H:n <= m

- m == min (- n) (- m)
n, m:t
H:m <= n
- max n m == min (- n) (- m)
n, m:t
H:n <= m

min (- n) (- m) == - m
n, m:t
H:m <= n
- max n m == min (- n) (- m)
n, m:t
H:n <= m

- m <= - n
n, m:t
H:m <= n
- max n m == min (- n) (- m)
n, m:t
H:m <= n

- max n m == min (- n) (- m)
n, m:t
H:m <= n

- n == min (- n) (- m)
n, m:t
H:m <= n

min (- n) (- m) == - n
n, m:t
H:m <= n

- n <= - m
now rewrite <- opp_le_mono. Qed.

forall n m : t, - min n m == max (- n) (- m)

forall n m : t, - min n m == max (- n) (- m)
n, m:t

- min n m == max (- n) (- m)
n, m:t
H:n <= m

- min n m == max (- n) (- m)
n, m:t
H:m <= n
- min n m == max (- n) (- m)
n, m:t
H:n <= m

- n == max (- n) (- m)
n, m:t
H:m <= n
- min n m == max (- n) (- m)
n, m:t
H:n <= m

max (- n) (- m) == - n
n, m:t
H:m <= n
- min n m == max (- n) (- m)
n, m:t
H:n <= m

- m <= - n
n, m:t
H:m <= n
- min n m == max (- n) (- m)
n, m:t
H:m <= n

- min n m == max (- n) (- m)
n, m:t
H:m <= n

- m == max (- n) (- m)
n, m:t
H:m <= n

max (- n) (- m) == - m
n, m:t
H:m <= n

- n <= - m
now rewrite <- opp_le_mono. Qed.
Sub

forall n m p : t, max (p - n) (p - m) == p - min n m

forall n m p : t, max (p - n) (p - m) == p - min n m
n, m, p:t

max (p - n) (p - m) == p - min n m
n, m, p:t
H:n <= m

max (p - n) (p - m) == p - min n m
n, m, p:t
H:m <= n
max (p - n) (p - m) == p - min n m
n, m, p:t
H:n <= m

max (p - n) (p - m) == p - n
n, m, p:t
H:m <= n
max (p - n) (p - m) == p - min n m
n, m, p:t
H:n <= m

p - m <= p - n
n, m, p:t
H:m <= n
max (p - n) (p - m) == p - min n m
n, m, p:t
H:m <= n

max (p - n) (p - m) == p - min n m
n, m, p:t
H:m <= n

max (p - n) (p - m) == p - m
n, m, p:t
H:m <= n

p - n <= p - m
now rewrite <- sub_le_mono_l. Qed.

forall n m p : t, max (n - p) (m - p) == max n m - p

forall n m p : t, max (n - p) (m - p) == max n m - p
n, m, p:t

max (n - p) (m - p) == max n m - p
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; try order; now apply sub_le_mono_r. Qed.

forall n m p : t, min (p - n) (p - m) == p - max n m

forall n m p : t, min (p - n) (p - m) == p - max n m
n, m, p:t

min (p - n) (p - m) == p - max n m
n, m, p:t
H:n <= m

min (p - n) (p - m) == p - max n m
n, m, p:t
H:m <= n
min (p - n) (p - m) == p - max n m
n, m, p:t
H:n <= m

min (p - n) (p - m) == p - m
n, m, p:t
H:m <= n
min (p - n) (p - m) == p - max n m
n, m, p:t
H:n <= m

p - m <= p - n
n, m, p:t
H:m <= n
min (p - n) (p - m) == p - max n m
n, m, p:t
H:m <= n

min (p - n) (p - m) == p - max n m
n, m, p:t
H:m <= n

min (p - n) (p - m) == p - n
n, m, p:t
H:m <= n

p - n <= p - m
now rewrite <- sub_le_mono_l. Qed.

forall n m p : t, min (n - p) (m - p) == min n m - p

forall n m p : t, min (n - p) (m - p) == min n m - p
n, m, p:t

min (n - p) (m - p) == min n m - p
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; try order; now apply sub_le_mono_r. Qed.
Mul

forall n m p : t, 0 <= p -> max (p * n) (p * m) == p * max n m

forall n m p : t, 0 <= p -> max (p * n) (p * m) == p * max n m
n, m, p:t
H:0 <= p

max (p * n) (p * m) == p * max n m
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; try order; now apply mul_le_mono_nonneg_l. Qed.

forall n m p : t, 0 <= p -> max (n * p) (m * p) == max n m * p

forall n m p : t, 0 <= p -> max (n * p) (m * p) == max n m * p
n, m, p:t
H:0 <= p

max (n * p) (m * p) == max n m * p
destruct (le_ge_cases n m); [rewrite 2 max_r | rewrite 2 max_l]; try order; now apply mul_le_mono_nonneg_r. Qed.

forall n m p : t, 0 <= p -> min (p * n) (p * m) == p * min n m

forall n m p : t, 0 <= p -> min (p * n) (p * m) == p * min n m
n, m, p:t
H:0 <= p

min (p * n) (p * m) == p * min n m
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; try order; now apply mul_le_mono_nonneg_l. Qed.

forall n m p : t, 0 <= p -> min (n * p) (m * p) == min n m * p

forall n m p : t, 0 <= p -> min (n * p) (m * p) == min n m * p
n, m, p:t
H:0 <= p

min (n * p) (m * p) == min n m * p
destruct (le_ge_cases n m); [rewrite 2 min_l | rewrite 2 min_r]; try order; now apply mul_le_mono_nonneg_r. Qed.

forall n m p : t, p <= 0 -> max (p * n) (p * m) == p * min n m

forall n m p : t, p <= 0 -> max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0

max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:n <= m

max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:m <= n
max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:n <= m

max (p * n) (p * m) == p * n
n, m, p:t
H:p <= 0
H0:m <= n
max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:n <= m

p * n == p * n
n, m, p:t
H:p <= 0
H0:n <= m
p * m <= p * n
n, m, p:t
H:p <= 0
H0:m <= n
max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:n <= m

p * m <= p * n
n, m, p:t
H:p <= 0
H0:m <= n
max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:m <= n

max (p * n) (p * m) == p * min n m
n, m, p:t
H:p <= 0
H0:m <= n

max (p * n) (p * m) == p * m
n, m, p:t
H:p <= 0
H0:m <= n

p * m == p * m
n, m, p:t
H:p <= 0
H0:m <= n
p * n <= p * m
n, m, p:t
H:p <= 0
H0:m <= n

p * n <= p * m
now apply mul_le_mono_nonpos_l. Qed.

forall n m p : t, p <= 0 -> max (n * p) (m * p) == min n m * p

forall n m p : t, p <= 0 -> max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0

max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:n <= m

max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:m <= n
max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:n <= m

max (n * p) (m * p) == n * p
n, m, p:t
H:p <= 0
H0:m <= n
max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:n <= m

n * p == n * p
n, m, p:t
H:p <= 0
H0:n <= m
m * p <= n * p
n, m, p:t
H:p <= 0
H0:m <= n
max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:n <= m

m * p <= n * p
n, m, p:t
H:p <= 0
H0:m <= n
max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:m <= n

max (n * p) (m * p) == min n m * p
n, m, p:t
H:p <= 0
H0:m <= n

max (n * p) (m * p) == m * p
n, m, p:t
H:p <= 0
H0:m <= n

m * p == m * p
n, m, p:t
H:p <= 0
H0:m <= n
n * p <= m * p
n, m, p:t
H:p <= 0
H0:m <= n

n * p <= m * p
now apply mul_le_mono_nonpos_r. Qed.

forall n m p : t, p <= 0 -> min (p * n) (p * m) == p * max n m

forall n m p : t, p <= 0 -> min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0

min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:n <= m

min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:m <= n
min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:n <= m

min (p * n) (p * m) == p * m
n, m, p:t
H:p <= 0
H0:m <= n
min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:n <= m

p * m == p * m
n, m, p:t
H:p <= 0
H0:n <= m
p * m <= p * n
n, m, p:t
H:p <= 0
H0:m <= n
min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:n <= m

p * m <= p * n
n, m, p:t
H:p <= 0
H0:m <= n
min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:m <= n

min (p * n) (p * m) == p * max n m
n, m, p:t
H:p <= 0
H0:m <= n

min (p * n) (p * m) == p * n
n, m, p:t
H:p <= 0
H0:m <= n

p * n == p * n
n, m, p:t
H:p <= 0
H0:m <= n
p * n <= p * m
n, m, p:t
H:p <= 0
H0:m <= n

p * n <= p * m
now apply mul_le_mono_nonpos_l. Qed.

forall n m p : t, p <= 0 -> min (n * p) (m * p) == max n m * p

forall n m p : t, p <= 0 -> min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0

min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:n <= m

min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:m <= n
min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:n <= m

min (n * p) (m * p) == m * p
n, m, p:t
H:p <= 0
H0:m <= n
min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:n <= m

m * p == m * p
n, m, p:t
H:p <= 0
H0:n <= m
m * p <= n * p
n, m, p:t
H:p <= 0
H0:m <= n
min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:n <= m

m * p <= n * p
n, m, p:t
H:p <= 0
H0:m <= n
min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:m <= n

min (n * p) (m * p) == max n m * p
n, m, p:t
H:p <= 0
H0:m <= n

min (n * p) (m * p) == n * p
n, m, p:t
H:p <= 0
H0:m <= n

n * p == n * p
n, m, p:t
H:p <= 0
H0:m <= n
n * p <= m * p
n, m, p:t
H:p <= 0
H0:m <= n

n * p <= m * p
now apply mul_le_mono_nonpos_r. Qed. End ZMaxMinProp.