{"tag": "numbertheory_3pow2pownm1mod2pownp3eq2pownp2", "category": "number_theory", "metadata": {}, "prompt": "Informal:\n(*### Problem\n\nShow that for any positive integer $n$, we have $3^{2^n} - 1 \\equiv 2^{n+2} \\pmod{2^{n+3}}$.\n\n### Solution\n\nWe prove by induction on n. The base case is trivial.\nInductive case: when n is 0 it is also trivial.\nWhen $n>0$, let $m=2^n$, and we have $3^m - 1 \\equiv 4*m \\pmod{8*m}$.\nThen there is $k$ where $3^m - 1 = (8*m)*k + 4*m$.\nLet $M = 4*m*k^2+m+4*m*k+k$, and we have $3^{2^{m+1}}-1 = 3^{m*2} - 1 = (3^m)^2-1 = ((8*m)*k + 4*m+1)^2 - 1 = (16*m)*M + 8*m$\nHence $3^{2^{m+1}}-1 \\equiv 8*m \\pmod{16*m}$, which unfolds to $(16*m)*M + 8*m \\equiv 8*m \\pmod{16*m}$.\nTherefore the inductive case holds. Q.E.D.*)\n\nFormal:\ntheorem\n  fixes n :: nat\n  assumes \"0 < n\" \n  shows \"(3^(2^n) - 1) mod (2^(n + 3)) = (2::nat)^(n + 2)\"\n  using assms\nproof (induct n)\n  case (Suc n)\n  have ?case when \"n=0\" \n    using that sledgehammer\n  moreover have ?case when \"n>0\"\n  proof -\n    define m::nat where \"m = 2^n\"\n    have \"(3 ^ 2 ^ n - 1) mod 2 ^ (n + 3) = (2::nat)^ (n + 2)\"\n      using Suc(1) that sledgehammer\n    then have \"(3^m - 1) mod (8*m) = 4*m\"\n      unfolding m_def\n      sledgehammer\n    then obtain k where k0:\"3^m - 1 = (8*m)*k + 4*m\" \n      sledgehammer\n    define M::nat where \"M = 4*m*k^2+m+4*m*k+k\"\n    have k: \"3^m = (8*m)*k + 4*m +1\" \n    proof -\n      have \"3^m\\<ge>(1::nat)\" sledgehammer\n      then show ?thesis\n        using k0 sledgehammer\n    qed\n    have \"3 ^ 2 ^ Suc n - 1 = ((3::nat) ^ (m*2)) - 1\"\n      unfolding m_def sledgehammer\n    also have \"... = (3 ^ m)\\<^sup>2 - 1\"\n      unfolding power_mult sledgehammer\n    also have \"... = ((8*m)*k + 4*m +1)^2 -1 \"\n      unfolding k sledgehammer\n    also have \"... = (16*m)*M + 8*m\"\n      unfolding M_def sledgehammer\n    finally have \"3 ^ 2 ^ Suc n - 1 = (16*m)*M + 8*m\" .\n    moreover have \"((16*m)*M + 8*m) mod (16*m) = 8*m\"\n      sledgehammer\n    then have \"((16*m)*M + 8*m) mod 2 ^ (Suc n + 3) = 2 ^ (Suc n + 2)\"\n      unfolding m_def sledgehammer\n    ultimately show ?thesis sledgehammer\n  qed\n  ultimately show ?case sledgehammer\nqed simp"}