MPE Home Metamath Proof Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  MPE Home  >  Th. List  >  algcvg Structured version   Visualization version   GIF version

Theorem algcvg 16593
Description: One way to prove that an algorithm halts is to construct a countdown function 𝐶:𝑆⟶ℕ0 whose value is guaranteed to decrease for each iteration of 𝐹 until it reaches 0. That is, if 𝑋𝑆 is not a fixed point of 𝐹, then (𝐶‘(𝐹𝑋)) < (𝐶𝑋).

If 𝐶 is a countdown function for algorithm 𝐹, the sequence (𝐶‘(𝑅𝑘)) reaches 0 after at most 𝑁 steps, where 𝑁 is the value of 𝐶 for the initial state 𝐴. (Contributed by Paul Chapman, 22-Jun-2011.)

Hypotheses
Ref Expression
algcvg.1 𝐹:𝑆𝑆
algcvg.2 𝑅 = seq0((𝐹 ∘ 1st ), (ℕ0 × {𝐴}))
algcvg.3 𝐶:𝑆⟶ℕ0
algcvg.4 (𝑧𝑆 → ((𝐶‘(𝐹𝑧)) ≠ 0 → (𝐶‘(𝐹𝑧)) < (𝐶𝑧)))
algcvg.5 𝑁 = (𝐶𝐴)
Assertion
Ref Expression
algcvg (𝐴𝑆 → (𝐶‘(𝑅𝑁)) = 0)
Distinct variable groups:   𝑧,𝐶   𝑧,𝐹   𝑧,𝑅   𝑧,𝑆
Allowed substitution hints:   𝐴(𝑧)   𝑁(𝑧)

