ILE Home Intuitionistic Logic Explorer < Previous   Next >
Nearby theorems
Mirrors  >  Home  >  ILE Home  >  Th. List  >  eucalglt GIF version

Theorem eucalglt 11989
Description: The second member of the state decreases with each iteration of the step function 𝐸 for Euclid's Algorithm. (Contributed by Paul Chapman, 31-Mar-2011.) (Revised by Mario Carneiro, 29-May-2014.)
Hypothesis
Ref Expression
eucalgval.1 𝐸 = (𝑥 ∈ ℕ0, 𝑦 ∈ ℕ0 ↦ if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩))
Assertion
Ref Expression
eucalglt (𝑋 ∈ (ℕ0 × ℕ0) → ((2nd ‘(𝐸𝑋)) ≠ 0 → (2nd ‘(𝐸𝑋)) < (2nd𝑋)))
Distinct variable group:   𝑥,𝑦,𝑋
Allowed substitution hints:   𝐸(𝑥,𝑦)

Proof of Theorem eucalglt
StepHypRef Expression
1 eucalgval.1 . . . . . . . 8 𝐸 = (𝑥 ∈ ℕ0, 𝑦 ∈ ℕ0 ↦ if(𝑦 = 0, ⟨𝑥, 𝑦⟩, ⟨𝑦, (𝑥 mod 𝑦)⟩))
21eucalgval 11986 . . . . . . 7 (𝑋 ∈ (ℕ0 × ℕ0) → (𝐸𝑋) = if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩))
32adantr 274 . . . . . 6 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (𝐸𝑋) = if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩))
4 simpr 109 . . . . . . . 8 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd ‘(𝐸𝑋)) ≠ 0)
5 iftrue 3525 . . . . . . . . . . . . 13 ((2nd𝑋) = 0 → if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩) = 𝑋)
65eqeq2d 2177 . . . . . . . . . . . 12 ((2nd𝑋) = 0 → ((𝐸𝑋) = if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩) ↔ (𝐸𝑋) = 𝑋))
7 fveq2 5486 . . . . . . . . . . . 12 ((𝐸𝑋) = 𝑋 → (2nd ‘(𝐸𝑋)) = (2nd𝑋))
86, 7syl6bi 162 . . . . . . . . . . 11 ((2nd𝑋) = 0 → ((𝐸𝑋) = if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩) → (2nd ‘(𝐸𝑋)) = (2nd𝑋)))
9 eqeq2 2175 . . . . . . . . . . 11 ((2nd𝑋) = 0 → ((2nd ‘(𝐸𝑋)) = (2nd𝑋) ↔ (2nd ‘(𝐸𝑋)) = 0))
108, 9sylibd 148 . . . . . . . . . 10 ((2nd𝑋) = 0 → ((𝐸𝑋) = if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩) → (2nd ‘(𝐸𝑋)) = 0))
113, 10syl5com 29 . . . . . . . . 9 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ((2nd𝑋) = 0 → (2nd ‘(𝐸𝑋)) = 0))
1211necon3ad 2378 . . . . . . . 8 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ((2nd ‘(𝐸𝑋)) ≠ 0 → ¬ (2nd𝑋) = 0))
134, 12mpd 13 . . . . . . 7 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ¬ (2nd𝑋) = 0)
1413iffalsed 3530 . . . . . 6 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → if((2nd𝑋) = 0, 𝑋, ⟨(2nd𝑋), ( mod ‘𝑋)⟩) = ⟨(2nd𝑋), ( mod ‘𝑋)⟩)
153, 14eqtrd 2198 . . . . 5 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (𝐸𝑋) = ⟨(2nd𝑋), ( mod ‘𝑋)⟩)
1615fveq2d 5490 . . . 4 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd ‘(𝐸𝑋)) = (2nd ‘⟨(2nd𝑋), ( mod ‘𝑋)⟩))
17 xp2nd 6134 . . . . . 6 (𝑋 ∈ (ℕ0 × ℕ0) → (2nd𝑋) ∈ ℕ0)
1817adantr 274 . . . . 5 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd𝑋) ∈ ℕ0)
19 1st2nd2 6143 . . . . . . . . 9 (𝑋 ∈ (ℕ0 × ℕ0) → 𝑋 = ⟨(1st𝑋), (2nd𝑋)⟩)
2019adantr 274 . . . . . . . 8 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → 𝑋 = ⟨(1st𝑋), (2nd𝑋)⟩)
2120fveq2d 5490 . . . . . . 7 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ( mod ‘𝑋) = ( mod ‘⟨(1st𝑋), (2nd𝑋)⟩))
22 df-ov 5845 . . . . . . 7 ((1st𝑋) mod (2nd𝑋)) = ( mod ‘⟨(1st𝑋), (2nd𝑋)⟩)
2321, 22eqtr4di 2217 . . . . . 6 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ( mod ‘𝑋) = ((1st𝑋) mod (2nd𝑋)))
24 xp1st 6133 . . . . . . . . 9 (𝑋 ∈ (ℕ0 × ℕ0) → (1st𝑋) ∈ ℕ0)
2524adantr 274 . . . . . . . 8 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (1st𝑋) ∈ ℕ0)
2625nn0zd 9311 . . . . . . 7 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (1st𝑋) ∈ ℤ)
2713neqned 2343 . . . . . . . 8 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd𝑋) ≠ 0)
28 elnnne0 9128 . . . . . . . 8 ((2nd𝑋) ∈ ℕ ↔ ((2nd𝑋) ∈ ℕ0 ∧ (2nd𝑋) ≠ 0))
2918, 27, 28sylanbrc 414 . . . . . . 7 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd𝑋) ∈ ℕ)
3026, 29zmodcld 10280 . . . . . 6 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ((1st𝑋) mod (2nd𝑋)) ∈ ℕ0)
3123, 30eqeltrd 2243 . . . . 5 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ( mod ‘𝑋) ∈ ℕ0)
32 op2ndg 6119 . . . . 5 (((2nd𝑋) ∈ ℕ0 ∧ ( mod ‘𝑋) ∈ ℕ0) → (2nd ‘⟨(2nd𝑋), ( mod ‘𝑋)⟩) = ( mod ‘𝑋))
3318, 31, 32syl2anc 409 . . . 4 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd ‘⟨(2nd𝑋), ( mod ‘𝑋)⟩) = ( mod ‘𝑋))
3416, 33, 233eqtrd 2202 . . 3 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd ‘(𝐸𝑋)) = ((1st𝑋) mod (2nd𝑋)))
35 zq 9564 . . . . 5 ((1st𝑋) ∈ ℤ → (1st𝑋) ∈ ℚ)
3626, 35syl 14 . . . 4 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (1st𝑋) ∈ ℚ)
3718nn0zd 9311 . . . . 5 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd𝑋) ∈ ℤ)
38 zq 9564 . . . . 5 ((2nd𝑋) ∈ ℤ → (2nd𝑋) ∈ ℚ)
3937, 38syl 14 . . . 4 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd𝑋) ∈ ℚ)
4029nngt0d 8901 . . . 4 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → 0 < (2nd𝑋))
41 modqlt 10268 . . . 4 (((1st𝑋) ∈ ℚ ∧ (2nd𝑋) ∈ ℚ ∧ 0 < (2nd𝑋)) → ((1st𝑋) mod (2nd𝑋)) < (2nd𝑋))
4236, 39, 40, 41syl3anc 1228 . . 3 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → ((1st𝑋) mod (2nd𝑋)) < (2nd𝑋))
4334, 42eqbrtrd 4004 . 2 ((𝑋 ∈ (ℕ0 × ℕ0) ∧ (2nd ‘(𝐸𝑋)) ≠ 0) → (2nd ‘(𝐸𝑋)) < (2nd𝑋))
4443ex 114 1 (𝑋 ∈ (ℕ0 × ℕ0) → ((2nd ‘(𝐸𝑋)) ≠ 0 → (2nd ‘(𝐸𝑋)) < (2nd𝑋)))
Colors of variables: wff set class
Syntax hints:  ¬ wn 3  wi 4  wa 103   = wceq 1343  wcel 2136  wne 2336  ifcif 3520  cop 3579   class class class wbr 3982   × cxp 4602  cfv 5188  (class class class)co 5842  cmpo 5844  1st c1st 6106  2nd c2nd 6107  0cc0 7753   < clt 7933  cn 8857  0cn0 9114  cz 9191  cq 9557   mod cmo 10257
This theorem was proved from axioms:  ax-mp 5  ax-1 6  ax-2 7  ax-ia1 105  ax-ia2 106  ax-ia3 107  ax-in1 604  ax-in2 605  ax-io 699  ax-5 1435  ax-7 1436  ax-gen 1437  ax-ie1 1481  ax-ie2 1482  ax-8 1492  ax-10 1493  ax-11 1494  ax-i12 1495  ax-bndl 1497  ax-4 1498  ax-17 1514  ax-i9 1518  ax-ial 1522  ax-i5r 1523  ax-13 2138  ax-14 2139  ax-ext 2147  ax-sep 4100  ax-pow 4153  ax-pr 4187  ax-un 4411  ax-setind 4514  ax-cnex 7844  ax-resscn 7845  ax-1cn 7846  ax-1re 7847  ax-icn 7848  ax-addcl 7849  ax-addrcl 7850  ax-mulcl 7851  ax-mulrcl 7852  ax-addcom 7853  ax-mulcom 7854  ax-addass 7855  ax-mulass 7856  ax-distr 7857  ax-i2m1 7858  ax-0lt1 7859  ax-1rid 7860  ax-0id 7861  ax-rnegex 7862  ax-precex 7863  ax-cnre 7864  ax-pre-ltirr 7865  ax-pre-ltwlin 7866  ax-pre-lttrn 7867  ax-pre-apti 7868  ax-pre-ltadd 7869  ax-pre-mulgt0 7870  ax-pre-mulext 7871  ax-arch 7872
This theorem depends on definitions:  df-bi 116  df-dc 825  df-3or 969  df-3an 970  df-tru 1346  df-fal 1349  df-nf 1449  df-sb 1751  df-eu 2017  df-mo 2018  df-clab 2152  df-cleq 2158  df-clel 2161  df-nfc 2297  df-ne 2337  df-nel 2432  df-ral 2449  df-rex 2450  df-reu 2451  df-rmo 2452  df-rab 2453  df-v 2728  df-sbc 2952  df-csb 3046  df-dif 3118  df-un 3120  df-in 3122  df-ss 3129  df-nul 3410  df-if 3521  df-pw 3561  df-sn 3582  df-pr 3583  df-op 3585  df-uni 3790  df-int 3825  df-iun 3868  df-br 3983  df-opab 4044  df-mpt 4045  df-id 4271  df-po 4274  df-iso 4275  df-xp 4610  df-rel 4611  df-cnv 4612  df-co 4613  df-dm 4614  df-rn 4615  df-res 4616  df-ima 4617  df-iota 5153  df-fun 5190  df-fn 5191  df-f 5192  df-fv 5196  df-riota 5798  df-ov 5845  df-oprab 5846  df-mpo 5847  df-1st 6108  df-2nd 6109  df-pnf 7935  df-mnf 7936  df-xr 7937  df-ltxr 7938  df-le 7939  df-sub 8071  df-neg 8072  df-reap 8473  df-ap 8480  df-div 8569  df-inn 8858  df-n0 9115  df-z 9192  df-q 9558  df-rp 9590  df-fl 10205  df-mod 10258
This theorem is referenced by:  eucalgcvga  11990
  Copyright terms: Public domain W3C validator