Proof Trace Export for
thm1/WD (true)
from
find_ctx/find_ctx.pl
Proof Steps
< Previous Step
Next Step >
Run Steps
1. and_r
2. upper_bound_r
3. fin_rel_ran_r
4. fin_fun1_r(1..n +-> NATURAL1)
5. true_goal
6. DEF_IN_TFCT (arr ∈ 1 ‥ n → ℕ1)
7. hyp
8. Evaluate tautology (finite(1 ‥ n))
9. true_goal
10. fun_goal
11. DEF_IN_TFCT (arr ∈ 1 ‥ n → ℕ1)
12. eq (lr,dom(arr) = 1 ‥ n)
13. hyp
14. SIMP_NOTEQUAL (ran(arr) ≠ ∅)
15. DEF_SPECIAL_NOT_EQUAL (¬(ran(arr) = ∅))
16. exists_inst(arr(1))
17. and_r
18. DERIV_DOM_TOTALREL (1 ∈ dom(arr))
19. DEF_IN_UPTO (1 ∈ 1 ‥ n)
20. SIMP_LIT_LE (1 ≤ 1)
21. true_goal
22. DEF_IN_NATURAL1 (n ∈ ℕ1)
23. hyp
24. fun_goal
25. DEF_IN_RAN (arr(1) ∈ ran(arr))
26. exists_inst(1)
27. true_goal
28. SIMP_IN_FUNIMAGE (1 ↦ arr(1) ∈ arr)
29. true_goal
ProB Version: 1.16.0-nightly (1742b9cc6629604302028955e627f3b757167b11)
Generated on 26/01/2026 at 15:03
Proof Tree
prob_graph
dot_node_0
Select PO
dot_node_11
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
(∃b·(∀x·(x ∈ ran(arr) ⇒ x ≤ b))) ∧ arr ∈ ℤ ⇸ ℤ ∧ mxi ∈ dom(arr) ∧ ran(arr) ≠ ∅
dot_node_0->dot_node_11
thm1/WD (true)
dot_node_1
Proven.
dot_node_2
Proven.
dot_node_3
Proven.
dot_node_4
Proven.
dot_node_5
Proven.
dot_node_6
Proven.
dot_node_7
Proven.
dot_node_8
Proven.
dot_node_9
Proven.
dot_node_10
Proven.
dot_node_12
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
(∃b·(∀x·(x ∈ ran(arr) ⇒ x ≤ b)))
dot_node_11->dot_node_12
and_r
dot_node_13
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
arr ∈ ℤ ⇸ ℤ
dot_node_11->dot_node_13
and_r
dot_node_14
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
mxi ∈ dom(arr)
dot_node_11->dot_node_14
and_r
dot_node_15
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
ran(arr) ≠ ∅
dot_node_11->dot_node_15
and_r
dot_node_16
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
finite(ran(arr))
dot_node_12->dot_node_16
upper_bound_r
dot_node_13->dot_node_4
fun_goal
dot_node_23
arr ∈ 1 ‥ n ⇸ ℕ1
dom(arr) = 1 ‥ n
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
mxi ∈ dom(arr)
dot_node_14->dot_node_23
DEF_IN_TFCT (arr ∈ 1 ‥ n → ℕ1)
dot_node_25
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
¬(ran(arr) = ∅)
dot_node_15->dot_node_25
SIMP_NOTEQUAL (ran(arr) ≠ ∅)
dot_node_17
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
finite(arr)
dot_node_16->dot_node_17
fin_rel_ran_r
dot_node_18
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
⊤
dot_node_17->dot_node_18
fin_fun1_r(1..n +-> NATURAL1)
dot_node_19
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
arr ∈ 1 ‥ n ⇸ ℕ1
dot_node_17->dot_node_19
fin_fun1_r(1..n +-> NATURAL1)
dot_node_20
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
finite(1 ‥ n)
dot_node_17->dot_node_20
fin_fun1_r(1..n +-> NATURAL1)
dot_node_18->dot_node_1
true_goal
dot_node_21
arr ∈ 1 ‥ n ⇸ ℕ1
dom(arr) = 1 ‥ n
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
arr ∈ 1 ‥ n ⇸ ℕ1
dot_node_19->dot_node_21
DEF_IN_TFCT (arr ∈ 1 ‥ n → ℕ1)
dot_node_22
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
⊤
dot_node_20->dot_node_22
Evaluate tautology (finite(1 ‥ n))
dot_node_21->dot_node_2
hyp
dot_node_22->dot_node_3
true_goal
dot_node_24
arr ∈ 1 ‥ n ⇸ ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
mxi ∈ 1 ‥ n
dot_node_23->dot_node_24
eq (lr,dom(arr) = 1 ‥ n)
dot_node_24->dot_node_5
hyp
dot_node_26
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
(∃x·x ∈ ran(arr))
dot_node_25->dot_node_26
DEF_SPECIAL_NOT_EQUAL (¬(ran(arr) = ∅))
dot_node_27
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ∈ dom(arr) ∧ arr ∈ ℤ ⇸ ℤ
dot_node_26->dot_node_27
exists_inst(arr(1))
dot_node_28
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
arr(1) ∈ ran(arr)
dot_node_26->dot_node_28
exists_inst(arr(1))
dot_node_29
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ∈ dom(arr)
dot_node_27->dot_node_29
and_r
dot_node_30
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
arr ∈ ℤ ⇸ ℤ
dot_node_27->dot_node_30
and_r
dot_node_36
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
(∃x·x ↦ arr(1) ∈ arr)
dot_node_28->dot_node_36
DEF_IN_RAN (arr(1) ∈ ran(arr))
dot_node_31
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ∈ 1 ‥ n
dot_node_29->dot_node_31
DERIV_DOM_TOTALREL (1 ∈ dom(arr))
dot_node_30->dot_node_8
fun_goal
dot_node_32
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ≤ 1
dot_node_31->dot_node_32
DEF_IN_UPTO (1 ∈ 1 ‥ n)
dot_node_33
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ≤ n
dot_node_31->dot_node_33
DEF_IN_UPTO (1 ∈ 1 ‥ n)
dot_node_34
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
⊤
dot_node_32->dot_node_34
SIMP_LIT_LE (1 ≤ 1)
dot_node_35
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
1 ≤ n
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ≤ n
dot_node_33->dot_node_35
DEF_IN_NATURAL1 (n ∈ ℕ1)
dot_node_34->dot_node_6
true_goal
dot_node_35->dot_node_7
hyp
dot_node_37
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
⊤
dot_node_36->dot_node_37
exists_inst(1)
dot_node_38
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
1 ↦ arr(1) ∈ arr
dot_node_36->dot_node_38
exists_inst(1)
dot_node_37->dot_node_9
true_goal
dot_node_39
arr ∈ 1 ‥ n → ℕ1
mxi ∈ 1 ‥ n
n ∈ ℕ1
(∀j·(j ∈ 1 ‥ n ⇒ arr(j) ≤ arr(mxi)))
⊤
dot_node_38->dot_node_39
SIMP_IN_FUNIMAGE (1 ↦ arr(1) ∈ arr)
dot_node_39->dot_node_10
true_goal
Reset View