Proof of Theorem algcvg
Dummy variable 𝑘 is distinct from all other variables.
StepHypRef Expression
1 nn0uz 12874 . . . 4 0 = (ℤ‘0)
2 algcvg.2 . . . 4 𝑅 = seq0((𝐹 ∘ 1st ), (ℕ0 × {𝐴}))
3 0zd 12577 . . . 4 (𝐴𝑆 → 0 ∈ ℤ)
4 id 22 . . . 4 (𝐴𝑆𝐴𝑆)
5 algcvg.1 . . . . 5 𝐹:𝑆𝑆
65a1i 11 . . . 4 (𝐴𝑆𝐹:𝑆𝑆)
71, 2, 3, 4, 6algrf 16590 . . 3 (𝐴𝑆𝑅:ℕ0𝑆)
8 algcvg.5 . . . 4 𝑁 = (𝐶𝐴)
9 algcvg.3 . . . . 5 𝐶:𝑆⟶ℕ0
109ffvelcdmi 7060 . . . 4 (𝐴𝑆 → (𝐶𝐴) ∈ ℕ0)
118, 10eqeltrid 2865 . . 3 (𝐴𝑆𝑁 ∈ ℕ0)
12 fvco3 6963 . . 3 ((𝑅:ℕ0𝑆𝑁 ∈ ℕ0) → ((𝐶𝑅)‘𝑁) = (𝐶‘(𝑅𝑁)))
137, 11, 12syl2anc 593 . 2 (𝐴𝑆 → ((𝐶𝑅)‘𝑁) = (𝐶‘(𝑅𝑁)))
14 fco 6712 . . . 4 ((𝐶:𝑆⟶ℕ0𝑅:ℕ0𝑆) → (𝐶𝑅):ℕ0⟶ℕ0)
159, 7, 14sylancr 596 . . 3 (𝐴𝑆 → (𝐶𝑅):ℕ0⟶ℕ0)
16 0nn0 12493 . . . . . 6 0 ∈ ℕ0
17 fvco3 6963 . . . . . 6 ((𝑅:ℕ0𝑆 ∧ 0 ∈ ℕ0) → ((𝐶𝑅)‘0) = (𝐶‘(𝑅‘0)))
187, 16, 17sylancl 595 . . . . 5 (𝐴𝑆 → ((𝐶𝑅)‘0) = (𝐶‘(𝑅‘0)))
191, 2, 3, 4algr0 16589 . . . . . 6 (𝐴𝑆 → (𝑅‘0) = 𝐴)
2019fveq2d 6867 . . . . 5 (𝐴𝑆 → (𝐶‘(𝑅‘0)) = (𝐶𝐴))
2118, 20eqtrd 2796 . . . 4 (𝐴𝑆 → ((𝐶𝑅)‘0) = (𝐶𝐴))
228, 21eqtr4id 2815 . . 3 (𝐴𝑆𝑁 = ((𝐶𝑅)‘0))
237ffvelcdmda 7061 . . . . 5 ((𝐴𝑆𝑘 ∈ ℕ0) → (𝑅𝑘) ∈ 𝑆)
24 2fveq3 6868 . . . . . . . 8 (𝑧 = (𝑅𝑘) → (𝐶‘(𝐹𝑧)) = (𝐶‘(𝐹‘(𝑅𝑘))))
2524neeq1d 3015 . . . . . . 7 (𝑧 = (𝑅𝑘) → ((𝐶‘(𝐹𝑧)) ≠ 0 ↔ (𝐶‘(𝐹‘(𝑅𝑘))) ≠ 0))
26 fveq2 6863 . . . . . . . 8 (𝑧 = (𝑅𝑘) → (𝐶𝑧) = (𝐶‘(𝑅𝑘)))
2724, 26breq12d 5112 . . . . . . 7 (𝑧 = (𝑅𝑘) → ((𝐶‘(𝐹𝑧)) < (𝐶𝑧) ↔ (𝐶‘(𝐹‘(𝑅𝑘))) < (𝐶‘(𝑅𝑘))))
2825, 27imbi12d 346 . . . . . 6 (𝑧 = (𝑅𝑘) → (((𝐶‘(𝐹𝑧)) ≠ 0 → (𝐶‘(𝐹𝑧)) < (𝐶𝑧)) ↔ ((𝐶‘(𝐹‘(𝑅𝑘))) ≠ 0 → (𝐶‘(𝐹‘(𝑅𝑘))) < (𝐶‘(𝑅𝑘)))))
29 algcvg.4 . . . . . 6 (𝑧𝑆 → ((𝐶‘(𝐹𝑧)) ≠ 0 → (𝐶‘(𝐹𝑧)) < (𝐶𝑧)))
3028, 29vtoclga 3541 . . . . 5 ((𝑅𝑘) ∈ 𝑆 → ((𝐶‘(𝐹‘(𝑅𝑘))) ≠ 0 → (𝐶‘(𝐹‘(𝑅𝑘))) < (𝐶‘(𝑅𝑘))))
3123, 30syl 17 . . . 4 ((𝐴𝑆𝑘 ∈ ℕ0) → ((𝐶‘(𝐹‘(𝑅𝑘))) ≠ 0 → (𝐶‘(𝐹‘(𝑅𝑘))) < (𝐶‘(𝑅𝑘))))
32 peano2nn0 12518 . . . . . . 7 (𝑘 ∈ ℕ0 → (𝑘 + 1) ∈ ℕ0)
33 fvco3 6963 . . . . . . 7 ((𝑅:ℕ0𝑆 ∧ (𝑘 + 1) ∈ ℕ0) → ((𝐶𝑅)‘(𝑘 + 1)) = (𝐶‘(𝑅‘(𝑘 + 1))))
347, 32, 33syl2an 605 . . . . . 6 ((𝐴𝑆𝑘 ∈ ℕ0) → ((𝐶𝑅)‘(𝑘 + 1)) = (𝐶‘(𝑅‘(𝑘 + 1))))
351, 2, 3, 4, 6algrp1 16591 . . . . . . 7 ((𝐴𝑆𝑘 ∈ ℕ0) → (𝑅‘(𝑘 + 1)) = (𝐹‘(𝑅𝑘)))
3635fveq2d 6867 . . . . . 6 ((𝐴𝑆𝑘 ∈ ℕ0) → (𝐶‘(𝑅‘(𝑘 + 1))) = (𝐶‘(𝐹‘(𝑅𝑘))))
3734, 36eqtrd 2796 . . . . 5 ((𝐴𝑆𝑘 ∈ ℕ0) → ((𝐶𝑅)‘(𝑘 + 1)) = (𝐶‘(𝐹‘(𝑅𝑘))))
3837neeq1d 3015 . . . 4 ((𝐴𝑆𝑘 ∈ ℕ0) → (((𝐶𝑅)‘(𝑘 + 1)) ≠ 0 ↔ (𝐶‘(𝐹‘(𝑅𝑘))) ≠ 0))
39 fvco3 6963 . . . . . 6 ((𝑅:ℕ0𝑆𝑘 ∈ ℕ0) → ((𝐶𝑅)‘𝑘) = (𝐶‘(𝑅𝑘)))
407, 39sylan 589 . . . . 5 ((𝐴𝑆𝑘 ∈ ℕ0) → ((𝐶𝑅)‘𝑘) = (𝐶‘(𝑅𝑘)))
4137, 40breq12d 5112 . . . 4 ((𝐴𝑆𝑘 ∈ ℕ0) → (((𝐶𝑅)‘(𝑘 + 1)) < ((𝐶𝑅)‘𝑘) ↔ (𝐶‘(𝐹‘(𝑅𝑘))) < (𝐶‘(𝑅𝑘))))
4231, 38, 413imtr4d 296 . . 3 ((𝐴𝑆𝑘 ∈ ℕ0) → (((𝐶𝑅)‘(𝑘 + 1)) ≠ 0 → ((𝐶𝑅)‘(𝑘 + 1)) < ((𝐶𝑅)‘𝑘)))
4315, 22, 42nn0seqcvgd 16587 . 2 (𝐴𝑆 → ((𝐶𝑅)‘𝑁) = 0)
4413, 43eqtr3d 2798 1 (𝐴𝑆 → (𝐶‘(𝑅𝑁)) = 0)
Colors of variables: wff setvar class
Syntax hints:  wi 4  wa 399   = wceq 1559  wcel 2141  wne 2956  {csn 4581   class class class wbr 5099   × cxp 5643  ccom 5649  wf 6513  cfv 6517  (class class class)co 7392  1st c1st 7964  0cc0 11070  1c1 11071   + caddc 11073   < clt 11213  0cn0 12478  seqcseq 14011
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-3 8  ax-gen 1814  ax-4 1828  ax-5 1929  ax-6 1986  ax-7 2027  ax-8 2143  ax-9 2151  ax-10 2174  ax-11 2190  ax-12 2211  ax-ext 2733  ax-sep 5245  ax-nul 5255  ax-pow 5321  ax-pr 5389  ax-un 7714  ax-cnex 11126  ax-resscn 11127  ax-1cn 11128  ax-icn 11129  ax-addcl 11130  ax-addrcl 11131  ax-mulcl 11132  ax-mulrcl 11133  ax-mulcom 11134  ax-addass 11135  ax-mulass 11136  ax-distr 11137  ax-i2m1 11138  ax-1ne0 11139  ax-1rid 11140  ax-rnegex 11141  ax-rrecex 11142  ax-cnre 11143  ax-pre-lttri 11144  ax-pre-lttrn 11145  ax-pre-ltadd 11146  ax-pre-mulgt0 11147
This theorem depends on definitions:  df-bi 209  df-an 400  df-or 859  df-3or 1098  df-3an 1099  df-tru 1562  df-fal 1572  df-ex 1799  df-nf 1803  df-sb 2090  df-mo 2565  df-eu 2595  df-clab 2740  df-cleq 2753  df-clel 2836  df-nfc 2910  df-ne 2957  df-nel 3061  df-ral 3076  df-rex 3086  df-reu 3367  df-rab 3414  df-v 3455  df-sbc 3745  df-csb 3853  df-dif 3907  df-un 3909  df-in 3911  df-ss 3921  df-pss 3924  df-nul 4286  df-if 4480  df-pw 4556  df-sn 4582  df-pr 4584  df-op 4588  df-uni 4865  df-iun 4950  df-br 5100  df-opab 5162  df-mpt 5181  df-tr 5207  df-id 5540  df-eprel 5545  df-po 5553  df-so 5554  df-fr 5598  df-we 5600  df-xp 5651  df-rel 5652  df-cnv 5653  df-co 5654  df-dm 5655  df-rn 5656  df-res 5657  df-ima 5658  df-pred 6284  df-ord 6345  df-on 6346  df-lim 6347  df-suc 6348  df-iota 6473  df-fun 6519  df-fn 6520  df-f 6521  df-f1 6522  df-fo 6523  df-f1o 6524  df-fv 6525  df-riota 7349  df-ov 7395  df-oprab 7396  df-mpo 7397  df-om 7843  df-1st 7966  df-2nd 7967  df-frecs 8257  df-wrecs 8288  df-recs 8337  df-rdg 8376  df-er 8673  df-en 8924  df-dom 8925  df-sdom 8926  df-pnf 11215  df-mnf 11216  df-xr 11217  df-ltxr 11218  df-le 11219  df-sub 11413  df-neg 11414  df-nn 12208  df-n0 12479  df-z 12566  df-uz 12837  df-fz 13510  df-seq 14012
This theorem is referenced by:  algcvga  16596
  Copyright terms: Public domain W3C validator