[
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_329 (x y : ℝ) (h₀ : 3 * y = x) (h₁ : 2 * x + 5 * y = 11) : x + y = 4 := by\n  have hx : x = 3 * y := by linarith\n  rw [hx] at h₁\n  have hy : y = 1 := by\n    linarith\n  have hx2 : x = 3 := by\n    rw [hy] at hx\n    linarith\n  linarith [hx2, hy]",
    "name": "mathd_algebra_329"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_239 : (∑ k in Finset.Icc 1 12, k) % 4 = 2 := by \n  norm_num [Finset.sum_Icc_succ_top, Nat.add_comm]",
    "name": "mathd_numbertheory_239"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_711 (m n : ℕ) (h₀ : 0 < m ∧ 0 < n) (h₁ : Nat.gcd m n = 8)\n    (h₂ : Nat.lcm m n = 112) : 72 ≤ m + n := by\n  have h3 : m * n = 896 := by \n    calc\n      m * n = m.gcd n * m.lcm n := by rw [Nat.gcd_mul_lcm]\n      _ = 8 * 112 := by rw [h₁, h₂]\n      _ = 896 := by norm_num\n  by_contra h\n  push_neg at h\n  have h4 : m ≤ 71 := by nlinarith\n  have h5 : n ≤ 71 := by nlinarith\n  interval_cases m <;> interval_cases n <;> norm_num at h₁ h₂ h3 <;> omega",
    "name": "mathd_numbertheory_711"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2009_p7 (x : ℝ) (n : ℕ) (a : ℕ → ℝ)\n    (h₁ : ∀ m, a (m + 1) - a m = a (m + 2) - a (m + 1)) (h₂ : a 1 = 2 * x - 3)\n    (h₃ : a 2 = 5 * x - 11) (h₄ : a 3 = 3 * x + 1) (h₅ : a n = 2009) : n = 502 := by\n\n  have h6 := h₁ 1\n  simp [h₂, h₃, h₄] at h6\n  have hx : x = 4 := by linarith\n\n  have h_a1 : a 1 = 5 := by\n    rw [h₂, hx]\n    norm_num\n\n  have h_a2 : a 2 = 9 := by\n    rw [h₃, hx]\n    norm_num\n\n  have h_a3 : a 3 = 13 := by\n    rw [h₄, hx]\n    norm_num\n\n  have seq_formula : ∀ m, a (m + 2) = 2 * a (m + 1) - a m := by\n    intro m\n    have h1 := h₁ m\n    linarith\n\n  have h_diff : ∀ m, a (m + 1) - a m = 4 := by\n    intro m\n    induction m with\n    | zero =>\n      have h1 := h₁ 0\n      simp [h_a1, h_a2] at h1\n      linarith\n    | succ m ih =>\n      have h1 := h₁ (m + 1)\n      simp at h1 ⊢\n      have h2 := h₁ m\n      simp at h2\n      linarith [ih, h2]\n\n  have h_a0 : a 0 = 1 := by\n    have h1 := h_diff 0\n    have h2 : a 1 = 5 := by linarith [h_a1]\n    simp [h2] at h1\n    linarith\n\n  have h_n : ∀ n, a n = 1 + 4 * n := by\n    intro n\n    induction n with\n    | zero =>\n      simp [h_a0]\n    | succ n ih =>\n      have h1 := h_diff n\n      simp [ih] at h1 ⊢\n      linarith\n\n  have h_eq : a n = 1 + 4 * n := h_n n\n  rw [h_eq] at h₅\n  have hn : (n : ℝ) = 502 := by\n    linarith\n  exact_mod_cast hn",
    "name": "amc12a_2009_p7"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_313 (v i z : ℂ) (h₀ : v = i * z) (h₁ : v = 1 + Complex.I)\n    (h₂ : z = 2 - Complex.I) : i = 1 / 5 + 3 / 5 * Complex.I := by \n  have h3 : i = v / z := by \n    rw [h₀]\n    field_simp [Complex.ext_iff, h₂]\n  rw [h3, h₁, h₂]\n  field_simp [Complex.ext_iff]\n  norm_num",
    "name": "mathd_algebra_313"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_541 (m n : ℕ) (h₀ : 1 < m) (h₁ : 1 < n) (h₂ : m * n = 2005) :\n    m + n = 406 := by\n  have h3 : m ≤ 2005 := by nlinarith\n  have h4 : n ≤ 2005 := by nlinarith\n  interval_cases m <;> omega",
    "name": "mathd_numbertheory_541"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_332 (x y : ℝ) (h₀ : (x + y) / 2 = 7) (h₁ : Real.sqrt (x * y) = Real.sqrt 19) :\n    x ^ 2 + y ^ 2 = 158 := by\n\n  have h2 : x + y = 14 := by linarith\n\n  have h3 : x * y = 19 := by\n    have h4 : Real.sqrt (x * y) = Real.sqrt 19 := h₁\n    have h5 : x * y ≥ 0 := by\n      have h6 : Real.sqrt 19 > 0 := by\n        apply Real.sqrt_pos.2\n        norm_num\n      have h7 : Real.sqrt (x * y) > 0 := by linarith [h₁, h6]\n      have h8 : Real.sqrt (x * y) ≥ 0 := Real.sqrt_nonneg (x * y)\n      by_contra h9\n      push_neg at h9\n      have h10 : Real.sqrt (x * y) = 0 := by\n        apply Real.sqrt_eq_zero_of_nonpos\n        linarith\n      linarith\n    have h9 : (19 : ℝ) ≥ 0 := by norm_num\n    have h11 : x * y = 19 := by\n      have h10 : Real.sqrt (x * y) = Real.sqrt 19 := h₁\n      have h12 : x * y = 19 := by\n        have h13 : x * y ≥ 0 := by linarith\n        have h14 : (19 : ℝ) ≥ 0 := by norm_num\n        have h15 : Real.sqrt (x * y) = Real.sqrt 19 := h₁\n        have h16 : x * y = 19 := by\n          rw [Real.sqrt_inj (by linarith) (by linarith)] at h15\n          linarith\n        linarith\n      linarith\n    linarith\n  have h4 : x^2 + y^2 = (x + y) ^ 2 - 2 * (x * y) := by\n    ring\n  rw [h4, h2, h3]\n  norm_num",
    "name": "mathd_algebra_332"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_others_exirrpowirrrat : ∃ a b, Irrational a ∧ Irrational b ∧ ¬Irrational (a ^ b) := by\n  by_cases h : Irrational ((Real.sqrt 2) ^ (Real.sqrt 2 : ℝ))\n  · -- Assume $\\sqrt{2}^{\\sqrt{2}}$ is irrational\n    use (Real.sqrt 2) ^ (Real.sqrt 2 : ℝ), Real.sqrt 2\n    constructor\n    · -- Show that $\\sqrt{2}^{\\sqrt{2}}$ is irrational (from assumption)\n      exact h\n    constructor\n    · -- Show that $\\sqrt{2}$ is irrational\n      apply irrational_sqrt_two\n    · -- Show that $(\\sqrt{2}^{\\sqrt{2}})^{\\sqrt{2}}$ is rational\n      have h1 : Real.sqrt 2 > (0 : ℝ) := by\n        apply Real.sqrt_pos.mpr\n        norm_num\n      have h2 : ((Real.sqrt 2) ^ (Real.sqrt 2 : ℝ)) ^ (Real.sqrt 2 : ℝ) = (Real.sqrt 2) ^ ((Real.sqrt 2 : ℝ) * (Real.sqrt 2 : ℝ)) := by\n        rw [Real.rpow_mul]\n        all_goals linarith [h1]\n      have h3 : (Real.sqrt 2 : ℝ) * (Real.sqrt 2 : ℝ) = (2 : ℝ) := by\n        exact Real.mul_self_sqrt (by norm_num)\n      rw [h2, h3]\n      have h4 : (Real.sqrt 2 : ℝ) ^ (2 : ℝ) = (2 : ℝ) := by\n        rw [show (2 : ℝ) = (2 : ℕ) by norm_num]\n        simp [Real.rpow_natCast, Real.sq_sqrt]\n        all_goals norm_num\n      rw [h4]\n      norm_num\n  · -- Assume $\\sqrt{2}^{\\sqrt{2}}$ is rational\n    use Real.sqrt 2, Real.sqrt 2\n    constructor\n    · -- Show that $\\sqrt{2}$ is irrational\n      apply irrational_sqrt_two\n    constructor\n    · -- Show that $\\sqrt{2}$ is irrational\n      apply irrational_sqrt_two\n    · -- Show that $\\sqrt{2}^{\\sqrt{2}}$ is rational\n      simpa using h",
    "name": "algebra_others_exirrpowirrrat"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_76 (f : ℤ → ℤ) (h₀ : ∀ n, Odd n → f n = n ^ 2)\n    (h₁ : ∀ n, Even n → f n = n ^ 2 - 4 * n - 1) : f 4 = -1 := by\n  have h_even : f 4 = 4 ^ 2 - 4 * 4 - 1 := by \n    apply h₁ \n    decide \n  norm_num at h_even \n  linarith",
    "name": "mathd_algebra_76"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem induction_12dvd4expnp1p20 (n : ℕ) : 12 ∣ 4 ^ (n + 1) + 20 := by\n  induction n with\n  | zero =>\n    norm_num\n  | succ k ih =>\n    have h1 : 4 ^ (k + 2) + 20 = 4 * (4 ^ (k + 1)) + 20 := by ring\n    rw [h1]\n    omega",
    "name": "induction_12dvd4expnp1p20"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_2varlineareq_fp3zeq11_3tfm1m5zeqn68_feqn10_zeq7 (f z : ℂ) (h₀ : f + 3 * z = 11)\n    (h₁ : 3 * (f - 1) - 5 * z = -68) : f = -10 ∧ z = 7 := by\n  have hz : z = 7 := by\n    have eq1 := h₀\n    have eq2 := h₁\n    have h2 : f = 11 - 3 * z := by\n      rw [←eq1]\n      ring\n    rw [h2] at eq2\n    simp [mul_sub, sub_eq_add_neg] at eq2\n    have hz' : z = 7 := by\n      have h_real: z.re = 7 := by \n        have eq2_real := congr_arg Complex.re eq2\n        simp [Complex.add_re, Complex.ofReal_re, Complex.I_re, Complex.add_im, Complex.ofReal_im, Complex.I_im] at eq2_real \n        linarith\n      have h_imag : z.im = 0 := by \n        have eq2_imag := congr_arg Complex.im eq2\n        simp [Complex.add_re, Complex.ofReal_re, Complex.I_re, Complex.add_im, Complex.ofReal_im, Complex.I_im] at eq2_imag \n        linarith\n      rw [Complex.ext_iff]\n      simp [h_real, h_imag]\n    exact hz'\n  have hf : f = -10 := by\n    rw [hz] at h₀\n    have : f = -10 := by \n      have h_real: f.re = -10 := by \n        have h₀_real := congr_arg Complex.re h₀\n        simp [Complex.add_re, Complex.ofReal_re, Complex.I_re, Complex.add_im, Complex.ofReal_im, Complex.I_im] at h₀_real \n        linarith\n      have h_imag : f.im = 0 := by \n        have h₀_imag := congr_arg Complex.im h₀\n        simp [Complex.add_re, Complex.ofReal_re, Complex.I_re, Complex.add_im, Complex.ofReal_im, Complex.I_im] at h₀_imag \n        linarith\n      rw [Complex.ext_iff]\n      simp [h_real, h_imag]\n    exact this\n  exact ⟨hf, hz⟩",
    "name": "algebra_2varlineareq_fp3zeq11_3tfm1m5zeqn68_feqn10_zeq7"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_227 (x y n : ℕ+) (h₀ : ↑x / (4 : ℝ) + y / 6 = (x + y) / n) : n = 5 := by\n\n  have h1 : (n : ℝ) ≠ 0 := by\n    exact_mod_cast Nat.not_eq_zero_of_lt n.pos\n\n  have h2 : (3 * (n : ℝ) * x + 2 * (n : ℝ) * y) = 12 * (x + y) := by\n    field_simp at h₀\n    linarith\n\n  have hx : (x : ℝ) > 0 := by\n    exact_mod_cast Nat.pos_of_ne_zero (by positivity)\n\n  have hy : (y : ℝ) > 0 := by\n    exact_mod_cast Nat.pos_of_ne_zero (by positivity)\n\n  have h3 : (n : ℝ) = 5 := by\n    have h4 : (3 * (n : ℝ) - 12) * x + (2 * (n : ℝ) - 12) * y = 0 := by\n      linarith\n\n    by_cases h₃ : (3 * (n : ℝ) - 12) > 0\n    · -- If 3 * n - 12 > 0, then we have (2 * n - 12) < 0\n      have h5 : (2 * (n : ℝ) - 12) < 0 := by\n        nlinarith [h4, hx, hy, h₃]\n\n      have h6 : (n : ℝ) < 6 := by linarith\n\n      have h7 : (n : ℝ) > 4 := by linarith\n\n      have h8 : (n : ℝ) = 5 := by\n        have h9 : ∃ k : ℕ, (n : ℝ) = k := by\n          refine ⟨n, by simp⟩\n        rcases h9 with ⟨k, hk⟩\n        have h10 : k < 6 := by\n          rify at h6 ⊢\n          linarith\n        have h11 : k > 4 := by\n          rify at h7 ⊢\n          linarith\n        interval_cases k <;> norm_num at *\n        all_goals linarith [hk]\n      linarith\n\n    · -- Now consider the case when 3 * n - 12 ≤ 0\n      have h₄ : (3 * (n : ℝ) - 12) ≤ 0 := by linarith\n\n      by_cases h₅ : (2 * (n : ℝ) - 12) ≥ 0\n      · -- If 2 * n - 12 ≥ 0, then we have (3n - 12) ≤ 0 and (2n - 12) ≥ 0\n        nlinarith\n\n      · -- Case 2.2: 2 * n - 12 < 0\n        have h₁₂ : (2 * (n : ℝ) - 12) < 0 := by linarith\n        nlinarith [h4, hx, hy, h₄, h₁₂]\n\n  exact_mod_cast h3",
    "name": "mathd_numbertheory_227"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem numbertheory_notequiv2i2jasqbsqdiv8 :\n    ¬∀ a b : ℤ, (∃ i j, a = 2 * i ∧ b = 2 * j) ↔ ∃ k, a ^ 2 + b ^ 2 = 8 * k := by\n  intro h\n  specialize h 2 4\n  have h1 : ∃ i j : ℤ, (2 = 2 * i) ∧ (4 = 2 * j) := by\n    use 1, 2\n    all_goals norm_num\n  have h2 : ¬∃ k : ℤ, (2 : ℤ) ^ 2 + (4 : ℤ) ^ 2 = 8 * k := by\n    intro h3\n    rcases h3 with ⟨k, hk⟩\n    have : (2 : ℤ) ^ 2 + (4 : ℤ) ^ 2 = 20 := by norm_num\n    rw [this] at hk\n    omega\n  have h3 := h.1 h1\n  exact h2 h3",
    "name": "numbertheory_notequiv2i2jasqbsqdiv8"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_521 (m n : ℕ) (h₀ : Even m) (h₁ : Even n) (h₂ : m - n = 2)\n    (h₃ : m * n = 288) : m = 18 := by\n  have h4 : m = n + 2 := by\n    omega\n  rw [h4] at h₃\n  have h5 : n ≤ 17 := by\n    nlinarith\n  interval_cases n <;> omega",
    "name": "mathd_numbertheory_521"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2021_p9 : (∏ k in Finset.range 7, (2 ^ 2 ^ k + 3 ^ 2 ^ k)) = 3 ^ 128 - 2 ^ 128 := by \n  norm_num [Finset.prod_range_succ]",
    "name": "amc12a_2021_p9"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_478 (b h v : ℝ) (h₀ : 0 < b ∧ 0 < h ∧ 0 < v) (h₁ : v = 1 / 3 * (b * h))\n    (h₂ : b = 30) (h₃ : h = 13 / 2) : v = 65 := by\n  rw [h₂, h₃] at h₁\n  linarith",
    "name": "mathd_algebra_478"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem numbertheory_x5neqy2p4 (x y : ℤ) : x ^ 5 ≠ y ^ 2 + 4 := by\n  by_contra h\n  have h1 : x ^ 5 % 11 = 0 ∨ x ^ 5 % 11 = 1 ∨ x ^ 5 % 11 = 10 := by \n    have h1 : x % 11 = 0 ∨ x % 11 = 1 ∨ x % 11 = 2 ∨ x % 11 = 3 ∨ x % 11 = 4 ∨ x % 11 = 5 ∨ x % 11 = 6 ∨ x % 11 = 7 ∨ x % 11 = 8 ∨ x % 11 = 9 ∨ x % 11 = 10 := by \n      omega \n    rcases h1 with (h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1) <;> ( \n      norm_num [h1, pow_succ, Int.add_emod, Int.sub_emod, Int.mul_emod] at * \n    )\n  have h2 : (y ^ 2 + 4) % 11 = 2 ∨ (y ^ 2 + 4) % 11 = 4 ∨ (y ^ 2 + 4) % 11 = 5 ∨ (y ^ 2 + 4) % 11 = 6 ∨ (y ^ 2 + 4) % 11 = 7 ∨ (y ^ 2 + 4) % 11 = 8 ∨ (y ^ 2 + 4) % 11 = 9 := by \n    have h2 : y % 11 = 0 ∨ y % 11 = 1 ∨ y % 11 = 2 ∨ y % 11 = 3 ∨ y % 11 = 4 ∨ y % 11 = 5 ∨ y % 11 = 6 ∨ y % 11 = 7 ∨ y % 11 = 8 ∨ y % 11 = 9 ∨ y % 11 = 10 := by \n      omega \n    rcases h2 with (h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2) <;> ( \n      norm_num [h2, pow_succ, Int.add_emod, Int.sub_emod, Int.mul_emod] at * \n    )\n  -- Using omega to derive the contradiction from modular constraints\n  omega",
    "name": "numbertheory_x5neqy2p4"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_296 : abs ((3491 - 60) * (3491 + 60) - 3491 ^ 2 : ℤ) = 3600 := by \n  norm_num",
    "name": "mathd_algebra_296"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_175 : 2 ^ 2010 % 10 = 4 := by \n  norm_num",
    "name": "mathd_numbertheory_175"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_188 (σ : Equiv ℝ ℝ) (h : σ.1 2 = σ.2 2) : σ.1 (σ.1 2) = 2 := by\n  have h1 : σ.1 (σ.2 2) = 2 := by \n    apply Equiv.right_inv _ 2\n  have h2 : σ.1 2 = σ.2 2 := h\n  calc\n    σ.1 (σ.1 2) = σ.1 (σ.2 2) := by rw [h2]\n    _ = 2 := by exact h1",
    "name": "mathd_algebra_188"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_185 (n : ℕ) (h₀ : n % 5 = 3) : 2 * n % 5 = 1 := by \n  omega -- The omega tactic is powerful for solving arithmetic goals involving natural numbers. It can deduce that if $n \\bmod 5 = 3$, then $2n \\bmod 5 = 1$ directly from the properties of modular arithmetic.",
    "name": "mathd_numbertheory_185"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_184 (a b : NNReal) (h₀ : 0 < a ∧ 0 < b) (h₁ : a ^ 2 = 6 * b)\n    (h₂ : a ^ 2 = 54 / b) : a = 3 * NNReal.sqrt 2 := by\n\n  have hb : b = 3 := by\n    have h_pos : 0 < b := h₀.right\n    have eq1 : a ^ 2 = 6 * b := h₁\n    have eq2 : a ^ 2 = 54 / b := h₂\n    have h3 : (6 * b : ℝ) = (54 / b : ℝ) := by\n      have h4 : (a ^ 2 : ℝ) = (6 * b : ℝ) := by\n        exact_mod_cast eq1\n      have h5 : (a ^ 2 : ℝ) = (54 / b : ℝ) := by\n        exact_mod_cast eq2\n      rw [h4] at h5\n      linarith\n    have h4 : (b : ℝ) ≠ 0 := by\n      have h5 : (b : ℝ) > 0 := by exact_mod_cast h_pos\n      linarith\n    have h5 : (b : ℝ) ^ 2 = 9 := by\n      have h6 : (6 * b : ℝ) = (54 / b : ℝ) := by\n        exact_mod_cast h3\n      field_simp at h6\n      nlinarith [h4]\n    have h6 : (b : ℝ) = 3 := by\n      have h7 : (b : ℝ) > 0 := by exact_mod_cast h_pos\n      have h8 : (b : ℝ) = 3 := by\n        have h9 : (b : ℝ) ^ 2 - 9 = 0 := by linarith\n        have h10 : ((b : ℝ) - 3) * ((b : ℝ) + 3) = 0 := by\n          rw [←h9]\n          ring\n        cases' (mul_eq_zero.mp h10) with h11 h12\n        · -- (b : ℝ) - 3 = 0\n          linarith\n        · -- (b : ℝ) + 3 = 0\n          have h13 : (b : ℝ) = -3 := by linarith\n          linarith [h7, h13]\n      exact h8\n    exact_mod_cast h6\n    all_goals linarith\n\n  have ha_sq : a ^ 2 = 18 := by\n    have h1 : a ^ 2 = 6 * b := h₁\n    rw [hb] at h1\n    have h2 : a ^ 2 = 18 := by\n      have h3 : (a ^ 2 : ℝ) = (6 * (3 : ℝ) : ℝ) := by\n        exact_mod_cast h1\n      norm_num at h3\n      exact_mod_cast h3\n    exact h2\n\n  have ha : a = 3 * NNReal.sqrt 2 := by\n    have h_pos : 0 < a := h₀.left\n    have h1 : a ^ 2 = 18 := ha_sq\n    have h2 : a = NNReal.sqrt 18 := by\n      rw [←h1]\n      field_simp [h_pos]\n    rw [h2]\n    have h3 : NNReal.sqrt 18 = 3 * NNReal.sqrt 2 := by\n      rw [NNReal.sqrt_eq_iff_sq_eq] <;> norm_num\n      <;> ring_nf <;> norm_num\n      <;> positivity\n    rw [h3]\n\n  exact ha",
    "name": "mathd_algebra_184"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1987_p5 (x y : ℤ) (h₀ : y ^ 2 + 3 * (x ^ 2 * y ^ 2) = 30 * x ^ 2 + 517) :\n    3 * (x ^ 2 * y ^ 2) = 588 := by\n        have h1 : 3 * (x ^ 2 * y ^ 2) = 30 * x ^ 2 + 517 - y^2 := by linarith\n        have h2 : y^2 ≤ 517 := by\n          nlinarith [sq_nonneg (x * y), sq_nonneg (x * y - 17), sq_nonneg (y - 17), sq_nonneg (x - 2), sq_nonneg (x + 2)]\n        have h3 : y ≤ 22 := by nlinarith [h2]\n        have h4 : y ≥ -22 := by nlinarith [sq_nonneg (y + 22), sq_nonneg (y + 21), sq_nonneg (y + 20), sq_nonneg (y + 19), sq_nonneg (y + 18), sq_nonneg (y + 17), sq_nonneg (y + 16), sq_nonneg (y + 15), sq_nonneg (y + 14), sq_nonneg (y + 13), sq_nonneg (y + 12), sq_nonneg (y + 11), sq_nonneg (y + 10), sq_nonneg (y + 9), sq_nonneg (y + 8), sq_nonneg (y + 7), sq_nonneg (y + 6), sq_nonneg (y + 5), sq_nonneg (y + 4), sq_nonneg (y + 3), sq_nonneg (y + 2), sq_nonneg (y + 1), sq_nonneg (y)]\n        interval_cases y <;> \n          try {\n            simp_all\n            <;> \n            ( \n              ring_nf \n              <;> \n              omega\n            )\n          }",
    "name": "aime_1987_p5"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_9onxpypzleqsum2onxpy (x y z : ℝ) (h₀ : 0 < x ∧ 0 < y ∧ 0 < z) :\n    9 / (x + y + z) ≤ 2 / (x + y) + 2 / (y + z) + 2 / (z + x) := by\n  have h1 : x + y + z > 0 := by nlinarith [h₀.left, h₀.right.left, h₀.right.right]\n  have h2 : x + y > 0 := by nlinarith [h₀.left, h₀.right.left]\n  have h3 : y + z > 0 := by nlinarith [h₀.right.left, h₀.right.right]\n  have h4 : z + x > 0 := by nlinarith [h₀.left, h₀.right.right]\n  have h5 : 9 / (x + y + z) ≤ 2 / (x + y) + 2 / (y + z) + 2 / (z + x) := by\n    have h6 : (x + y) * (y + z) * (z + x) > 0 := by\n      apply mul_pos\n      apply mul_pos\n      nlinarith\n      nlinarith\n      nlinarith\n    have h7 : 9 / (x + y + z) ≤ 2 / (x + y) + 2 / (y + z) + 2 / (z + x) := by\n      have h8 : 9 / (x + y + z) - (2 / (x + y) + 2 / (y + z) + 2 / (z + x)) ≤ 0 := by\n        have h9 : (x + y + z) > 0 := h1\n        have h10 : (x + y) > 0 := h2\n        have h11 : (y + z) > 0 := h3\n        have h12 : (z + x) > 0 := h4\n        have h13 : 9 / (x + y + z) - (2 / (x + y) + 2 / (y + z) + 2 / (z + x)) =\n          (9 * ((x + y) * (y + z) * (z + x)) - 2 * (x + y + z) * ((y + z) * (z + x) + (x + y) * (z + x) + (x + y) * (y + z))) / ((x + y + z) * (x + y) * (y + z) * (z + x)) := by\n          field_simp\n          ring\n        rw [h13]\n        have h14 : 9 * ((x + y) * (y + z) * (z + x)) - 2 * (x + y + z) * ((y + z) * (z + x) + (x + y) * (z + x) + (x + y) * (y + z)) ≤ 0 := by\n          nlinarith [sq_nonneg (x - y), sq_nonneg (y - z), sq_nonneg (z - x),\n            sq_nonneg (x - y + z), sq_nonneg (x + y - z), sq_nonneg (y + z - x),\n            mul_pos h2 h3, mul_pos h3 h4, mul_pos h4 h2]\n        have h15 : (x + y + z) * (x + y) * (y + z) * (z + x) > 0 := by\n          apply mul_pos\n          apply mul_pos\n          apply mul_pos\n          all_goals linarith\n        apply (div_nonpos_of_nonpos_of_nonneg (by linarith) (by nlinarith)).trans\n        · norm_num\n        all_goals linarith\n      linarith\n    linarith\n  exact h5",
    "name": "algebra_9onxpypzleqsum2onxpy"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_459 (a b c d : ℚ) (h₀ : 3 * a = b + c + d) (h₁ : 4 * b = a + c + d)\n    (h₂ : 2 * c = a + b + d) (h₃ : 8 * a + 10 * b + 6 * c = 24) : ↑d.den + d.num = 28 := by\n  have h4 : 5 * b = 4 * a := by\n    linarith [h₀, h₁]\n  have h5 : 3 * c = 5 * b := by \n    linarith [h₁, h₂]\n  have h6 : c = 4 / 3 * a := by\n    have h7 : 3 * c = 5 * b := by linarith [h₁, h₂]\n    have h8 : 5 * b = 4 * a := by linarith [h₀, h₁]\n    linarith\n  have ha : a = 1 := by \n    have h7 : 24 * a = 24 := by\n      have eq1 := h₃\n      have eq2 : 10 * b = 10 * (4 / 5 * a) := by \n        linarith [h4]\n      have eq3 : 6 * c = 6 * (4 / 3 * a) := by \n        linarith [h6]\n      rw [eq2, eq3] at eq1\n      linarith\n    linarith\n  have hb : b = 4 / 5 := by \n    have eq1 := h4\n    rw [ha] at eq1\n    linarith \n  have hc : c = 4 / 3 := by \n    have eq1 := h6\n    rw [ha] at eq1\n    linarith \n  have hd : d = 13 / 15 := by\n    have eq1 := h₀\n    rw [ha, hb, hc] at eq1\n    linarith\n  rw [hd]\n  norm_num",
    "name": "mathd_algebra_459"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2021_p3 (x : ℝ) (h₀ : 2 + 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53) : x = 3 / 4 := by\n  have h1 : 2 + 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53 := h₀\n  have h2 : 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53 - 2 := by\n    linarith\n  have h3 : 1 + 1 / (2 + 2 / (3 + x)) = 53 / 38 := by\n    have h2' : 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53 - 2 := by linarith\n    have h_pos : 1 + 1 / (2 + 2 / (3 + x)) ≠ 0 := by\n      by_contra h\n      rw [h] at h2'\n      norm_num at h2'\n    field_simp [h_pos] at h2'\n    linarith\n  have h4 : 1 / (2 + 2 / (3 + x)) = 15 / 38 := by\n    linarith\n  have h5 : 2 + 2 / (3 + x) = 38 / 15 := by\n    have h4' : 1 / (2 + 2 / (3 + x)) = 15 / 38 := by linarith\n    have h_pos2 : 2 + 2 / (3 + x) ≠ 0 := by\n      by_contra h\n      rw [h] at h4'\n      norm_num at h4'\n    field_simp [h_pos2] at h4'\n    linarith\n  have h6 : 2 / (3 + x) = 8 / 15 := by\n    have h5' : 2 + 2 / (3 + x) = 38 / 15 := by linarith\n    linarith\n  have h7 : 3 + x ≠ 0 := by\n    by_contra h\n    rw [h] at h6\n    norm_num at h6\n  have h8 : 2 = 8 / 15 * (3 + x) := by\n    field_simp [h7] at h6\n    linarith\n  have h9 : x = 3 / 4 := by\n    linarith\n  exact h9",
    "name": "amc12b_2021_p3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_141 (a b : ℝ) (h₁ : a * b = 180) (h₂ : 2 * (a + b) = 54) :\n    a ^ 2 + b ^ 2 = 369 := by\n  have h3 : a + b = 27 := by linarith\n  have h4 : a^2 + b^2 = (a + b) ^ 2 - 2 * (a * b) := by \n    ring\n  rw [h4, h3, h₁]\n  norm_num",
    "name": "mathd_algebra_141"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem induction_nfactltnexpnm1ngt3 (n : ℕ) (h₀ : 3 ≤ n) : n ! < n ^ (n - 1) := by\n\n  have h : n ≥ 3 := h₀\n  have h1 : n ! < n ^ (n - 1) := by\n    cases n with\n    | zero => \n      exfalso\n      linarith\n    | succ n => \n      cases n with\n      | zero => \n        exfalso\n        linarith\n      | succ n => \n        cases n with\n        | zero => \n          exfalso\n          linarith\n        | succ n => \n          cases n with\n          | zero => \n            norm_num [Nat.factorial]\n          | succ n => \n            have ih : (n + 3) ! < (n + 3) ^ ((n + 3) - 1) := by \n              have h2 : n + 3 ≥ 3 := by omega\n              apply induction_nfactltnexpnm1ngt3\n              omega\n            have h3 : (n + 4) ! = (n + 4) * (n + 3) ! := by \n              rw [Nat.factorial_succ]\n            have h4 : (n + 4) ^ ((n + 4) - 1) = (n + 4) ^ (n + 3) := by \n              simp [pow_succ]\n            rw [h3, h4]\n            have h5 : (n + 4) ^ (n + 3) = (n + 4) * (n + 4) ^ (n + 2) := by \n              ring\n            rw [h5]\n            have h6 : (n + 3) ! < (n + 3) ^ ((n + 3) - 1) := ih\n            have h7 : (n + 3) ^ ((n + 3) - 1) = (n + 3) ^ (n + 2) := by \n              simp [pow_succ]\n            rw [h7] at h6\n            have h8 : (n + 3) ^ (n + 2) < (n + 4) ^ (n + 2) := by \n              apply pow_lt_pow_left\n              all_goals omega\n            have h9 : (n + 3) ! < (n + 4) ^ (n + 2) := by \n              linarith\n            have h10 : (n + 4) * (n + 3) ! < (n + 4) * ((n + 4) ^ (n + 2)) := by \n              nlinarith [h9, show 0 < (n + 4) by omega]\n            linarith\n  exact h1",
    "name": "induction_nfactltnexpnm1ngt3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1990_p4 (x : ℝ) (h₀ : 0 < x) (h₁ : x ^ 2 - 10 * x - 29 ≠ 0)\n    (h₂ : x ^ 2 - 10 * x - 45 ≠ 0) (h₃ : x ^ 2 - 10 * x - 69 ≠ 0)\n    (h₄ : 1 / (x ^ 2 - 10 * x - 29) + 1 / (x ^ 2 - 10 * x - 45) - 2 / (x ^ 2 - 10 * x - 69) = 0) :\n    x = 13 := by \n        have h5 : x^2 - 10 * x - 29 ≠ 0 := h₁\n        have h6 : x^2 - 10 * x - 45 ≠ 0 := h₂\n        have h7 : x^2 - 10 * x - 69 ≠ 0 := h₃\n        have h_eq : (x - 13) * (x + 3) = 0 := by\n            field_simp [(show x^2 - 10 * x - 29 ≠ 0 by assumption), (show x^2 - 10 * x - 45 ≠ 0 by assumption), (show x^2 - 10 * x - 69 ≠ 0 by assumption)] at h₄\n            ring_nf at h₄\n            nlinarith [sq_nonneg (x - 13), sq_nonneg (x + 3), sq_nonneg (x^2 - 10 * x - 29), sq_nonneg (x^2 - 10 * x - 45), sq_nonneg (x^2 - 10 * x - 69)]\n        cases' (mul_eq_zero.mp h_eq) with h13 h3\n        · -- x - 13 = 0\n          linarith\n        · -- x + 3 = 0, so x = -3, contradicting 0 < x\n          linarith",
    "name": "aime_1990_p4"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_551 : 1529 % 6 = 5 := by\n  norm_num",
    "name": "mathd_numbertheory_551"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2020_p22 (t : ℝ) : (2 ^ t - 3 * t) * t / 4 ^ t ≤ 1 / 12 := by\n\n  have h1 : (2:ℝ) ^ (2 * t) - 12 * (2:ℝ) ^ t * t + 36 * t ^ 2 ≥ 0 := by\n    have h2 : (2:ℝ) ^ (2 * t) - 12 * (2:ℝ) ^ t * t + 36 * t ^ 2 = (2 ^ t - 6 * t) ^ 2 := by\n      ring_nf\n      <;> simp [Real.rpow_mul, Real.rpow_add]\n      <;> ring\n    rw [h2]\n    apply sq_nonneg\n\n  have h3 : (4:ℝ) ^ t > 0 := by\n    apply Real.rpow_pos_of_pos\n    norm_num\n\n  have h4 : (2 ^ t - 3 * t) * t ≤ (1 / 12) * (4 ^ t) := by\n    have h4 : (4:ℝ) ^ t = (2:ℝ) ^ (2 * t) := by\n      rw [show (4 : ℝ) = 2 ^ (2 : ℝ) by norm_num]\n      rw [Real.rpow_mul]\n      all_goals linarith\n    nlinarith [h1, h4, Real.rpow_pos_of_pos (show (0 : ℝ) < (2 : ℝ) by norm_num), Real.rpow_pos_of_pos (show (0 : ℝ) < (2 : ℝ) by norm_num)]\n\n  have h5 : (2 ^ t - 3 * t) * t / 4 ^ t ≤ 1 / 12 := by\n    have h_pos : (4:ℝ) ^ t > 0 := by\n      apply Real.rpow_pos_of_pos\n      norm_num\n    apply (div_le_iff₀ h_pos).mpr\n    linarith [h4]\n\n  linarith [h5]",
    "name": "amc12b_2020_p22"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_212 : 16 ^ 17 * 17 ^ 18 * 18 ^ 19 % 10 = 8 := by\n  norm_num",
    "name": "mathd_numbertheory_212"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_432 (x : ℝ) : (x + 3) * (2 * x - 6) = 2 * x ^ 2 - 18 := by\n  ring",
    "name": "mathd_algebra_432"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2021_p4 (m a : ℕ) (h₀ : 0 < m ∧ 0 < a) (h₁ : ↑m / ↑a = (3 : ℝ) / 4) :\n    (84 * ↑m + 70 * ↑a) / (↑m + ↑a) = (76 : ℝ) := by\n  have h2 : (m : ℝ) / (a : ℝ) = (3 : ℝ) / 4 := by\n    exact_mod_cast h₁\n  have h3 : (a : ℝ) ≠ 0 := by\n    have ha : (a : ℝ) > (0 : ℝ) := by\n      exact_mod_cast h₀.right\n    linarith\n  have h4 : (m : ℝ) = (3 : ℝ) / 4 * (a : ℝ) := by\n    have h5 : (a : ℝ) ≠ 0 := h3\n    field_simp at h2 ⊢\n    linarith\n  have h5 : (↑m + ↑a : ℝ) ≠ 0 := by\n    have ha : (a : ℝ) > 0 := by exact_mod_cast h₀.right\n    have hm : (m : ℝ) ≥ 0 := by\n      exact_mod_cast (show (m : ℝ) ≥ (0 : ℝ) by norm_num)\n    nlinarith [h4]\n  have h6 : (84 : ℝ) * ↑m + 70 * ↑a = 76 * (↑m + ↑a) := by\n    have h7 : (m : ℝ) = (3 : ℝ) / 4 * (a : ℝ) := h4\n    linarith\n  have h8 : (84 * (m : ℝ) + 70 * (a : ℝ)) / ((m : ℝ) + (a : ℝ)) = (76 : ℝ) := by\n    have h9 : (84 : ℝ) * ↑m + 70 * ↑a = 76 * (↑m + ↑a) := h6\n    have h10 : (↑m + ↑a : ℝ) ≠ 0 := by\n      exact_mod_cast h5\n    field_simp at *\n    linarith\n  exact h8",
    "name": "amc12b_2021_p4"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2002_p19 (a b c : ℝ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : a * (b + c) = 152)\n    (h₂ : b * (c + a) = 162) (h₃ : c * (a + b) = 170) : a * b * c = 720 := by\n\n  have pos_a : 0 < a := h₀.1\n  have pos_b : 0 < b := h₀.2.1\n  have pos_c : 0 < c := h₀.2.2\n\n  have eq1 : a * b + a * c = 152 := by linarith\n\n  have eq2 : b * a + b * c = 162 := by linarith\n\n  have eq3 : c * a + c * b = 170 := by linarith\n\n  have h4 : a * b = 72 := by\n    nlinarith [mul_pos pos_a pos_b, mul_pos pos_b pos_c, mul_pos pos_a pos_c, eq1, eq2, eq3]\n\n  have h5 : b * c = 90 := by\n    nlinarith [mul_pos pos_a pos_b, mul_pos pos_b pos_c, mul_pos pos_a pos_c, eq1, eq2, eq3]\n\n  have h6 : a * c = 80 := by\n    nlinarith [mul_pos pos_a pos_b, mul_pos pos_b pos_c, mul_pos pos_a pos_c, eq1, eq2, eq3]\n\n  have h7 : a * b * c = 720 := by\n    nlinarith [mul_pos pos_a pos_b, mul_pos pos_b pos_c, mul_pos pos_a pos_c, h4, h5, h6]\n\n  exact h7",
    "name": "amc12b_2002_p19"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_288 (x y : ℝ) (n : NNReal) (h₀ : x < 0 ∧ y < 0) (h₁ : abs y = 6)\n    (h₂ : Real.sqrt ((x - 8) ^ 2 + (y - 3) ^ 2) = 15)\n    (h₃ : Real.sqrt (x ^ 2 + y ^ 2) = Real.sqrt n) : n = 52 := by\n        have hy : y = -6 := by\n            cases eq_or_eq_neg_of_abs_eq h₁ with\n            | inl h => linarith [h₀.right]\n            | inr h => linarith\n        have h2' : (x - 8) ^ 2 + (y - 3) ^ 2 = 15 ^ 2 := by\n            calc\n                (x - 8) ^ 2 + (y - 3) ^ 2 = (Real.sqrt ((x - 8) ^ 2 + (y - 3) ^ 2)) ^ 2 := by rw [Real.sq_sqrt]; positivity\n                _ = 15 ^ 2 := by rw [h₂]\n        rw [hy] at h2'\n        have hx_eq : x = -4 := by\n            have h4 : (x - 8) ^ 2 = 144 := by\n                nlinarith\n            have h5 : x - 8 = 12 ∨ x - 8 = -12 := by\n                apply eq_or_eq_neg_of_sq_eq_sq\n                norm_num\n                linarith\n            cases h5 with\n            | inl h12 =>\n                have hx : x = 20 := by linarith\n                linarith [h₀.left, hx]\n            | inr h_neg12 =>\n                have hx : x = -4 := by linarith\n                exact hx\n        have h3 : (x : ℝ) ^ 2 + (y : ℝ) ^ 2 = (n : ℝ) := by\n            have h3_1 : Real.sqrt (x^2 + y^2) = Real.sqrt n := h₃\n            have h3_2 : (x^2 + y^2 : ℝ) = (n : ℝ) := by\n                have h4 : (Real.sqrt (x ^ 2 + y ^ 2)) ^ 2 = (Real.sqrt n) ^ 2 := by rw [h3_1]\n                rw [Real.sq_sqrt (by positivity), Real.sq_sqrt (by positivity)] at h4\n                linarith\n            exact_mod_cast h3_2\n        rw [hx_eq, hy] at h3\n        norm_num at h3\n        have hn : (n : ℝ) = 52 := by linarith\n        exact_mod_cast hn",
    "name": "mathd_algebra_288"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_114 (a : ℝ) (h₀ : a = 8) :\n    (16 * (a ^ 2) ^ ((1 : ℝ) / 3)) ^ ((1 : ℝ) / 3) = 4 := by\n  rw [h₀]\n  have h1 : (16 * ((8 : ℝ) ^ 2) ^ ((1 : ℝ) / 3)) ^ ((1 : ℝ) / 3) = 4 := by\n    have h2 : (8 : ℝ) ^ 2 = (64 : ℝ) := by norm_num\n    rw [h2]\n    have h3 : (64 : ℝ) ^ ((1 : ℝ) / 3) = 4 := by\n      have h4 : (64 : ℝ) = 4 ^ (3 : ℝ) := by norm_num\n      rw [h4]\n      rw [← Real.rpow_mul]\n      norm_num\n      all_goals norm_num\n    have h4 : (16 : ℝ) * (64 : ℝ) ^ ((1 : ℝ) / 3) = (64 : ℝ) := by\n      rw [h3]\n      norm_num\n    rw [h4]\n    rw [h3]\n  exact h1",
    "name": "mathd_algebra_114"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_559 (x y : ℕ) (h₀ : x % 3 = 2) (h₁ : y % 5 = 4) (h₂ : x % 10 = y % 10) :\n    14 ≤ x := by\n  have hy1 : y % 10 = 4 ∨ y % 10 = 9 := by\n    have h4 : y % 5 = 4 := h₁\n    omega\n  rcases hy1 with hy1 | hy1\n  · -- Case 1: y % 10 = 4\n    have hx1 : x % 10 = 4 := by omega\n    omega\n  · -- Case 2: y % 10 = 9\n    have hx1 : x % 10 = 9 := by omega\n    omega",
    "name": "mathd_numbertheory_559"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1988_p8 (f : ℕ → ℕ → ℝ) (h₀ : ∀ x, 0 < x → f x x = x)\n    (h₁ : ∀ x y, 0 < x ∧ 0 < y → f x y = f y x)\n    (h₂ : ∀ x y, 0 < x ∧ 0 < y → (↑x + ↑y) * f x y = y * f x (x + y)) : f 14 52 = 364 := by\n  have h1 : (14 + 52 : ℝ) * f 14 52 = 52 * f 14 66 := by\n    specialize h₂ 14 52 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n  \n  have h2 : (14 + 38 : ℝ) * f 14 38 = 38 * f 14 52 := by\n    specialize h₂ 14 38 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n\n  have h3 : (14 + 24 : ℝ) * f 14 24 = 24 * f 14 38 := by\n    specialize h₂ 14 24 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n\n  have h4 : (14 + 10 : ℝ) * f 14 10 = 10 * f 14 24 := by\n    specialize h₂ 14 10 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n  \n  have h5 : f 14 10 = f 10 14 := by\n    specialize h₁ 14 10 ⟨by norm_num, by norm_num⟩\n    linarith\n\n  have h6 : (10 + 4 : ℝ) * f 10 4 = 4 * f 10 14 := by\n    specialize h₂ 10 4 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n  \n  have h7 : f 10 4 = f 4 10 := by\n    specialize h₁ 10 4 ⟨by norm_num, by norm_num⟩\n    linarith\n\n  have h8 : (4 + 6 : ℝ) * f 4 6 = 6 * f 4 10 := by\n    specialize h₂ 4 6 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n\n  have h9 : (4 + 2 : ℝ) * f 4 2 = 2 * f 4 6 := by\n    specialize h₂ 4 2 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n\n  have h10 : f 2 2 = (2 : ℝ) := by\n    specialize h₀ 2 (by norm_num)\n    norm_num at h₀\n    linarith\n  \n  have h11 : (2 + 2 : ℝ) * f 2 2 = 2 * f 2 4 := by\n    specialize h₂ 2 2 ⟨by norm_num, by norm_num⟩\n    norm_num at h₂\n    linarith\n  \n  have h12 : (f 2 4 : ℝ) = 4 := by \n    have h13 : (f 2 4 : ℝ) = 2 * f 2 2 := by\n      linarith\n    rw [h10] at h13\n    linarith\n\n  have h13 : f 4 2 = (4 : ℝ) := by \n    have h14 : f 4 2 = f 2 4 := by\n      specialize h₁ 4 2 ⟨by norm_num, by norm_num⟩\n      linarith\n    rw [h14, h12]\n\n  have h14 : (f 4 6 : ℝ) = 12 := by \n    have h15 : (6 : ℝ) * f 4 2 = 2 * f 4 6 := by\n      linarith [h9]\n    rw [h13] at h15\n    linarith\n  \n  have h15 : (f 4 10 : ℝ) = 20 := by \n    have h16 : (10 : ℝ) * f 4 6 = 6 * f 4 10 := by\n      linarith [h8]\n    rw [h14] at h16\n    linarith\n\n  have h16 : (f 10 14 : ℝ) = 70 := by \n    have h17 : (14 : ℝ) * f 10 4 = 4 * f 10 14 := by\n      linarith [h6]\n    have h18 : f 10 4 = (20 : ℝ) := by\n      linarith [h15, h7]\n    rw [h18] at h17\n    linarith\n\n  have h17 : (f 14 24 : ℝ) = 168 := by \n    have h19 : (24 : ℝ) * f 14 10 = 10 * f 14 24 := by\n      linarith [h4]\n    have h20 : (f 14 10 : ℝ) = 70 := by\n      linarith [h16, h5]\n    rw [h20] at h19\n    linarith\n\n  have h18 : (f 14 38 : ℝ) = 266 := by \n    have h21 : (38 : ℝ) * f 14 24 = 24 * f 14 38 := by\n      linarith [h3]\n    rw [h17] at h21\n    linarith\n  \n  have h19 : (f 14 52 : ℝ) = 364 := by \n    have h22 : (52 : ℝ) * f 14 38 = 38 * f 14 52 := by\n      linarith [h2]\n    rw [h18] at h22\n    linarith\n\n  exact h19",
    "name": "aime_1988_p8"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12_2000_p12 (a m c : ℕ) (h₀ : a + m + c = 12) :\n    a * m * c + a * m + m * c + a * c ≤ 112 := by \n  have h1 : a ≤ 12 := by omega\n  have h2 : m ≤ 12 := by omega\n  have h3 : c ≤ 12 := by omega\n\n  interval_cases a <;> interval_cases m <;> omega",
    "name": "amc12_2000_p12"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1963_p5 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) = 1 / 2 := by\n  have h : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) = 1 / 2 := by\n    have h1 : Real.cos (Real.pi / 7) > 0 := by\n      apply Real.cos_pos_of_mem_Ioo\n      constructor\n      · linarith [Real.pi_pos]\n      · linarith [Real.pi_pos]\n    have h2 : Real.cos (2 * Real.pi / 7) > 0 := by\n      apply Real.cos_pos_of_mem_Ioo\n      constructor\n      · linarith [Real.pi_pos]\n      · linarith [Real.pi_pos]\n    have h3 : Real.cos (3 * Real.pi / 7) > 0 := by\n      apply Real.cos_pos_of_mem_Ioo\n      constructor\n      · linarith [Real.pi_pos]\n      · linarith [Real.pi_pos]\n    have h4 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) = 1 / 2 := by\n      have h5 : Real.sin (Real.pi / 7) > 0 := by\n        apply Real.sin_pos_of_pos_of_lt_pi\n        · linarith [Real.pi_pos]\n        · linarith [Real.pi_pos]\n      have h6 : 2 * Real.sin (Real.pi / 7) * (Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2) = 0 := by\n        have h1 : 2 * Real.sin (Real.pi / 7) * (Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2) =\n            (2 * Real.sin (Real.pi / 7) * Real.cos (Real.pi / 7)) -\n            (2 * Real.sin (Real.pi / 7) * Real.cos (2 * Real.pi / 7)) +\n            (2 * Real.sin (Real.pi / 7) * Real.cos (3 * Real.pi / 7)) -\n            (2 * Real.sin (Real.pi / 7) * (1 / 2)) := by ring\n        rw [h1]\n        have h2 : 2 * Real.sin (Real.pi / 7) * Real.cos (Real.pi / 7) = Real.sin (2 * Real.pi / 7) := by\n          have h_sin2 : Real.sin (2 * Real.pi / 7) = 2 * Real.sin (Real.pi / 7) * Real.cos (Real.pi / 7) := by\n            rw [show 2 * Real.pi / 7 = 2 * (Real.pi / 7) by ring]\n            rw [Real.sin_two_mul]\n          linarith\n        rw [h2]\n        have h3 : 2 * Real.sin (Real.pi / 7) * Real.cos (2 * Real.pi / 7) = Real.sin (3 * Real.pi / 7) + Real.sin (Real.pi / 7 - 2 * Real.pi / 7) := by\n          rw [show 2 * Real.sin (Real.pi / 7) * Real.cos (2 * Real.pi / 7) = Real.sin ((Real.pi / 7) + (2 * Real.pi / 7)) + Real.sin ((Real.pi / 7) - (2 * Real.pi / 7)) by rw [Real.sin_add, Real.sin_sub]; ring]\n          ring\n        have h4 : 2 * Real.sin (Real.pi / 7) * Real.cos (3 * Real.pi / 7) = Real.sin (4 * Real.pi / 7) + Real.sin (Real.pi / 7 - 3 * Real.pi / 7) := by\n          rw [show 2 * Real.sin (Real.pi / 7) * Real.cos (3 * Real.pi / 7) = Real.sin ((Real.pi / 7) + (3 * Real.pi / 7)) + Real.sin ((Real.pi / 7) - (3 * Real.pi / 7)) by rw [Real.sin_add, Real.sin_sub]; ring]\n          ring\n        rw [h3, h4]\n        have h5 : Real.sin (Real.pi / 7 - 2 * Real.pi / 7) = - Real.sin (Real.pi / 7) := by\n          have h : Real.pi / 7 - 2 * Real.pi / 7 = -(Real.pi / 7) := by ring\n          rw [h]\n          rw [Real.sin_neg]\n        have h6 : Real.sin (Real.pi / 7 - 3 * Real.pi / 7) = - Real.sin (2 * Real.pi / 7) := by\n          have h : Real.pi / 7 - 3 * Real.pi / 7 = -(2 * Real.pi / 7) := by ring\n          rw [h]\n          rw [Real.sin_neg]\n        rw [h5, h6]\n        have h7 : Real.sin (4 * Real.pi / 7) = Real.sin (3 * Real.pi / 7) := by\n          have h : 4 * Real.pi / 7 = Real.pi - 3 * Real.pi / 7 := by ring\n          rw [h]\n          rw [Real.sin_pi_sub]\n        linarith [h7]\n      have h7 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2 = 0 := by\n        have h8 : Real.sin (Real.pi / 7) ≠ 0 := by\n          linarith [h5]\n        have h9 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2 = 0 := by\n          have eq1 : 2 * Real.sin (Real.pi / 7) * (Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2) = 0 := by\n            linarith [h6]\n          have eq2 : Real.sin (Real.pi / 7) ≠ 0 := by\n            assumption\n          have eq3 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2 = 0 := by\n            apply (mul_eq_zero.mp eq1).resolve_left\n            simp [eq2]\n          linarith\n        linarith\n      linarith\n    linarith\n  linarith",
    "name": "imo_1963_p5"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_139 (s : ℝ → ℝ → ℝ)\n    (h₀ : ∀ (x) (_ : x ≠ 0), ∀ (y) (_ : y ≠ 0), s x y = (1 / y - 1 / x) / (x - y)) :\n    s 3 11 = 1 / 33 := by\n  have h1 := h₀ 3 (by norm_num) 11 (by norm_num)\n  rw [h1]\n  norm_num",
    "name": "mathd_algebra_139"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_769 : (129 ^ 34 + 96 ^ 38) % 11 = 9 := by \n  norm_num",
    "name": "mathd_numbertheory_769"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2002_p2 (x : ℤ) (h₀ : x = 4) :\n    (3 * x - 2) * (4 * x + 1) - (3 * x - 2) * (4 * x) + 1 = 11 := by \n  rw [h₀]\n  norm_num",
    "name": "amc12b_2002_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_293 (n : ℕ) (h₀ : n ≤ 9) (h₁ : 11 ∣ 20 * 100 + 10 * n + 7) : n = 5 := by \n  omega",
    "name": "mathd_numbertheory_293"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2020_p2 :\n    (100 ^ 2 - 7 ^ 2 : ℝ) / (70 ^ 2 - 11 ^ 2) * ((70 - 11) * (70 + 11) / ((100 - 7) * (100 + 7))) =\n      1 := by \n  norm_num",
    "name": "amc12b_2020_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_12 :\n    Finset.card (Finset.filter (fun x => 20 ∣ x) (Finset.Icc 15 85)) = 4 := by \n  native_decide",
    "name": "mathd_numbertheory_12"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1959_p1 (n : ℕ) (h₀ : 0 < n) : Nat.gcd (21 * n + 4) (14 * n + 3) = 1 := by \n  have h1 : Nat.gcd (21 * n + 4) (14 * n + 3) = 1 := by\n    have h2 : 21 * n + 4 = (14 * n + 3) * 1 + (7 * n + 1) := by omega\n    have h3 : 14 * n + 3 = (7 * n + 1) * 2 + 1 := by omega\n    rw [h2]\n    rw [h3]\n    <;> simp [Nat.gcd]\n    <;> omega\n  exact h1",
    "name": "imo_1959_p1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_484 : Real.log 27 / Real.log 3 = 3 := by\n  have h1 : Real.log 27 = 3 * Real.log 3 := by\n    rw [show (27 : ℝ) = (3 ^ (3 : ℝ)) by norm_num]\n    simp [Real.log_rpow]\n  have h2 : Real.log 3 ≠ 0 := by\n    have h3 : Real.log 3 > 0 := by\n      apply Real.log_pos\n      norm_num\n    linarith\n  field_simp [h2]\n  linarith [h1]",
    "name": "mathd_algebra_484"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_254 : (239 + 174 + 83) % 10 = 6 := by \n  norm_num",
    "name": "mathd_numbertheory_254"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2021_p14 :\n    ((∑ k in Finset.Icc 1 20, Real.logb (5 ^ k) (3 ^ k ^ 2)) *\n        ∑ k in Finset.Icc 1 100, Real.logb (9 ^ k) (25 ^ k)) = 21000 := by\n\n  have h1 : (∑ k in Finset.Icc 1 20, Real.logb (5 ^ k) (3 ^ k ^ 2)) = (210 : ℝ) * (Real.logb 5 3) := by\n    simp [Finset.sum_Icc_succ_top, Real.logb]\n    <;> ring_nf <;> field_simp <;> ring\n    <;> norm_num\n\n  have h2 : (∑ k in Finset.Icc 1 100, Real.logb (9 ^ k) (25 ^ k)) = (100 : ℝ) * (Real.logb 9 25) := by\n    simp [Finset.sum_Icc_succ_top, Real.logb]\n    <;> ring_nf <;> field_simp <;> ring\n    <;> norm_num\n\n  rw [h1, h2]\n  \n  have h3 : Real.logb 9 25 = Real.logb 3 5 := by\n    have h31 : Real.logb 9 25 = Real.log 25 / Real.log 9 := by\n      simp [Real.logb]\n    have h32 : Real.logb 3 5 = Real.log 5 / Real.log 3 := by\n      simp [Real.logb]\n    rw [h31, h32]\n    have h33 : Real.log 25 = 2 * Real.log 5 := by\n      rw [show (25 : ℝ) = 5 ^ 2 by norm_num]\n      simp [Real.log_pow]\n    have h34 : Real.log 9 = 2 * Real.log 3 := by\n      rw [show (9 : ℝ) = 3 ^ 2 by norm_num]\n      simp [Real.log_pow]\n    rw [h33, h34]\n    ring\n  \n  rw [h3]\n  have h4 : Real.logb 5 3 * Real.logb 3 5 = 1 := by\n    have h41 : Real.logb 5 3 = Real.log 3 / Real.log 5 := by\n      simp [Real.logb]\n    have h42 : Real.logb 3 5 = Real.log 5 / Real.log 3 := by\n      simp [Real.logb]\n    rw [h41, h42]\n    field_simp\n\n  have h5 : (210 : ℝ) * Real.logb 5 3 * (100 : ℝ) * Real.logb 3 5 = 21000 := by\n    have h51 : (210 : ℝ) * Real.logb 5 3 * (100 : ℝ) * Real.logb 3 5 = \n        (210 * 100 : ℝ) * (Real.logb 5 3 * Real.logb 3 5) := by ring\n    rw [h51]\n    have h52 : Real.logb 5 3 * Real.logb 3 5 = 1 := by \n      linarith [h4]\n    rw [h52]\n    norm_num\n  \n  linarith [h5]",
    "name": "amc12a_2021_p14"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_277 (m n : ℕ) (h₀ : Nat.gcd m n = 6) (h₁ : Nat.lcm m n = 126) :\n    60 ≤ m + n := by \n  have h2 : m * n = 6 * 126 := by \n    calc\n      m * n = Nat.gcd m n * Nat.lcm m n := by rw [Nat.gcd_mul_lcm]\n      _ = 6 * 126 := by rw [h₀, h₁]\n  by_contra h\n  push_neg at h\n  have h3 : m ≤ 60 := by nlinarith\n  have h4 : n ≤ 60 := by nlinarith\n  interval_cases m <;> interval_cases n <;> norm_num at h₀ h₁ h2 <;> all_goals \n    omega",
    "name": "mathd_numbertheory_277"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_137 (x : ℕ) (h₀ : ↑x + (4 : ℝ) / (100 : ℝ) * ↑x = 598) : x = 575 := by \n  have h1 : (x : ℝ) + (4 : ℝ) / (100 : ℝ) * (x : ℝ) = 598 := by \n    exact_mod_cast h₀\n  have hx : (x : ℝ) = 575 := by \n    linarith\n  exact_mod_cast hx",
    "name": "mathd_algebra_137"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_247 (n : ℕ) (h₀ : 3 * n % 11 = 2) : n % 11 = 8 := by \n  have h1 : n % 11 = 8 := by \n    omega\n  exact h1",
    "name": "mathd_numbertheory_247"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_328 : 5 ^ 999999 % 7 = 6 := by \n  norm_num",
    "name": "mathd_numbertheory_328"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_233 (b : ZMod (11 ^ 2)) (h₀ : b = 24⁻¹) : b = 116 := by\n  rw [h₀]\n  native_decide",
    "name": "mathd_numbertheory_233"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_517 : 121 * 122 * 123 % 4 = 2 := by \n  norm_num",
    "name": "mathd_numbertheory_517"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_153 (n : ℝ) (h₀ : n = 1 / 3) :\n    Int.floor (10 * n) + Int.floor (100 * n) + Int.floor (1000 * n) + Int.floor (10000 * n) = 3702 := by \n  rw [h₀]\n  norm_num [Int.floor_eq_iff]",
    "name": "mathd_algebra_153"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_160 (n x : ℝ) (h₀ : n + x = 97) (h₁ : n + 5 * x = 265) : n + 2 * x = 139 := by \n  linarith",
    "name": "mathd_algebra_160"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1989_p8 (a b c d e f g : ℝ)\n    (h₀ : a + 4 * b + 9 * c + 16 * d + 25 * e + 36 * f + 49 * g = 1)\n    (h₁ : 4 * a + 9 * b + 16 * c + 25 * d + 36 * e + 49 * f + 64 * g = 12)\n    (h₂ : 9 * a + 16 * b + 25 * c + 36 * d + 49 * e + 64 * f + 81 * g = 123) :\n    16 * a + 25 * b + 36 * c + 49 * d + 64 * e + 81 * f + 100 * g = 334 := by\n  \n  have eq1 : 3 * a + 5 * b + 7 * c + 9 * d + 11 * e + 13 * f + 15 * g = 11 := by \n    linarith\n  \n  have eq2 : 5 * a + 7 * b + 9 * c + 11 * d + 13 * e + 15 * f + 17 * g = 111 := by \n    linarith\n\n  have h_sum : a + b + c + d + e + f + g = 50 := by\n    have temp : 2 * a + 2 * b + 2 * c + 2 * d + 2 * e + 2 * f + 2 * g = 100 := by \n      linarith [eq1, eq2]\n    linarith\n\n  have eq3 : 7 * a + 9 * b + 11 * c + 13 * d + 15 * e + 17 * f + 19 * g = 211 := by \n    linarith [eq2, h_sum]\n\n  have h3 : 16 * a + 25 * b + 36 * c + 49 * d + 64 * e + 81 * f + 100 * g = 334 := by \n    linarith [h₂, eq3]\n\n  exact h3",
    "name": "aime_1989_p8"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2021_p8 (d : ℕ → ℕ) (h₀ : d 0 = 0) (h₁ : d 1 = 0) (h₂ : d 2 = 1)\n    (h₃ : ∀ n ≥ 3, d n = d (n - 1) + d (n - 3)) : Even (d 2021) ∧ Odd (d 2022) ∧ Even (d 2023) := by\n\n  have h3_eq : d 3 = 1 := by\n    have h3 := h₃ 3 (by norm_num)\n    simp [h₂, h₀] at h3\n    omega\n\n  have h4_eq : d 4 = 1 := by\n    have h4 := h₃ 4 (by norm_num)\n    simp [h3_eq, h₁] at h4\n    omega\n\n  have h5_eq : d 5 = 2 := by\n    have h5 := h₃ 5 (by norm_num)\n    simp [h4_eq, h₂] at h5\n    omega\n\n  have h6_eq : d 6 = 3 := by\n    have h6 := h₃ 6 (by norm_num)\n    simp [h5_eq, h3_eq] at h6\n    omega\n\n  have h7_eq : d 7 = 4 := by\n    have h7 := h₃ 7 (by norm_num)\n    simp [h6_eq, h4_eq] at h7\n    omega\n\n  have h8_eq : d 8 = 6 := by\n    have h8 := h₃ 8 (by norm_num)\n    simp [h7_eq, h5_eq] at h8\n    omega\n\n  have h9_eq : d 9 = 9 := by\n    have h9 := h₃ 9 (by norm_num)\n    simp [h8_eq, h6_eq] at h9\n    omega\n\n  have h11 : ∀ n, n ≥ 2 → d (n + 7) % 2 = d n % 2 := by\n    intro n hn\n    have h11 := h₃ (n + 7) (by omega)\n    rw [show n + 7 - 1 = n + 6 by omega, show n + 7 - 3 = n + 4 by omega] at h11\n    have h12 := h₃ (n + 6) (by omega)\n    rw [show n + 6 - 1 = n + 5 by omega, show n + 6 - 3 = n + 3 by omega] at h12\n    have h13 := h₃ (n + 5) (by omega)\n    rw [show n + 5 - 1 = n + 4 by omega, show n + 5 - 3 = n + 2 by omega] at h13\n    have h14 := h₃ (n + 4) (by omega)\n    rw [show n + 4 - 1 = n + 3 by omega, show n + 4 - 3 = n + 1 by omega] at h14\n    have h15 := h₃ (n + 3) (by omega)\n    rw [show n + 3 - 1 = n + 2 by omega, show n + 3 - 3 = n by omega] at h15\n    have h16 := h₃ (n + 2) (by omega)\n    rw [show n + 2 - 1 = n + 1 by omega, show n + 2 - 3 = n - 1 by omega] at h16\n    have h17 := h₃ (n + 1) (by omega)\n    rw [show n + 1 - 1 = n by omega, show n + 1 - 3 = n - 2 by omega] at h17\n    have eq1 : d (n + 7) = d (n + 6) + d (n + 4) := by omega\n    have eq2 : d (n + 6) = d (n + 5) + d (n + 3) := by omega\n    have eq3 : d (n + 5) = d (n + 4) + d (n + 2) := by omega\n    have eq4 : d (n + 4) = d (n + 3) + d (n + 1) := by omega\n    have eq5 : d (n + 3) = d (n + 2) + d n := by omega\n    have eq6 : d (n + 2) = d (n + 1) + d (n - 1) := by omega\n    have eq7 : d (n + 1) = d n + d (n - 2) := by omega\n    have h18 : d (n + 7) % 2 = d n % 2 := by\n      omega\n    exact h18\n\n  have h2021_even : Even (d 2021) := by\n    have h2021 : d 2021 % 2 = d 5 % 2 := by\n      have h : ∀ k, d (5 + 7 * k) % 2 = d 5 % 2 := by\n        intro k\n        induction k with\n        | zero => simp\n        | succ k ih =>\n          have n : 5 + 7 * k ≥ 2 := by omega\n          have h11' := h11 (5 + 7 * k) n\n          rw [show 5 + 7 * (k + 1) = (5 + 7 * k) + 7 by ring]\n          rw [h11']\n          exact ih\n      have h288 : d 2021 % 2 = d 5 % 2 := by\n        calc\n          d 2021 % 2 = d (5 + 7 * 288) % 2 := by norm_num\n          _ = d 5 % 2 := h 288\n      exact h288\n    have h5_mod2 : d 5 % 2 = 0 := by\n      have : d 5 = 2 := h5_eq\n      omega\n    rw [Nat.even_iff]\n    rw [h2021, h5_mod2]\n\n  have h2022_odd : Odd (d 2022) := by\n    have h2022 : d 2022 % 2 = d 6 % 2 := by\n      have h : ∀ k, d (6 + 7 * k) % 2 = d 6 % 2 := by\n        intro k\n        induction k with\n        | zero => simp\n        | succ k ih =>\n          have n : 6 + 7 * k ≥ 2 := by omega\n          have h11' := h11 (6 + 7 * k) n\n          rw [show 6 + 7 * (k + 1) = (6 + 7 * k) + 7 by ring]\n          rw [h11']\n          exact ih\n      have h288 : d 2022 % 2 = d 6 % 2 := by\n        calc\n          d 2022 % 2 = d (6 + 7 * 288) % 2 := by norm_num\n          _ = d 6 % 2 := h 288\n      exact h288\n    have h6_mod2 : d 6 % 2 = 1 := by\n      have : d 6 = 3 := h6_eq\n      omega\n    rw [Nat.odd_iff]\n    rw [h2022, h6_mod2]\n\n  have h2023_even : Even (d 2023) := by\n    have h2023 : d 2023 % 2 = d 7 % 2 := by\n      have h : ∀ k, d (7 + 7 * k) % 2 = d 7 % 2 := by\n        intro k\n        induction k with\n        | zero => simp\n        | succ k ih =>\n          have n : 7 + 7 * k ≥ 2 := by omega\n          have h11' := h11 (7 + 7 * k) n\n          rw [show 7 + 7 * (k + 1) = (7 + 7 * k) + 7 by ring]\n          rw [h11']\n          exact ih\n      have h288 : d 2023 % 2 = d 7 % 2 := by\n        calc\n          d 2023 % 2 = d (7 + 7 * 288) % 2 := by norm_num\n          _ = d 7 % 2 := h 288\n      exact h288\n    have h7_mod2 : d 7 % 2 = 0 := by\n      have : d 7 = 4 := h7_eq\n      omega\n    rw [Nat.even_iff]\n    rw [h2023, h7_mod2]\n\n  exact ⟨h2021_even, h2022_odd, h2023_even⟩",
    "name": "amc12a_2021_p8"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1960_p2 (x : ℝ) (h₀ : 0 ≤ 1 + 2 * x) (h₁ : (1 - Real.sqrt (1 + 2 * x)) ^ 2 ≠ 0)\n    (h₂ : 4 * x ^ 2 / (1 - Real.sqrt (1 + 2 * x)) ^ 2 < 2 * x + 9) : -(1 / 2) ≤ x ∧ x < 45 / 8 := by\n  have h3 : 0 ≤ Real.sqrt (1 + 2 * x) := Real.sqrt_nonneg (1 + 2 * x)\n  have h4 : (1 - Real.sqrt (1 + 2 * x)) ≠ 0 := by\n    intro h\n    have : (1 - Real.sqrt (1 + 2 * x)) ^ 2 = 0 := by\n      rw [h]\n      ring\n    contradiction\n  have h5 : (1 - Real.sqrt (1 + 2 * x)) ^ 2 > 0 := by\n    apply pow_two_pos_of_ne_zero\n    exact h4\n  have h6 : 4 * x^2 < (2 * x + 9) * (1 - Real.sqrt (1 + 2 * x)) ^ 2 := by\n    have h_pos : 0 < (1 - Real.sqrt (1 + 2 * x)) ^ 2 := by linarith\n    apply (div_lt_iff h_pos).mp at h₂\n    nlinarith\n  have h8 : x < 45 / 8 := by\n    by_contra h\n    push_neg at h\n    have h9 : Real.sqrt (1 + 2 * x) ≥ 7 / 2 := by\n      have h10 : 1 + 2 * x ≥ (7 / 2) ^ 2 := by\n        nlinarith [h]\n      have h11 : Real.sqrt (1 + 2 * x) ≥ Real.sqrt ((7 / 2) ^ 2) := Real.sqrt_le_sqrt (by linarith)\n      have h12 : Real.sqrt ((7 / 2) ^ 2) = 7 / 2 := by\n        rw [Real.sqrt_sq]\n        all_goals linarith\n      linarith\n    have h13 : (1 - Real.sqrt (1 + 2 * x)) ^ 2 ≥ (5 / 2) ^ 2 := by\n      nlinarith [h9, Real.sqrt_nonneg (1 + 2 * x)]\n    nlinarith [h6, h13, sq_nonneg (Real.sqrt (1 + 2 * x)), sq_nonneg (x - 45 / 8), Real.sq_sqrt (show 0 ≤ 1 + 2 * x by linarith)]\n  have h14 : -(1 / 2) ≤ x := by linarith\n  exact ⟨h14, h8⟩",
    "name": "imo_1960_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_430 (a b c : ℕ) (h₀ : 1 ≤ a ∧ a ≤ 9) (h₁ : 1 ≤ b ∧ b ≤ 9)\n    (h₂ : 1 ≤ c ∧ c ≤ 9) (h₃ : a ≠ b) (h₄ : a ≠ c) (h₅ : b ≠ c) (h₆ : a + b = c)\n    (h₇ : 10 * a + a - b = 2 * c) (h₈ : c * b = 10 * a + a + a) : a + b + c = 8 := by\n  rcases h₀ with ⟨ha1, ha2⟩\n  rcases h₁ with ⟨hb1, hb2⟩\n  rcases h₂ with ⟨hc1, hc2⟩\n  have h9 : c = a + b := by linarith\n  rw [h9] at h₇\n  have h10 : b = 3 * a := by \n    omega\n  rw [h10] at h₈ \n  rw [h9] at h₈\n  have ha_eq_1 : a = 1 := by\n    nlinarith\n  have hb_eq_3 : b = 3 := by \n    rw [ha_eq_1] at h10\n    omega\n  have hc_eq_4 : c = 4 := by \n    rw [ha_eq_1, hb_eq_3] at h₆\n    omega\n  calc\n    a + b + c = 1 + 3 + 4 := by rw [ha_eq_1, hb_eq_3, hc_eq_4]\n    _ = 8 := by norm_num",
    "name": "mathd_numbertheory_430"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2021_p3 (x y : ℕ) (h₀ : x + y = 17402) (h₁ : 10 ∣ x) (h₂ : x / 10 = y) :\n    ↑x - ↑y = (14238 : ℤ) := by\n  have h3 : x = 10 * y := by \n    have h4 : x = 10 * (x / 10) := by \n      omega\n    rw [h4]\n    rw [h₂]\n  have hy : y = 1582 := by\n    have h4 : 11 * y = 17402 := by \n      omega\n    omega\n  have hx : x = 15820 := by\n    omega\n  rw [hx, hy]\n  norm_num",
    "name": "amc12a_2021_p3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_299 : 1 * 3 * 5 * 7 * 9 * 11 * 13 % 10 = 5 := by \n  norm_num",
    "name": "mathd_numbertheory_299"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_176 (x : ℝ) : (x + 1) ^ 2 * x = x ^ 3 + 2 * x ^ 2 + x := by\n  ring",
    "name": "mathd_algebra_176"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1991_p9 (x : ℝ) (m : ℚ) (h₀ : 1 / Real.cos x + Real.tan x = 22 / 7)\n    (h₁ : 1 / Real.sin x + 1 / Real.tan x = m) : ↑m.den + m.num = 44 := by\n  have h2 : Real.cos x ≠ 0 := by\n    by_contra h\n    have h3 : 1 / Real.cos x = 0 := by\n      field_simp [h]\n    have h4 : Real.tan x = 0 := by\n      rw [Real.tan_eq_sin_div_cos]\n      simp [h]\n    have h5 : (22 : ℝ) / 7 = 0 := by linarith [h₀, h3, h4]\n    norm_num at h5\n\n  have h_tan : Real.tan x = Real.sin x / Real.cos x := by\n    rw [Real.tan_eq_sin_div_cos]\n\n  have h3 : Real.sin x ^ 2 + Real.cos x ^ 2 = 1 := Real.sin_sq_add_cos_sq x\n\n  have h4 : 1 / Real.cos x + Real.tan x = 22 / 7 := h₀\n  rw [h_tan] at h4\n  have h5 : 1 / Real.cos x + Real.sin x / Real.cos x = 22 / 7 := h4\n  have h6 : (1 + Real.sin x) / Real.cos x = 22 / 7 := by\n    have h7 : Real.cos x ≠ 0 := h2\n    field_simp [h7] at h5 ⊢\n    nlinarith\n\n  have h7 : 7 * (1 + Real.sin x) = 22 * Real.cos x := by\n    have h8 : Real.cos x ≠ 0 := h2\n    field_simp at h6\n    nlinarith\n\n  have h_sin : Real.sin x = (22 * Real.cos x - 7) / 7 := by linarith\n\n  have h8 : Real.sin x ^ 2 + Real.cos x ^ 2 = 1 := Real.sin_sq_add_cos_sq x\n  have h9 : Real.sin x = (22 * Real.cos x - 7) / 7 := h_sin\n\n  have h_cos_sq : Real.cos x ^ 2 = (308 / 533) ^ 2 := by\n    have h10 : Real.cos x ≠ 0 := h2\n    have h11 : Real.sin x = (22 * Real.cos x - 7) / 7 := h_sin\n    rw [h11] at h3\n    have h12 : ((22 * Real.cos x - 7) / 7) ^ 2 + Real.cos x ^ 2 = 1 := by linarith\n    have h13 : (22 * Real.cos x - 7) ^ 2 + (7 * Real.cos x) ^ 2 = 49 := by\n      nlinarith\n    have h14 : (Real.cos x) * (533 * Real.cos x - 308) = 0 := by\n      ring_nf at h13 ⊢\n      linarith\n    cases' (mul_eq_zero.mp h14) with h_cos h15\n    · -- Real.cos x = 0\n      exfalso\n      exact h10 (by linarith)\n    · -- 533 * Real.cos x - 308 = 0\n      have h_cos : Real.cos x = 308 / 533 := by linarith\n      nlinarith [h_cos]\n  have h_cos : Real.cos x = 308 / 533 := by nlinarith [h_cos_sq]\n\n  have h_sin' : Real.sin x = 435 / 533 := by\n    have h9 : Real.sin x = (22 * Real.cos x - 7) / 7 := h_sin\n    rw [h9, h_cos]\n    norm_num\n\n  have h_csc_cot : (1 / Real.sin x : ℝ) + (1 / Real.tan x : ℝ) = (29 / 15 : ℝ) := by\n    have h10 : Real.sin x ≠ 0 := by\n      by_contra h\n      have h11 : Real.sin x = 0 := by linarith\n      rw [h11] at h3\n      have h12 : Real.cos x ^ 2 = 1 := by nlinarith\n      have h13 : Real.cos x = 1 ∨ Real.cos x = -1 := by\n        have h14 : Real.cos x ^ 2 - 1 = 0 := by linarith\n        have h15 : (Real.cos x - 1) * (Real.cos x + 1) = 0 := by\n          ring_nf at h14 ⊢\n          linarith\n        cases (mul_eq_zero.mp h15) with\n        | inl h16 => left; linarith\n        | inr h17 => right; linarith\n      cases h13 with\n      | inl h14 =>\n        have h15 : Real.cos x = 308 / 533 := h_cos\n        linarith\n      | inr h14 =>\n        have h15 : Real.cos x = 308 / 533 := h_cos\n        linarith\n    have h11 : Real.tan x ≠ 0 := by\n      by_contra h\n      have h12 : Real.sin x = 0 := by\n        rw [Real.tan_eq_sin_div_cos] at h\n        have h13 : Real.cos x ≠ 0 := h2\n        field_simp [h13] at h\n        linarith\n      contradiction\n    have h12 : (1 / Real.sin x : ℝ) + (1 / Real.tan x : ℝ) = (29 / 15 : ℝ) := by\n      have h13 : Real.tan x = Real.sin x / Real.cos x := Real.tan_eq_sin_div_cos x\n      rw [h13]\n      have h14 : Real.sin x ≠ 0 := h10\n      have h15 : Real.cos x ≠ 0 := h2\n      field_simp [h14, h15, h_sin', h_cos]\n      norm_num\n    exact h12\n  have h_m : (m : ℝ) = (29 / 15 : ℝ) := by\n    have h12 : (1 / Real.sin x : ℝ) + (1 / Real.tan x : ℝ) = (29 / 15 : ℝ) := h_csc_cot\n    have h13 : (1 / Real.sin x : ℝ) + (1 / Real.tan x : ℝ) = (m : ℝ) := by\n      exact_mod_cast h₁\n    rw [h13] at h12\n    linarith\n  have h14 : m = (29 / 15 : ℚ) := by\n    have h15 : (m : ℝ) = (29 / 15 : ℝ) := h_m\n    have h16 : (m : ℝ) = (29 / 15 : ℚ) := by\n      norm_num at h15 ⊢\n      exact_mod_cast h15\n    exact_mod_cast h16\n  rw [h14]\n  norm_num",
    "name": "aime_1991_p9"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1994_p3 (f : ℤ → ℤ) (h0 : ∀ x, f x + f (x - 1) = x ^ 2) (h1 : f 19 = 94) :\n    f 94 % 1000 = 561 := by\n  have h20 := h0 20\n  have h21 := h0 21\n  have h22 := h0 22\n  have h23 := h0 23\n  have h24 := h0 24\n  have h25 := h0 25\n  have h26 := h0 26\n  have h27 := h0 27\n  have h28 := h0 28\n  have h29 := h0 29\n  have h30 := h0 30\n  have h31 := h0 31\n  have h32 := h0 32\n  have h33 := h0 33\n  have h34 := h0 34\n  have h35 := h0 35\n  have h36 := h0 36\n  have h37 := h0 37\n  have h38 := h0 38\n  have h39 := h0 39\n  have h40 := h0 40\n  have h41 := h0 41\n  have h42 := h0 42\n  have h43 := h0 43\n  have h44 := h0 44\n  have h45 := h0 45\n  have h46 := h0 46\n  have h47 := h0 47\n  have h48 := h0 48\n  have h49 := h0 49\n  have h50 := h0 50\n  have h51 := h0 51\n  have h52 := h0 52\n  have h53 := h0 53\n  have h54 := h0 54\n  have h55 := h0 55\n  have h56 := h0 56\n  have h57 := h0 57\n  have h58 := h0 58\n  have h59 := h0 59\n  have h60 := h0 60\n  have h61 := h0 61\n  have h62 := h0 62\n  have h63 := h0 63\n  have h64 := h0 64\n  have h65 := h0 65\n  have h66 := h0 66\n  have h67 := h0 67\n  have h68 := h0 68\n  have h69 := h0 69\n  have h70 := h0 70\n  have h71 := h0 71\n  have h72 := h0 72\n  have h73 := h0 73\n  have h74 := h0 74\n  have h75 := h0 75\n  have h76 := h0 76\n  have h77 := h0 77\n  have h78 := h0 78\n  have h79 := h0 79\n  have h80 := h0 80\n  have h81 := h0 81\n  have h82 := h0 82\n  have h83 := h0 83\n  have h84 := h0 84\n  have h85 := h0 85\n  have h86 := h0 86\n  have h87 := h0 87\n  have h88 := h0 88\n  have h89 := h0 89\n  have h90 := h0 90\n  have h91 := h0 91\n  have h92 := h0 92\n  have h93 := h0 93\n  have h94 := h0 94\n  norm_num [pow_two] at *\n  omega",
    "name": "aime_1994_p3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_435 (k : ℕ) (h₀ : 0 < k) (h₁ : ∀ n, Nat.gcd (6 * n + k) (6 * n + 3) = 1)\n    (h₂ : ∀ n, Nat.gcd (6 * n + k) (6 * n + 2) = 1) (h₃ : ∀ n, Nat.gcd (6 * n + k) (6 * n + 1) = 1) :\n    5 ≤ k := by \n  by_contra h\n  push_neg at h\n  have h4 : k ≤ 4 := by linarith\n  interval_cases k <;> try { \n    have h₁1 := h₁ 1\n    have h₂1 := h₂ 1\n    have h₃1 := h₃ 1\n    norm_num at h₁1 h₂1 h₃1 \n    all_goals omega\n  }\n  all_goals omega",
    "name": "mathd_numbertheory_435"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_354 (a d : ℝ) (h₀ : a + 6 * d = 30) (h₁ : a + 10 * d = 60) :\n    a + 20 * d = 135 := by \n  linarith",
    "name": "mathd_algebra_354"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_208 : Real.sqrt 1000000 - 1000000 ^ ((1 : ℝ) / 3) = 900 := by\n  have h1 : Real.sqrt 1000000 = 1000 := by\n    rw [Real.sqrt_eq_iff_sq_eq] <;> norm_num\n  have h2 : (1000000 : ℝ) ^ ((1 : ℝ) / 3) = 100 := by\n    have h21 : (1000000 : ℝ) = 100 ^ (3 : ℝ) := by norm_num\n    rw [h21]\n    rw [← Real.rpow_mul]\n    norm_num\n    all_goals norm_num\n  rw [h1, h2]\n  all_goals norm_num",
    "name": "mathd_algebra_208"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_513 (a b : ℝ) (h₀ : 3 * a + 2 * b = 5) (h₁ : a + b = 2) : a = 1 ∧ b = 1 := by\n  have h2 : a = 1 := by\n    linarith\n  have h3 : b = 1 := by \n    linarith\n  exact ⟨h2, h3⟩",
    "name": "mathd_algebra_513"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1983_p6 (a b c : ℝ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : c < a + b) (h₂ : b < a + c)\n    (h₃ : a < b + c) : 0 ≤ a ^ 2 * b * (a - b) + b ^ 2 * c * (b - c) + c ^ 2 * a * (c - a) := by\n  have h4 : a + b - c > 0 := by linarith\n  have h5 : b + c - a > 0 := by linarith\n  have h6 : c + a - b > 0 := by linarith\n  \n  nlinarith [sq_nonneg (a - b), sq_nonneg (b - c), sq_nonneg (c - a),\n    h4, h5, h6, mul_nonneg (show 0 ≤ a + b - c by linarith) (sq_nonneg (a - b)),\n    mul_nonneg (show 0 ≤ b + c - a by linarith) (sq_nonneg (b - c)),\n    mul_nonneg (show 0 ≤ c + a - b by linarith) (sq_nonneg (c - a))]",
    "name": "imo_1983_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_33 (x y z : ℝ) (h₀ : x ≠ 0) (h₁ : 2 * x = 5 * y) (h₂ : 7 * y = 10 * z) :\n    z / x = 7 / 25 := by\n  have hy : y = (2 / 5) * x := by\n    linarith\n  rw [hy] at h₂\n  have hz : z = (7 / 25) * x := by\n    linarith\n  have h : z / x = 7 / 25 := by\n    have h₅ : x ≠ 0 := h₀\n    have h₆ : z = (7 / 25) * x := by linarith\n    field_simp [h₅]\n    linarith [h₆]\n  exact h",
    "name": "mathd_algebra_33"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_276 (a b : ℤ)\n    (h₀ : ∀ x : ℝ, 10 * x ^ 2 - x - 24 = (a * x - 8) * (b * x + 3)) : a * b + b = 12 := by\n        have h1 := h₀ 0\n        have h2 := h₀ 1\n        have h3 := h₀ (-1)\n        have h4 := h₀ 2\n        norm_num at h1 h2 h3 h4\n        have hab : a * b = 10 := by\n          have h2_real : (a : ℝ) * (b : ℝ) = 10 := by\n            nlinarith\n          exact_mod_cast h2_real\n        have h_eq : 3 * a - 8 * b = -1 := by\n          have h3_real : (3 : ℝ) * (a : ℝ) - 8 * (b : ℝ) = -1 := by\n            nlinarith [h2, h3]\n          have h3_int : (3 : ℤ) * a - 8 * b = -1 := by\n            have h3_real := h3_real\n            norm_cast at h3_real\n            <;> linarith\n          linarith\n        have ha : a = 5 := by\n          have h1 : a ≤ 10 := by \n            nlinarith [hab]\n          have h2 : a ≥ -10 := by \n            nlinarith [hab]\n          interval_cases a <;> omega\n        have hb : b = 2 := by\n          rw [ha] at h_eq\n          omega\n        rw [ha, hb]\n        norm_num",
    "name": "mathd_algebra_276"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2003_p5 (A M C : ℕ) (h₀ : A ≤ 9 ∧ M ≤ 9 ∧ C ≤ 9)\n    (h₁ : Nat.ofDigits 10 [0, 1, C, M, A] + Nat.ofDigits 10 [2, 1, C, M, A] = 123422) :\n    A + M + C = 14 := by \n  rcases h₀ with ⟨hA, hM, hC⟩\n  simp [Nat.ofDigits] at h₁\n  have h2 : A ≤ 9 := hA\n  have h3 : M ≤ 9 := hM\n  have h4 : C ≤ 9 := hC\n  omega",
    "name": "amc12a_2003_p5"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_apbpceq2_abpbcpcaeq1_aleq1on3anbleq1ancleq4on3 (a b c : ℝ) (h₀ : a ≤ b ∧ b ≤ c)\n    (h₁ : a + b + c = 2) (h₂ : a * b + b * c + c * a = 1) :\n    0 ≤ a ∧ a ≤ 1 / 3 ∧ 1 / 3 ≤ b ∧ b ≤ 1 ∧ 1 ≤ c ∧ c ≤ 4 / 3 := by\n  have h₃ : a ≥ 0 := by\n    nlinarith [sq_nonneg (a - 1 / 3), sq_nonneg (b - 1), sq_nonneg (c - 4 / 3),\n              mul_self_nonneg (a + b + c - 2), mul_self_nonneg (a * b + b * c + c * a - 1),\n              h₀.left, h₀.right]\n  have h₄ : a ≤ 1 / 3 := by\n    nlinarith [sq_nonneg (a - 1 / 3), sq_nonneg (b - 1), sq_nonneg (c - 4 / 3),\n              mul_self_nonneg (a + b + c - 2), mul_self_nonneg (a * b + b * c + c * a - 1),\n              h₀.left, h₀.right]\n  have h₅ : 1 / 3 ≤ b := by\n    nlinarith [sq_nonneg (a - 1 / 3), sq_nonneg (b - 1), sq_nonneg (c - 4 / 3),\n              mul_self_nonneg (a + b + c - 2), mul_self_nonneg (a * b + b * c + c * a - 1),\n              h₀.left, h₀.right]\n  have h₆ : b ≤ 1 := by\n    nlinarith [sq_nonneg (a - 1 / 3), sq_nonneg (b - 1), sq_nonneg (c - 4 / 3),\n              mul_self_nonneg (a + b + c - 2), mul_self_nonneg (a * b + b * c + c * a - 1),\n              h₀.left, h₀.right]\n  have h₇ : 1 ≤ c := by\n    nlinarith [sq_nonneg (a - 1 / 3), sq_nonneg (b - 1), sq_nonneg (c - 4 / 3),\n              mul_self_nonneg (a + b + c - 2), mul_self_nonneg (a * b + b * c + c * a - 1),\n              h₀.left, h₀.right]\n  have h₈ : c ≤ 4 / 3 := by\n    nlinarith [sq_nonneg (a - 1 / 3), sq_nonneg (b - 1), sq_nonneg (c - 4 / 3),\n              mul_self_nonneg (a + b + c - 2), mul_self_nonneg (a * b + b * c + c * a - 1),\n              h₀.left, h₀.right]\n  exact ⟨h₃, h₄, h₅, h₆, h₇, h₈⟩",
    "name": "algebra_apbpceq2_abpbcpcaeq1_aleq1on3anbleq1ancleq4on3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_sqineq_at2malt1 (a : ℝ) : a * (2 - a) ≤ 1 := by \n  have h1 : (a - 1) ^ 2 ≥ 0:= by \n    exact sq_nonneg (a - 1)\n  linarith [sq_nonneg (a - 1)]",
    "name": "algebra_sqineq_at2malt1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12_2000_p20 (x y z : ℝ) (h₀ : 0 < x ∧ 0 < y ∧ 0 < z) (h₁ : x + 1 / y = 4)\n    (h₂ : y + 1 / z = 1) (h₃ : z + 1 / x = 7 / 3) : x * y * z = 1 := by\n  have pos_x : 0 < x := h₀.left\n  have pos_y : 0 < y := h₀.right.left\n  have pos_z : 0 < z := h₀.right.right\n  have eq1 : x * y + 1 = 4 * y := by \n    field_simp at h₁\n    nlinarith\n  have eq2 : y * z + 1 = z := by \n    field_simp at h₂\n    nlinarith [pos_z]\n  have eq3 : z * x + 1 = (7 / 3) * x := by \n    field_simp at h₃\n    nlinarith [pos_x]\n  have sum_eq : x + 1 / y + y + 1 / z + z + 1 / x = 22 / 3 := by\n    have h1 := h₁\n    have h2 := h₂\n    have h3 := h₃\n    have h4 : x + 1 / y + (y + 1 / z) + (z + 1 / x) = 4 + 1 + (7 / 3 : ℝ) := by\n      linarith [h₁, h₂, h₃]\n    have h5 : x + 1 / y + (y + 1 / z) + (z + 1 / x) = x + 1 / y + y + 1 / z + z + 1 / x := by\n      ring\n    rw [h5] at h4\n    linarith\n  have h4 : (x + 1 / y) * (y + 1 / z) * (z + 1 / x) = 4 * 1 * (7 / 3 : ℝ) := by\n    rw [h₁, h₂, h₃]\n  have eq4 : (x + 1 / y) * (y + 1 / z) * (z + 1 / x) = x * y * z + (x + 1 / y + y + 1 / z + z + 1 / x) + 1 / (x * y * z) := by\n    field_simp\n    ring_nf\n  rw [eq4] at h4\n  have eq5 : x * y * z + 1 / (x * y * z) = 2 := by\n    have h_sum : x + 1 / y + y + 1 / z + z + 1 / x = 22 / 3 := sum_eq\n    have h_eq : x * y * z + (x + 1 / y + y + 1 / z + z + 1 / x) + 1 / (x * y * z) = 28 / 3 := by\n      linarith\n    rw [h_sum] at h_eq\n    have h : x * y * z + 1 / (x * y * z) = 2 := by\n      linarith\n    exact h\n  have pos_xyz : x * y * z ≠ 0 := by\n    apply mul_ne_zero\n    apply mul_ne_zero\n    · linarith\n    · linarith\n    · linarith\n  have h5 : x * y * z = 1 := by\n    have h6 : x * y * z = 1 := by\n      have h7 : x * y * z > 0 := by\n        apply mul_pos\n        apply mul_pos\n        · linarith\n        · linarith\n        · linarith\n      have h8 : x * y * z > 0 := h7\n      have h9 : x * y * z ≠ 0 := pos_xyz\n      have h10 : (x * y * z - 1) ^ 2 = 0 := by\n        have h11 : x * y * z + 1 / (x * y * z) = 2 := eq5\n        field_simp at h11\n        nlinarith [sq_nonneg (x * y * z - 1)]\n      have h12 : x * y * z - 1 = 0 := by\n        rw [sq_eq_zero_iff] at h10\n        exact h10\n      linarith\n    exact h6\n  exact h5",
    "name": "amc12_2000_p20"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_222 (b : ℕ) (h₀ : Nat.lcm 120 b = 3720) (h₁ : Nat.gcd 120 b = 8) :\n    b = 248 := by\n  have h2 : 120 * b = 8 * 3720 := by\n    calc\n      120 * b = Nat.gcd 120 b * Nat.lcm 120 b := by rw [Nat.gcd_mul_lcm]\n      _ = 8 * 3720 := by rw [h₁, h₀]\n  have h3 : b = 248 := by\n    linarith\n  exact h3",
    "name": "mathd_numbertheory_222"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2002_p6 (n : ℕ) (h₀ : 0 < n) : ∃ m, m > n ∧ ∃ p, m * p ≤ m + p := by \n  use n + 1\n  constructor\n  . -- Show m > n\n    omega\n  . -- Find p such that (n + 1) * p ≤ (n + 1) + p\n    use 1\n    omega",
    "name": "amc12a_2002_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_34 (x : ℕ) (h₀ : x < 100) (h₁ : x * 9 % 100 = 1) : x = 89 := by\n  interval_cases x <;> norm_num at h₁ <;> omega",
    "name": "mathd_numbertheory_34"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_342 : 54 % 6 = 0 := by \n  norm_num",
    "name": "mathd_numbertheory_342"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12_2000_p6 (p q : ℕ) (h₀ : Nat.Prime p ∧ Nat.Prime q) (h₁ : 4 ≤ p ∧ p ≤ 18)\n    (h₂ : 4 ≤ q ∧ q ≤ 18) : ↑p * ↑q - (↑p + ↑q) ≠ (194 : ℕ) := by\n\n  rcases h₀ with ⟨hp, hq⟩\n  rcases h₁ with ⟨hp_ge, hp_le⟩\n  rcases h₂ with ⟨hq_ge, hq_le⟩\n  interval_cases p <;> interval_cases q <;> norm_num at *\n  <;> try { tauto }",
    "name": "amc12_2000_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_215 (S : Finset ℝ) (h₀ : ∀ x : ℝ, x ∈ S ↔ (x + 3) ^ 2 = 121) :\n    (∑ k in S, k) = -6 := by\n  have h1 : S = {8, -14} := by\n    ext x\n    simp [h₀]\n    constructor\n    · -- Assume (x + 3) ^ 2 = 121, we need to show x = 8 ∨ x = -14\n      intro h\n      have h_eq : (x + 3) ^ 2 = 121 := by linarith\n      have h1 : x + 3 = 11 ∨ x + 3 = -11 := by\n        have h2 : (x + 3) ^ 2 - 121 = 0 := by linarith\n        have h3 : ((x + 3) - 11) * ((x + 3) + 11) = 0 := by\n          linarith [h2]\n        cases (mul_eq_zero.mp h3) with\n        | inl h4 => \n          left\n          linarith\n        | inr h5 => \n          right\n          linarith\n      cases h1 with\n      | inl h11 =>\n        left\n        linarith\n      | inr h12 =>\n        right\n        linarith\n    · -- Show that if x = 8 ∨ x = -14, then (x + 3) ^ 2 = 121\n      rintro (h | h)\n      · -- x = 8\n        rw [h]\n        norm_num\n      · -- x = -14\n        rw [h]\n        norm_num\n  rw [h1]\n  norm_num [Finset.sum_insert, Finset.sum_singleton]",
    "name": "mathd_algebra_215"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_129 (a : ℝ) (h₀ : a ≠ 0) (h₁ : 8⁻¹ / 4⁻¹ - a⁻¹ = 1) : a = -2 := by \n  have h2 : (8 : ℝ)⁻¹ / (4 : ℝ)⁻¹ = (1 / 2 : ℝ) := by norm_num\n  have h3 : (1 / 2 : ℝ) - a⁻¹ = 1 := by \n    rw [h2] at h₁ \n    exact h₁\n  have h4 : a⁻¹ = -1 / 2 := by\n    linarith\n  have h5 : a = -2 := by \n    have h6 : a ≠ 0 := h₀\n    have h7 : a = -2 := by\n      field_simp [h6] at h4\n      linarith\n    exact h7\n  exact h5",
    "name": "mathd_algebra_129"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_235 : (29 * 79 + 31 * 81) % 10 = 2 := by \n  norm_num",
    "name": "mathd_numbertheory_235"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2020_p21 (S : Finset ℕ)\n    (h₀ : ∀ n : ℕ, n ∈ S ↔ 0 < n ∧ (↑n + (1000 : ℝ)) / 70 = Int.floor (Real.sqrt n)) : S.card = 6 := by\n  have h1 : S = {400, 470, 2290, 2360, 2430, 2500} := by\n    ext n\n    simp [h₀]\n    constructor\n    · -- Assume n ∈ S\n      intro hn\n      rcases hn with ⟨hn_pos, h_eq⟩\n      have h_n : (n : ℝ) > 0 := by exact_mod_cast hn_pos\n      have eq1 : (n : ℝ) + 1000 = (70 : ℝ) * (Int.floor (Real.sqrt n)) := by\n        have h2 : (Int.floor (Real.sqrt n) : ℝ) = (n + 1000) / 70 := by \n          field_simp\n          linarith [h_eq]\n        linarith\n      have h2 : ∃ k : ℤ, Int.floor (Real.sqrt n) = k := by \n        refine ⟨Int.floor (Real.sqrt n), rfl⟩\n      rcases h2 with ⟨k, hk⟩\n      have eq2 : (n : ℝ) = (70 : ℝ) * k - (1000 : ℝ) := by \n        have h2 : (Int.floor (Real.sqrt n) : ℝ) = (n + 1000) / 70 := by \n          field_simp\n          linarith [h_eq]\n        rw [hk] at h2\n        linarith\n      have h3 : n = 70 * k - 1000 := by \n        have h4 : (n : ℝ) = (70 : ℝ) * k - (1000 : ℝ) := eq2\n        have h5 : (n : ℝ) = (n : ℝ) := by rfl\n        have h6 : (n : ℝ) = (n : ℝ) := by rfl\n        have h7 : (70 : ℝ) * k - (1000 : ℝ) = (70 * k - 1000 : ℝ) := by ring\n        rw [h7] at h4\n        exact_mod_cast h4\n      have h4 : k ≤ Real.sqrt n := by \n        have h_floor_le_sqrt : (k : ℝ) ≤ Real.sqrt n := by \n          rw [←hk]\n          exact Int.floor_le (Real.sqrt n)\n        exact h_floor_le_sqrt\n      have h5 : Real.sqrt n < (k : ℝ) + 1 := by \n        have h_sqrt_lt_floor_plus_one : Real.sqrt n < (k : ℝ) + 1 := by \n          rw [←hk]\n          exact Int.lt_floor_add_one (Real.sqrt n)\n        exact h_sqrt_lt_floor_plus_one\n      have h6 : (k : ℝ) ^ 2 ≤ (n : ℝ) := by \n        have h7 : (k : ℝ) ≥ 0 := by nlinarith [h4, Real.sqrt_nonneg n]\n        have h8 : (k : ℝ) ^ 2 ≤ (Real.sqrt n) ^ 2 := by nlinarith [h4, Real.sqrt_nonneg n]\n        have h9 : (Real.sqrt n) ^ 2 = (n : ℝ) := Real.sq_sqrt (by linarith)\n        linarith\n      have h7 : (n : ℝ) < ((k : ℝ) + 1) ^ 2 := by \n        have h8 : (Real.sqrt n) ^ 2 < ((k : ℝ) + 1) ^ 2 := by nlinarith [h5]\n        have h9 : (Real.sqrt n) ^ 2 = (n : ℝ) := Real.sq_sqrt (by linarith)\n        nlinarith [h9]\n      rw [show (n : ℝ) = (70 : ℝ) * k - (1000 : ℝ) by exact_mod_cast eq2] at h6 h7\n      have h8 : (k : ℝ) ^ 2 ≤ (70 : ℝ) * k - (1000 : ℝ) := by linarith\n      have h9 : (70 : ℝ) * k - (1000 : ℝ) < ((k : ℝ) + 1) ^ 2 := by nlinarith\n      have h10 : 20 ≤ (k : ℝ) := by \n        nlinarith [sq_nonneg ((k : ℝ) - 20), sq_nonneg ((k : ℝ) - 50), h8]\n      have h11 : (k : ℝ) ≤ 50 := by \n        nlinarith [sq_nonneg ((k : ℝ) - 20), sq_nonneg ((k : ℝ) - 50), h8]\n      have h12 : (k : ℝ) ^ 2 - (68 : ℝ) * k + (1001 : ℝ) > 0 := by \n        nlinarith [h9]\n      have h13 : k = 20 ∨ k = 21 ∨ k = 47 ∨ k = 48 ∨ k = 49 ∨ k = 50 := by \n        have h14 : 20 ≤ k := by \n          norm_num at h10\n          exact_mod_cast h10\n        have h15 : k ≤ 50 := by \n          norm_num at h11\n          exact_mod_cast h11\n        interval_cases k <;> norm_num at h12 <;> tauto\n      rcases h13 with (rfl | rfl | rfl | rfl | rfl | rfl)\n      · -- Case k = 20 \n        have hn_eq : n = 400 := by \n          omega\n        exact Or.inl hn_eq\n      · -- Case k = 21 \n        have hn_eq : n = 470 := by \n          omega\n        exact Or.inr (Or.inl hn_eq)\n      · -- Case k = 47 \n        have hn_eq : n = 2290 := by \n          omega\n        exact Or.inr (Or.inr (Or.inl hn_eq))\n      · -- Case k = 48 \n        have hn_eq : n = 2360 := by \n          omega\n        exact Or.inr (Or.inr (Or.inr (Or.inl hn_eq)))\n      · -- Case k = 49 \n        have hn_eq : n = 2430 := by \n          omega\n        exact Or.inr (Or.inr (Or.inr (Or.inr (Or.inl hn_eq))))\n      · -- Case k = 50 \n        have hn_eq : n = 2500 := by \n          omega\n        exact Or.inr (Or.inr (Or.inr (Or.inr (Or.inr hn_eq))))\n    · -- Show that if n ∈ {400, 470, 2290, 2360, 2430, 2500}, then n ∈ S\n      rintro (rfl | rfl | rfl | rfl | rfl | rfl)\n      · -- n = 400\n        constructor \n        · norm_num   -- 400 > 0\n        · norm_num [Int.floor_eq_iff, Real.sqrt_eq_iff_sq_eq] <;> (norm_num)\n      · -- n = 470\n        constructor \n        · norm_num\n        · norm_num [Int.floor_eq_iff, Real.sqrt_lt, Real.lt_sqrt] <;> (norm_num)\n      · -- n = 2290\n        constructor \n        · norm_num\n        · norm_num [Int.floor_eq_iff, Real.sqrt_lt, Real.lt_sqrt] <;> (norm_num)\n      · -- n = 2360\n        constructor \n        · norm_num\n        · norm_num [Int.floor_eq_iff, Real.sqrt_lt, Real.lt_sqrt] <;> (norm_num)\n      · -- n = 2430\n        constructor \n        · norm_num\n        · norm_num [Int.floor_eq_iff, Real.sqrt_lt, Real.lt_sqrt] <;> (norm_num)\n      · -- n = 2500\n        constructor \n        · norm_num\n        · norm_num [Int.floor_eq_iff, Real.sqrt_eq_iff_sq_eq] <;> (norm_num)\n  rw [h1]\n  simp",
    "name": "amc12b_2020_p21"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2021_p1 (S : Finset ℤ) (h₀ : ∀ x : ℤ, x ∈ S ↔ ↑(abs x) < 3 * Real.pi) :\n    S.card = 19 := by\n\n  have h1 : (3 * Real.pi) > 9 := by\n    have hpi : Real.pi > 3 := Real.pi_gt_three\n    linarith\n  \n  have h2 : (3 * Real.pi) < 9.45 := by\n    have hpi : Real.pi < 3.15 := Real.pi_lt_315\n    norm_num at hpi ⊢\n    linarith\n  \n  have h3 : S = Finset.Icc (-9) 9 := by\n    ext x\n    simp [h₀]\n    constructor\n    · -- If x ∈ S, then |x| < 3π\n      intro hx\n      have h4 : abs x < 3 * Real.pi := by exact_mod_cast hx\n      have h5 : abs x ≤ 9 := by\n        by_contra h\n        push_neg at h\n        have h6 : abs x ≥ 10 := by omega\n        have h7 : (10 : ℝ) ≤ (abs x : ℝ) := by exact_mod_cast h6\n        have h8 : (abs x : ℝ) < 3 * Real.pi := by exact_mod_cast h4\n        linarith [h2]\n      constructor\n      · -- Show that -9 ≤ x\n        cases' abs_cases x with hx hx\n        · -- x ≥ 0, so |x| = x\n          linarith [abs_nonneg x]\n        · -- x < 0, so |x| = -x\n          linarith [abs_nonneg x]\n      · -- Show that x ≤ 9\n        cases' abs_cases x with hx hx\n        · -- x ≥ 0, so |x| = x\n          linarith [abs_nonneg x]\n        · -- x < 0, so |x| = -x\n          linarith [abs_nonneg x]\n    · -- If -9 ≤ x ≤ 9, then x ∈ S\n      rintro ⟨h1, h2⟩\n      have h3 : abs x ≤ 9 := by\n        apply abs_le.mpr\n        constructor <;> linarith\n      have h4 : (abs x : ℝ) < 3 * Real.pi := by\n        have h5 : (abs x : ℝ) ≤ (9 : ℝ) := by exact_mod_cast h3\n        linarith [h1]\n      exact_mod_cast h4\n  \n  rw [h3]\n  native_decide",
    "name": "amc12b_2021_p1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_346 (f g : ℝ → ℝ) (h₀ : ∀ x, f x = 2 * x - 3) (h₁ : ∀ x, g x = x + 1) :\n    g (f 5 - 1) = 7 := by \n  have h2 : f 5 = 7 := by \n    rw [h₀]\n    norm_num\n  rw [h2]\n  rw [h₁]\n  norm_num",
    "name": "mathd_algebra_346"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_304 : 91 ^ 2 = 8281 := by \n  norm_num",
    "name": "mathd_algebra_304"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2002_p7 (a b c : ℕ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : b = a + 1) (h₂ : c = b + 1)\n    (h₃ : a * b * c = 8 * (a + b + c)) : a ^ 2 + (b ^ 2 + c ^ 2) = 77 := by\n        have hb : b = a + 1 := h₁\n        have hc : c = a + 2 := by omega\n        rw [hb, hc] at h₃\n        have h4 : a = 4 := by\n            have h_pos : 0 < a := h₀.left\n            have : a ≤ 6 := by\n                nlinarith [h₃, mul_pos h_pos (show 0 < a + 1 by omega), mul_pos h_pos (show 0 < a + 2 by omega),\n                    show 0 < a + 1 by omega, show 0 < a + 2 by omega]\n            interval_cases a <;> omega\n        have ha : a = 4 := h4\n        have hb' : b = 5 := by omega\n        have hc' : c = 6 := by omega\n        rw [ha, hb', hc']\n        norm_num",
    "name": "amc12b_2002_p7"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_362 (a b : ℝ) (h₀ : a ^ 2 * b ^ 3 = 32 / 27) (h₁ : a / b ^ 3 = 27 / 4) :\n    a + b = 8 / 3 := by\n  have h2 : b ≠ 0 := by\n    by_contra h\n    rw [h] at h₀\n    norm_num at h₀\n  have h3 : a = 27 / 4 * b ^ 3 := by\n    have hb3 : b ^ 3 ≠ 0 := by\n      intro h\n      have : b = 0 := by\n        have h1 : b ^ 3 = 0 := by linarith\n        have h2 : b = 0 := by\n          have h3 : b ^ 3 = 0 := by linarith\n          simp at h3\n          linarith\n        exact h2\n      contradiction\n    field_simp [hb3] at h₁\n    linarith\n  have h4 : a ^ 2 * b ^ 3 = 32 / 27 := h₀\n  rw [h3] at h4\n  have h5 : (27 / 4 * b ^ 3) ^ 2 * b ^ 3 = 32 / 27 := by linarith\n  have h6 : (27 / 4 * b ^ 3) ^ 2 * b ^ 3 = (729 / 16) * b ^ 9 := by\n    ring_nf\n  rw [h6] at h5\n  have hb9 : b ^ 9 = 512 / 19683 := by\n    nlinarith\n  have hb : b = 2 / 3 := by\n    have h8 : b ^ 9 - 512 / 19683 = 0 := by linarith [hb9]\n    have h9 : (b - 2 / 3) * (b ^ 8 + (2 / 3) * b ^ 7 + (2 / 3) ^ 2 * b ^ 6 + (2 / 3) ^ 3 * b ^ 5 + (2 / 3) ^ 4 * b ^ 4 + (2 / 3) ^ 5 * b ^ 3 + (2 / 3) ^ 6 * b ^ 2 + (2 / 3) ^ 7 * b + (2 / 3) ^ 8) = 0 := by\n      ring_nf\n      nlinarith [h8]\n    cases (mul_eq_zero.mp h9) with\n    | inl h10 => \n      linarith\n    | inr h11 =>\n      have hb_pos : b > 0 := by\n        have h9_pos : b ^ 9 > 0 := by\n          rw [hb9]\n          norm_num\n        have : b > 0 := by\n          by_contra h\n          push_neg at h\n          have h1 : b ≤ 0 := by linarith\n          have h2 : b ^ 9 ≤ 0 := by\n            nlinarith [sq_nonneg (b ^ 4), sq_nonneg (b ^ 3), sq_nonneg (b ^ 2), sq_nonneg (b)]\n          linarith [h9_pos, h2]\n        exact this\n      have h12 : b ^ 8 + (2 / 3) * b ^ 7 + (2 / 3) ^ 2 * b ^ 6 + (2 / 3) ^ 3 * b ^ 5 + (2 / 3) ^ 4 * b ^ 4 + (2 / 3) ^ 5 * b ^ 3 + (2 / 3) ^ 6 * b ^ 2 + (2 / 3) ^ 7 * b + (2 / 3) ^ 8 > 0 := by\n        nlinarith [sq_nonneg (b ^ 4), sq_nonneg (b ^ 3), sq_nonneg (b ^ 2), sq_nonneg (b), hb_pos]\n      linarith [h11, h12]\n  have ha : a = 2 := by\n    rw [hb] at h3\n    nlinarith [h3]\n  rw [ha, hb]\n  norm_num",
    "name": "mathd_algebra_362"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_452 (a : ℕ → ℝ) (h₀ : ∀ n, a (n + 2) - a (n + 1) = a (n + 1) - a n)\n    (h₁ : a 1 = 2 / 3) (h₂ : a 9 = 4 / 5) : a 5 = 11 / 15 := by\n\n        have h3 := h₀ 1\n        have h4 := h₀ 2\n        have h5 := h₀ 3\n        have h6 := h₀ 4\n        have h7 := h₀ 5\n        have h8 := h₀ 6\n        have h9 := h₀ 7\n        have h10 := h₀ 8\n  \n        have eq3 : a 3 = 2 * a 2 - a 1 := by\n            linarith\n\n        have eq4 : a 4 = 2 * a 3 - a 2 := by\n            linarith\n\n        have eq4' : a 4 = 3 * a 2 - 2 * a 1 := by\n            rw [eq4, eq3]\n            linarith\n  \n        have eq5 : a 5 = 2 * a 4 - a 3 := by \n            linarith\n  \n        have eq5' : a 5 = 4 * a 2 - 3 * a 1 := by\n            rw [eq5, eq4', eq3]\n            linarith\n  \n        have eq6 : a 6 = 2 * a 5 - a 4 := by \n            linarith\n  \n        have eq6' : a 6 = 5 * a 2 - 4 * a 1 := by\n            rw [eq6, eq5', eq4']\n            linarith\n  \n        have eq7 : a 7 = 2 * a 6 - a 5 := by \n            linarith\n  \n        have eq7' : a 7 = 6 * a 2 - 5 * a 1 := by\n            rw [eq7, eq6', eq5']\n            linarith\n  \n        have eq8 : a 8 = 2 * a 7 - a 6 := by \n            linarith\n  \n        have eq8' : a 8 = 7 * a 2 - 6 * a 1 := by\n            rw [eq8, eq7', eq6']\n            linarith\n  \n        have eq9 : a 9 = 2 * a 8 - a 7 := by \n            linarith\n  \n        have eq9' : a 9 = 8 * a 2 - 7 * a 1 := by\n            rw [eq9, eq8', eq7']\n            linarith\n\n        have eq2 : a 2 = 41 / 60 := by \n            have h9_eq : a 9 = 8 * a 2 - 7 * a 1 := eq9'\n            rw [h₁] at h9_eq\n            rw [h₂] at h9_eq \n            linarith\n  \n        have eq5'' : a 5 = 11 / 15 := by \n            rw [eq5']\n            rw [h₁, eq2]\n            norm_num\n  \n        exact eq5''",
    "name": "mathd_algebra_452"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_457 (n : ℕ) (h₀ : 0 < n) (h₁ : 80325 ∣ n !) : 17 ≤ n := by\n  by_contra h\n  push_neg at h\n  have h2 : n ≤ 16 := by linarith\n  interval_cases n <;> contradiction",
    "name": "mathd_numbertheory_457"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_582 (n : ℕ) (h₀ : 0 < n) (h₁ : 3 ∣ n) :\n    (n + 4 + (n + 6) + (n + 8)) % 9 = 0 := by \n  have h2 : n % 9 = 0 ∨ n % 9 = 3 ∨ n % 9 = 6 := by\n    omega\n  rcases h2 with (h | h | h)\n  · -- n % 9 = 0\n    have h1 : n % 9 = 0 := h\n    omega\n  · -- n % 9 = 3\n    have h1 : n % 9 = 3 := h\n    omega\n  · -- n % 9 = 6\n    have h1 : n % 9 = 6 := h\n    omega",
    "name": "mathd_numbertheory_582"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_170 (S : Finset ℤ) (h₀ : ∀ n : ℤ, n ∈ S ↔ abs (n - 2) ≤ 5 + 6 / 10) :\n    S.card = 11 := by \n  have h1 : S = {-3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7} := by \n    ext n\n    simp [h₀]\n    constructor\n    · -- Assume $n \\in S$, we need to prove $n \\in \\{-3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7\\}$\n      intro h\n      rw [abs_le] at h\n      norm_num at h \n      have h1 : -3 ≤ n := by linarith \n      have h2 : n ≤ 7 := by linarith \n      have h3 : n = -3 ∨ n = -2 ∨ n = -1 ∨ n = 0 ∨ n = 1 ∨ n = 2 ∨ n = 3 ∨ n = 4 ∨ n = 5 ∨ n = 6 ∨ n = 7 := by \n        omega \n      exact h3\n    · -- Assume $n \\in \\{-3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7\\}$, we need to prove $n \\in S$\n      rintro (rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl)\n      · -- n = -3\n        norm_num [abs_le]\n      · -- n = -2\n        norm_num [abs_le]\n      · -- n = -1\n        norm_num [abs_le]\n      · -- n = 0\n        norm_num [abs_le]\n      · -- n = 1\n        norm_num [abs_le]\n      · -- n = 2\n        norm_num [abs_le]\n      · -- n = 3\n        norm_num [abs_le]\n      · -- n = 4\n        norm_num [abs_le]\n      · -- n = 5\n        norm_num [abs_le]\n      · -- n = 6\n        norm_num [abs_le]\n      · -- n = 7\n        norm_num [abs_le]\n  rw [h1]\n  native_decide",
    "name": "mathd_algebra_170"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_171 (f : ℝ → ℝ) (h₀ : ∀ x, f x = 5 * x + 4) : f 1 = 9 := by \n  have h1 : f 1 = 5 * 1 + 4 := h₀ 1\n  rw [h1]\n  norm_num",
    "name": "mathd_algebra_171"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_618 (n : ℕ) (hn : n > 0) (p : ℕ → ℕ) (h₀ : ∀ x, p x = x ^ 2 - x + 41)\n    (h₁ : 1 < Nat.gcd (p n) (p (n + 1))) : 41 ≤ n := by\n  have h2 : p n = n ^ 2 - n + 41 := h₀ n\n  have h3 : p (n + 1) = (n + 1) ^ 2 - (n + 1) + 41 := h₀ (n + 1)\n  rw [h2, h3] at h₁\n  by_contra h\n  push_neg at h\n  interval_cases n <;> norm_num [h₀] at h₁ <;> contradiction",
    "name": "mathd_numbertheory_618"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_sqineq_unitcircatbpabsamblt1 (a b : ℝ) (h₀ : a ^ 2 + b ^ 2 = 1) :\n    a * b + abs (a - b) ≤ 1 := by \n  by_cases h : a - b ≥ 0 \n  · -- Case 1: a - b ≥ 0, i.e., |a - b| = a - b\n    rw [abs_of_nonneg h]\n    nlinarith [sq_nonneg (a - 1), sq_nonneg (b + 1), sq_nonneg (a - b), sq_nonneg (a + b), h₀]\n  · -- Case 2: a - b < 0, i.e., |a - b| = b - a\n    rw [abs_of_neg (lt_of_not_ge h)]\n    nlinarith [sq_nonneg (a + 1), sq_nonneg (b - 1), sq_nonneg (a - b), sq_nonneg (a + b), h₀]",
    "name": "algebra_sqineq_unitcircatbpabsamblt1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_302 : (Complex.I / 2) ^ 2 = -(1 / 4) := by \n  calc\n    (Complex.I / 2) ^ 2 = (Complex.I ^ 2) / (2 ^ 2) := by ring\n    _ = (-1) / (2 ^ 2) := by rw [Complex.I_sq]\n    _ = (-1) / 4 := by norm_num\n    _ = -(1 / 4) := by ring",
    "name": "mathd_algebra_302"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2002_p13 (a b : ℝ) (h₀ : 0 < a ∧ 0 < b) (h₁ : a ≠ b) (h₂ : abs (a - 1 / a) = 1)\n    (h₃ : abs (b - 1 / b) = 1) : a + b = Real.sqrt 5 := by\n\n  have h_a : (a - 1 / a) = 1 ∨ (a - 1 / a) = -1 := by\n    cases eq_or_eq_neg_of_abs_eq h₂ with\n    | inl h => left; linarith\n    | inr h => right; linarith\n\n  have h_b : (b - 1 / b) = 1 ∨ (b - 1 / b) = -1 := by\n    cases eq_or_eq_neg_of_abs_eq h₃ with\n    | inl h => left; linarith\n    | inr h => right; linarith\n\n  rcases h_a with h_a1 | h_a2\n  · -- Case 1: a - 1/a = 1\n    rcases h_b with h_b1 | h_b2\n    · -- Subcase 1: a - 1/a = 1 and b - 1/b = 1\n      have eq1 : a^2 - a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a1\n        nlinarith\n\n      have eq2 : b^2 - b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b1\n        nlinarith\n\n      have h4 : a = b := by\n        have h5 : a^2 - a - 1 = 0 := eq1\n        have h6 : b^2 - b - 1 = 0 := eq2\n        have h7 : a^2 - a - 1 - (b^2 - b - 1) = 0 := by linarith\n        have h8 : a^2 - b^2 - (a - b) = 0 := by linarith\n        have h9 : (a - b) * (a + b - 1) = 0 := by\n          nlinarith [h8]\n        cases' (mul_eq_zero.mp h9) with h10 h11\n        · -- a - b = 0, so a = b\n          linarith\n        · -- a + b - 1 = 0, so a + b = 1\n          have h12 : a + b = 1 := by linarith\n          have h13 : b = 1 - a := by linarith\n          have h14 : a < 1 := by nlinarith [h₀.right, h13]\n          have h15 : a^2 - a - 1 = 0 := by linarith\n          have h16 : a < 1 := by nlinarith [h₀.right, h13]\n          have h17 : a > 0 := h₀.left\n          nlinarith [sq_nonneg (a - 1), h16, h17]\n      contradiction\n    · -- Subcase 2: a - 1/a = 1 and b - 1/b = -1\n      have eq1 : a^2 - a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a1\n        nlinarith\n\n      have eq2 : b^2 + b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b2\n        nlinarith\n\n      have ha : a = (1 + Real.sqrt 5) / 2 ∨ a = (1 - Real.sqrt 5) / 2 := by\n        have h1 : a^2 - a - 1 = 0 := eq1\n        have h2 : (2 * a - 1) ^ 2 = 5 := by\n          have h3 : a^2 - a - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * a - 1 = Real.sqrt 5 ∨ 2 * a - 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      have hb : b = (-1 + Real.sqrt 5) / 2 ∨ b = (-1 - Real.sqrt 5) / 2 := by\n        have h1 : b^2 + b - 1 = 0 := eq2\n        have h2 : (2 * b + 1) ^ 2 = 5 := by\n          have h3 : b^2 + b - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * b + 1 = Real.sqrt 5 ∨ 2 * b + 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      cases ha with\n      | inl ha1 =>\n        cases hb with\n        | inl hb1 =>\n          have h1 : a + b = Real.sqrt 5 := by\n            rw [ha1, hb1]\n            ring\n          linarith\n        | inr hb2 =>\n          have h2 : b < 0 := by\n            rw [hb2]\n            have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n            nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n          linarith [h₀.right, h2]\n      | inr ha2 =>\n        have h2 : a < 0 := by\n          rw [ha2]\n          have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n          nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n        linarith [h₀.left, h2]\n  · -- Case 2: a - 1/a = -1\n    rcases h_b with h_b1 | h_b2\n    · -- Subcase 1: a - 1/a = -1 and b - 1/b = 1\n      have eq1 : a^2 + a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a2\n        nlinarith\n\n      have eq2 : b^2 - b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b1\n        nlinarith\n\n      have ha : a = (-1 + Real.sqrt 5) / 2 ∨ a = (-1 - Real.sqrt 5) / 2 := by\n        have h1 : a^2 + a - 1 = 0 := eq1\n        have h2 : (2 * a + 1) ^ 2 = 5 := by\n          have h3 : a^2 + a - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * a + 1 = Real.sqrt 5 ∨ 2 * a + 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      have hb : b = (1 + Real.sqrt 5) / 2 ∨ b = (1 - Real.sqrt 5) / 2 := by\n        have h1 : b^2 - b - 1 = 0 := eq2\n        have h2 : (2 * b - 1) ^ 2 = 5 := by\n          have h3 : b^2 - b - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * b - 1 = Real.sqrt 5 ∨ 2 * b - 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      cases ha with\n      | inl ha1 =>\n        cases hb with\n        | inl hb1 =>\n          have h1 : a + b = Real.sqrt 5 := by\n            rw [ha1, hb1]\n            ring\n          linarith\n        | inr hb2 =>\n          have h2 : b < 0 := by\n            rw [hb2]\n            have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n            nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n          linarith [h₀.right, h2]\n      | inr ha2 =>\n        have h2 : a < 0 := by\n          rw [ha2]\n          have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n          nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n        linarith [h₀.left, h2]\n    · -- Subcase 2: a - 1/a = -1 and b - 1/b = -1\n      have eq1 : a^2 + a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a2\n        nlinarith\n\n      have eq2 : b^2 + b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b2\n        nlinarith\n\n      have h4 : a = b := by\n        have h5 : a^2 + a - 1 = 0 := eq1\n        have h6 : b^2 + b - 1 = 0 := eq2\n        have h7 : a^2 + a - 1 - (b^2 + b - 1) = 0 := by linarith\n        have h8 : a^2 - b^2 + (a - b) = 0 := by linarith\n        have h9 : (a - b) * (a + b + 1) = 0 := by\n          nlinarith [h8]\n        cases' (mul_eq_zero.mp h9) with h10 h11\n        · -- a - b = 0, so a = b\n          linarith\n        · -- a + b + 1 = 0\n          have h12 : a + b = -1 := by linarith\n          nlinarith [h₀.left, h₀.right, h12]\n      contradiction",
    "name": "amc12a_2002_p13"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_320 (n : ℕ) (h₀ : n < 101) (h₁ : 101 ∣ 123456 - n) : n = 34 := by\n  have h2 : n = 34 := by \n    omega\n  exact h2",
    "name": "mathd_numbertheory_320"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1981_p6 (f : ℕ → ℕ → ℕ) (h₀ : ∀ y, f 0 y = y + 1) (h₁ : ∀ x, f (x + 1) 0 = f x 1)\n    (h₂ : ∀ x y, f (x + 1) (y + 1) = f x (f (x + 1) y)) : ∀ y, f 4 (y + 1) = 2 ^ (f 4 y + 3) - 3 := by\n  have h3_eq : ∀ z, f 3 z = 2 ^ (z + 3) - 3 := by\n    intro z\n    induction z with\n    | zero =>\n      have h30 : f 3 0 = 5 := by\n        have h1 : f 3 0 = f 2 1 := by rw [h₁ 2]\n        have h2 : f 2 1 = f 1 (f 2 0) := by rw [h₂ 1 0]\n        have h3 : f 2 0 = f 1 1 := by rw [h₁ 1]\n        have h4 : f 1 1 = f 0 (f 1 0) := by rw [h₂ 0 0]\n        have h5 : f 1 0 = f 0 1 := by rw [h₁ 0]\n        have h6 : f 0 1 = 2 := by norm_num [h₀]\n        have h7 : f 0 2 = 3 := by norm_num [h₀]\n        rw [h6] at h5\n        rw [h5] at h4\n        rw [h7] at h4\n        have h8 : f 2 0 = 3 := by linarith\n        rw [h8] at h2\n        have h9 : f 1 3 = 5 := by\n          have h11 : f 1 3 = f 0 (f 1 2) := by rw [h₂ 0 2]\n          have h12 : f 1 2 = f 0 (f 1 1) := by rw [h₂ 0 1]\n          have h13 : f 1 1 = 3 := by linarith\n          rw [h13] at h12\n          have h14 : f 0 3 = 4 := by norm_num [h₀]\n          rw [h14] at h12\n          have h15 : f 0 4 = 5 := by norm_num [h₀]\n          rw [h12] at h11\n          rw [h15] at h11\n          exact h11\n        rw [h9] at h2\n        have h10 : f 3 0 = 5 := by linarith\n        exact h10\n      norm_num [h30]\n    | succ z ih =>\n      have eq1 : f 3 (z + 1) = f 2 (f 3 z) := by \n        rw [h₂ 2 z]\n      rw [eq1]\n      have h2_eq : ∀ w, f 2 w = 2 * w + 3 := by\n        intro w\n        induction w with\n        | zero =>\n          have h20 : f 2 0 = 3 := by\n            have h21 : f 2 0 = f 1 1 := by rw [h₁ 1]\n            have h22 : f 1 1 = 3 := by \n              have h23 : f 1 1 = f 0 (f 1 0) := by rw [h₂ 0 0]\n              have h24 : f 1 0 = f 0 1 := by rw [h₁ 0]\n              have h25 : f 0 1 = 2 := by norm_num [h₀]\n              rw [h25] at h24\n              rw [h24] at h23\n              have h26 : f 0 2 = 3 := by norm_num [h₀]\n              rw [h26] at h23\n              linarith\n            rw [h22] at h21\n            linarith\n          norm_num [h20]\n        | succ w ih =>\n          have eq1 : f 2 (w + 1) = f 1 (f 2 w) := by \n            rw [h₂ 1 w]\n          rw [eq1]\n          have h1_eq : ∀ z, f 1 z = z + 2 := by \n            intro z\n            induction z with\n            | zero =>\n              have h10 : f 1 0 = 2 := by \n                have h11 : f 1 0 = f 0 1 := by rw [h₁ 0]\n                have h12 : f 0 1 = 2 := by norm_num [h₀]\n                rw [h12] at h11\n                linarith\n              norm_num [h10]\n            | succ z ih =>\n              have eq1 : f 1 (z + 1) = f 0 (f 1 z) := by rw [h₂ 0 z]\n              rw [eq1]\n              have eq2 : f 1 z = z + 2 := ih\n              rw [eq2]\n              have eq3 : f 0 (z + 2) = (z + 2) + 1 := by \n                rw [h₀ (z + 2)]\n              rw [eq3]\n              all_goals omega\n          have eq2 : f 1 (f 2 w) = f 2 w + 2 := by \n            apply h1_eq \n          rw [eq2]\n          have eq3 : f 2 w = 2 * w + 3 := ih\n          rw [eq3]\n          omega\n      have eq2 : f 2 (f 3 z) = 2 * (f 3 z) + 3 := by \n        apply h2_eq \n      rw [eq2]\n      have eq3 : f 3 z = 2 ^ (z + 3) - 3 := ih\n      rw [eq3]\n      have eq4 : 2 * (2 ^ (z + 3) - 3) + 3 = 2 ^ (z + 4) - 3 := by \n        zify\n        rw [Nat.cast_sub (by \n          have h1 : 2 ^ (z + 3) ≥ 3 := by \n            have h2 : 2 ^ (z + 3) ≥ 2 ^ 3 := by \n              apply Nat.pow_le_pow_of_le_right (by norm_num) (by omega)\n            have h3 : 2 ^ 3 = 8 := by norm_num\n            linarith\n          omega)]\n        rw [Nat.cast_sub (by \n          have h1 : 2 ^ (z + 4) ≥ 3 := by \n            have h2 : 2 ^ (z + 4) ≥ 2 ^ 3 := by \n              apply Nat.pow_le_pow_of_le_right (by norm_num) (by omega)\n            have h3 : 2 ^ 3 = 8 := by norm_num\n            linarith\n          omega)]\n        ring\n        all_goals omega\n      rw [eq4]\n  intro y\n  have eq1 : f 4 (y + 1) = f 3 (f 4 y) := by \n    rw [h₂ 3 y]\n  rw [eq1]\n  have eq2 : f 3 (f 4 y) = 2 ^ (f 4 y + 3) - 3 := by \n    apply h3_eq \n  exact eq2",
    "name": "imo_1981_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_341 (a b c : ℕ) (h₀ : a ≤ 9 ∧ b ≤ 9 ∧ c ≤ 9)\n    (h₁ : Nat.digits 10 (5 ^ 100 % 1000) = [c, b, a]) : a + b + c = 13 := by \n  have h2 : 5 ^ 100 % 1000 = 625 := by\n    norm_num\n  \n  have h3 : Nat.digits 10 625 = [5, 2, 6] := by \n    norm_num\n  \n  rw [h2] at h₁ \n  rw [h3] at h₁\n  \n  have hc : c = 5 := by \n    simp at h₁ \n    omega\n  \n  have hb : b = 2 := by \n    simp at h₁ \n    omega\n  \n  have ha : a = 6 := by \n    simp at h₁ \n    omega\n\n  omega",
    "name": "mathd_numbertheory_341"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_absxm1pabsxpabsxp1eqxp2_0leqxleq1 (x : ℝ)\n    (h₀ : abs (x - 1) + abs x + abs (x + 1) = x + 2) : 0 ≤ x ∧ x ≤ 1 := by\n  by_cases h1 : x ≥ 1\n  · -- Case 1: x ≥ 1\n    rw [abs_of_nonneg (by linarith), abs_of_nonneg (by linarith), abs_of_nonneg (by linarith)] at h₀\n    constructor\n    · linarith\n    · linarith\n  · -- Case 2: x < 1\n    by_cases h2 : 0 ≤ x\n    · -- Subcase 2a: 0 ≤ x < 1\n      by_cases h3 : x < 1\n      · -- 0 ≤ x < 1\n        rw [abs_of_neg (by linarith), abs_of_nonneg (by linarith), abs_of_nonneg (by linarith)] at h₀\n        constructor\n        · linarith \n        · linarith\n      · -- x ≥ 1 in the context of x < 1? This is a contradiction\n        linarith\n    · -- Subcase 2b: x < 0\n      by_cases h3 : x ≥ -1\n      · -- -1 ≤ x < 0\n        rw [abs_of_neg (by linarith), abs_of_neg (by linarith), abs_of_nonneg (by linarith)] at h₀\n        constructor\n        · linarith \n        · linarith\n      · -- Case 3: x < -1\n        rw [abs_of_neg (by linarith), abs_of_neg (by linarith), abs_of_neg (by linarith)] at h₀\n        constructor\n        · linarith \n        · linarith",
    "name": "algebra_absxm1pabsxpabsxp1eqxp2_0leqxleq1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_234 (a b : ℕ) (h₀ : 1 ≤ a ∧ a ≤ 9 ∧ b ≤ 9)\n    (h₁ : (10 * a + b) ^ 3 = 912673) : a + b = 16 := by\n\n  have h2 : a ≤ 9 := h₀.right.left\n  have h3 : b ≤ 9 := h₀.right.right\n  \n  have h4 : 10 * a + b = 97 := by\n    have h5 : 10 * a + b ≤ 99 := by \n      omega\n    have h6 : 10 * a + b ≥ 10 := by\n      omega\n\n    have h7 : 10 * a + b = 97 := by\n      interval_cases h11 : (10 * a + b) <;> omega\n\n    exact h7\n\n  have h12 : a = 9 := by \n    omega\n  \n  have h13 : b = 7 := by \n    omega\n\n  calc \n    a + b = 9 + 7 := by rw [h12, h13]\n    _ = 16 := by norm_num",
    "name": "mathd_numbertheory_234"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_342 (a d : ℝ) (h₀ : (∑ k in Finset.range 5, (a + k * d)) = 70)\n    (h₁ : (∑ k in Finset.range 10, (a + k * d)) = 210) : a = 42 / 5 := by\n\n  norm_num [Finset.sum_range_succ, add_mul, mul_add] at h₀ h₁\n\n  linarith",
    "name": "mathd_algebra_342"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_495 (a b : ℕ) (h₀ : 0 < a ∧ 0 < b) (h₁ : a % 10 = 2) (h₂ : b % 10 = 4)\n    (h₃ : Nat.gcd a b = 6) : 108 ≤ Nat.lcm a b := by\n\n  have h4 : Nat.gcd a b * Nat.lcm a b = a * b := by\n    rw [Nat.gcd_mul_lcm]\n\n  have h5 : 6 ∣ a := by\n    have h6 : Nat.gcd a b ∣ a := Nat.gcd_dvd_left a b\n    rw [h₃] at h6\n    exact Nat.dvd_trans (by norm_num) h6\n\n  have h6 : 6 ∣ b := by\n    have h7 : Nat.gcd a b ∣ b := Nat.gcd_dvd_right a b\n    rw [h₃] at h7\n    exact Nat.dvd_trans (by norm_num) h7\n\n  have h7 : a ≥ 12 := by\n    by_contra h\n    push_neg at h\n    have h8 : a < 12 := h\n    have h9 : a % 10 = 2 := h₁\n    interval_cases a <;> norm_num at *\n    all_goals omega\n\n  have h10 : b ≥ 24 := by\n    by_contra h\n    push_neg at h\n    have h11 : b < 24 := h\n    have h12 : b % 10 = 4 := h₂\n    interval_cases b <;> norm_num at *\n    all_goals omega\n\n  have h11 : 108 ≤ Nat.lcm a b := by\n    by_contra h\n    push_neg at h\n    have h12 : Nat.lcm a b < 108 := h\n    have h13 : a * b < 648 := by\n      have h14 : a.gcd b * a.lcm b = a * b := by rw [Nat.gcd_mul_lcm]\n      rw [h₃] at h14\n      have h15 : a * b = 6 * (a.lcm b) := by linarith\n      have h16 : a.lcm b < 108 := h12\n      linarith [h16, h15]\n    have h14 : a ≤ 54 := by nlinarith [h13, h7, h10]\n    have h15 : b ≤ 54 := by nlinarith [h13, h7, h10]\n    interval_cases a <;> interval_cases b\n    all_goals\n      norm_num at *\n      all_goals\n        try { contradiction }\n        try { omega }\n  exact h11",
    "name": "mathd_numbertheory_495"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_143 (f g : ℝ → ℝ) (h₀ : ∀ x, f x = x + 1) (h₁ : ∀ x, g x = x ^ 2 + 3) :\n    f (g 2) = 8 := by \n  have g2 : g 2 = 7 := by \n    rw [h₁]\n    norm_num\n  rw [g2]\n  rw [h₀]\n  norm_num",
    "name": "mathd_algebra_143"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_756 (a b : ℝ) (h₀ : (2 : ℝ) ^ a = 32) (h₁ : a ^ b = 125) : b ^ a = 243 := by\n  have ha : a = 5 := by\n    have h2 : (2 : ℝ) ^ (5 : ℝ) = 32 := by norm_num [Real.rpow_natCast]\n    have h3 : a = Real.logb 2 32 := by\n      rw [←h₀]\n      field_simp [Real.logb_eq_iff_rpow_eq]\n      all_goals linarith\n    rw [h3]\n    have h4 : Real.logb 2 (32 : ℝ) = 5 := by\n      rw [Real.logb_eq_iff_rpow_eq] <;> (norm_num)\n    linarith [h4]\n  have hb : b = 3 := by\n    rw [ha] at h₁\n    have h5 : (5 : ℝ) ^ b = 125 := h₁\n    have h6 : b = Real.logb 5 125 := by\n      rw [←h5]\n      field_simp [Real.logb_eq_iff_rpow_eq]\n      all_goals linarith\n    have h7 : Real.logb 5 (125 : ℝ) = 3 := by\n      rw [Real.logb_eq_iff_rpow_eq] <;> (norm_num)\n    rw [h6, h7]\n  rw [ha, hb]\n  norm_num [Real.rpow_natCast]",
    "name": "mathd_algebra_756"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_765 (x : ℤ) (h₀ : x < 0) (h₁ : 24 * x % 1199 = 15) : x ≤ -449 := by \n  have h2 : x % 1199 = 750 := by \n    norm_num; omega\n  omega",
    "name": "mathd_numbertheory_765"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_728 : (29 ^ 13 - 5 ^ 13) % 7 = 3 := by \n  norm_num",
    "name": "mathd_numbertheory_728"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_296 (n : ℕ) (h₀ : 2 ≤ n) (h₁ : ∃ x, x ^ 3 = n) (h₂ : ∃ t, t ^ 4 = n) :\n    4096 ≤ n := by \n  rcases h₁ with ⟨x, hx⟩\n  rcases h₂ with ⟨t, ht⟩\n  by_contra h\n  push_neg at h\n  have h3 : n < 4096 := h\n  have h4 : x ^ 3 = t ^ 4 := by linarith\n  have h5 : x ≤ 15 := by\n    have h6 : x ^ 3 < 4096 := by linarith\n    by_contra h7\n    push_neg at h7\n    have h8 : x ^ 3 ≥ 4096 := by\n      have h9 : x ≥ 16 := by linarith\n      have h10 : x ^ 3 ≥ 16 ^ 3 := by\n        apply Nat.pow_le_pow_of_le_left h9 3\n      norm_num at h10\n      linarith\n    linarith\n  have h6 : t ≤ 7 := by\n    have h7 : t ^ 4 < 4096 := by linarith\n    by_contra h8\n    push_neg at h8\n    have h9 : t ≥ 8 := by linarith\n    have h10 : t ^ 4 ≥ 4096 := by\n      have h11 : t ^ 4 ≥ 8 ^ 4 := by\n        apply Nat.pow_le_pow_of_le_left h9 4\n      norm_num at h11\n      linarith\n    linarith\n  interval_cases x <;> interval_cases t <;> omega",
    "name": "mathd_numbertheory_296"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_237 : (∑ k in Finset.range 101, k) % 6 = 4 := by \n  calc \n    (∑ k in Finset.range 101, k) % 6 = 5050 % 6 := by \n      native_decide \n    _ = 4 := by \n      norm_num",
    "name": "mathd_numbertheory_237"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem induction_pprime_pdvdapowpma (p a : ℕ) (h₀ : 0 < a) (h₁ : Nat.Prime p) : p ∣ a ^ p - a := by\n  have h2 : p ∣ a ^ p - a := by\n    have h3 : a ^ p ≡ a [MOD p] := by\n      have h4 : Fact p.Prime := ⟨h₁⟩\n      have h5 : a ^ p % p = a % p := by\n        have h6 : a ^ p % p = a % p := by\n          have h7 : Fact p.Prime := ⟨h₁⟩\n          have h8 : a ^ p % p = a % p := by\n            apply (ZMod.eq_iff_modEq_nat p).mp\n            have h9 : (a : ZMod p) ^ p = (a : ZMod p) := by\n              rw [ZMod.pow_card]\n            simp [h9]\n            <;> (try { simp })\n            <;> (try { omega })\n          exact h8\n        exact h6\n      exact h5\n    exact Nat.dvd_of_mod_eq_zero (Nat.sub_mod_eq_zero_of_mod_eq h3)\n  exact h2",
    "name": "induction_pprime_pdvdapowpma"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_135 (n A B C : ℕ) (h₀ : n = 3 ^ 17 + 3 ^ 10) (h₁ : 11 ∣ n + 1)\n    (h₂ : [A, B, C].Pairwise (· ≠ ·)) (h₃ : {A, B, C} ⊂ Finset.Icc 0 9) (h₄ : Odd A ∧ Odd C)\n    (h₅ : ¬3 ∣ B) (h₆ : Nat.digits 10 n = [B, A, B, C, C, A, C, B, A]) :\n    100 * A + 10 * B + C = 129 := by\n  have hn : n = 129199212 := by\n    norm_num [h₀]\n  rw [hn] at h₆\n  simp [Nat.digits, Nat.digitsAux] at h₆\n  have hB : B = 2 := by \n    linarith\n  have hA : A = 1 := by \n    linarith\n  have hC : C = 9 := by \n    linarith\n  calc \n    100 * A + 10 * B + C = 100 * 1 + 10 * 2 + 9 := by rw [hA, hB, hC]\n    _ = 100 + 20 + 9 := by norm_num\n    _ = 129 := by norm_num",
    "name": "mathd_numbertheory_135"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem induction_11div10tonmn1ton (n : ℕ) : 11 ∣ 10 ^ n - (-1 : ℤ) ^ n := by \n  induction n with\n  | zero =>\n    norm_num\n  | succ n ih =>\n    have h1 : 10 ^ (n + 1) - (-1 : ℤ) ^ (n + 1) = 10 * (10 ^ n) - (-1) * (-1 : ℤ) ^ n := by \n      ring\n    rw [h1]\n    have h2 : 10 * (10 ^ n) - (-1) * (-1 : ℤ) ^ n = 10 * (10 ^ n - (-1 : ℤ) ^ n) + 11 * (-1 : ℤ) ^ n := by \n      ring\n    rw [h2]\n    omega",
    "name": "induction_11div10tonmn1ton"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_158 (a : ℕ) (h₀ : Even a)\n    (h₁ : ∑ k in Finset.range 8, (2 * k + 1) - ∑ k in Finset.range 5, (a + 2 * k) = (4 : ℤ)) :\n    a = 8 := by\n  norm_num [Finset.sum_range_succ, Nat.even_iff] at h₁ h₀ ⊢\n  omega",
    "name": "mathd_algebra_158"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1984_p1 (u : ℕ → ℚ) (h₀ : ∀ n, u (n + 1) = u n + 1)\n    (h₁ : (∑ k in Finset.range 98, u k.succ) = 137) :\n    (∑ k in Finset.range 49, u (2 * k.succ)) = 93 := by \n  norm_num [Finset.sum_range_succ, h₀] at h₁ ⊢ \n  linarith",
    "name": "aime_1984_p1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2021_p18 (z : ℂ)\n    (h₀ : 12 * Complex.normSq z = 2 * Complex.normSq (z + 2) + Complex.normSq (z ^ 2 + 1) + 31) :\n    z + 6 / z = -2 := by\n\n  have hne : z ≠ 0 := by\n    by_contra h\n    rw [h] at h₀\n    simp [Complex.normSq] at h₀\n    all_goals linarith\n\n  have h1 : z.re ^ 2 + z.im ^ 2 = 6 := by\n    have eq1 := h₀\n    simp [Complex.normSq, pow_two, Complex.add_re, Complex.add_im, Complex.mul_re, Complex.mul_im, Complex.ofReal_re, Complex.ofReal_im] at eq1\n    nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), sq_nonneg (z.re ^ 2 + z.im ^ 2 - 6)]\n\n  have h2 : z.re = -1 := by\n    have eq1 := h₀\n    simp [Complex.normSq, pow_two, Complex.add_re, Complex.add_im, Complex.mul_re, Complex.mul_im, Complex.ofReal_re, Complex.ofReal_im] at eq1\n    have h_eq : (z.re + 1) ^ 2 + (z.im ^ 2 - 5) ^ 2 = 0 := by \n      nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), h1]\n    have h_re : (z.re + 1) ^ 2 = 0 := by nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), h_eq]\n    have h_im : (z.im ^ 2 - 5) ^ 2 = 0 := by nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), h_eq]\n    have h_re_zero : z.re + 1 = 0 := by nlinarith [h_re]\n    linarith\n\n  have him : z.im ^ 2 = 5 := by \n    have h_re : z.re = -1 := h2\n    have h : z.re ^ 2 + z.im ^ 2 = 6 := h1\n    rw [h_re] at h\n    nlinarith\n\n  have h3 : z + 6 / z = -2 := by \n    have hz_ne_zero : z ≠ 0 := hne\n    have hz_re : z.re = -1 := h2\n    have hz_im_sq : z.im ^ 2 = 5 := him\n\n    have h2 : z.im = Real.sqrt 5 ∨ z.im = -Real.sqrt 5 := by\n      have h3 : z.im ^ 2 - 5 = 0 := by linarith\n      have h4 : z.im ^ 2 = 5 := by linarith\n      have h5 : z.im = Real.sqrt 5 ∨ z.im = -Real.sqrt 5 := by \n        apply eq_or_eq_neg_of_sq_eq_sq\n        norm_num\n        linarith\n      exact h5\n\n    cases h2 with\n    | inl him_pos =>\n      have him : z.im = Real.sqrt 5 := him_pos\n      have hz : z = -1 + Real.sqrt 5 * Complex.I := by \n        rw [Complex.ext_iff]\n        simp [hz_re, him]\n      rw [hz]\n      field_simp [Complex.ext_iff, hz_re, him, mul_add, pow_two, Complex.I_mul_I]\n      <;> ring_nf <;> norm_num [Real.sq_sqrt]\n    \n    | inr him_neg =>\n      have him : z.im = -Real.sqrt 5 := him_neg\n      have hz : z = -1 + (-Real.sqrt 5) * Complex.I := by \n        rw [Complex.ext_iff]\n        simp [hz_re, him]\n      rw [hz]\n      field_simp [Complex.ext_iff, hz_re, him, mul_add, pow_two, Complex.I_mul_I]\n      <;> ring_nf <;> norm_num [Real.sq_sqrt]\n    \n  exact h3",
    "name": "amc12b_2021_p18"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_343 : (∏ k in Finset.range 6, (2 * k + 1)) % 10 = 5 := by \n  rfl",
    "name": "mathd_numbertheory_343"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem numbertheory_aoddbdiv4asqpbsqmod8eq1 (a : ℤ) (b : ℕ) (h₀ : Odd a) (h₁ : 4 ∣ b) :\n    (a ^ 2 + b ^ 2) % 8 = 1 := by \n  rcases h₀ with ⟨m, hm⟩\n  rcases h₁ with ⟨k, hk⟩\n  have ha : a ^ 2 % 8 = 1 := by\n    rw [hm]\n    have h : (2 * m + 1) ^ 2 % 8 = 1 := by \n      have h1 : (2 * m + 1) % 8 = 1 ∨ (2 * m + 1) % 8 = 3 ∨ (2 * m + 1) % 8 = 5 ∨ (2 * m + 1) % 8 = 7 := by \n        have h2 : m % 2 = 0 ∨ m % 2 = 1 := by \n          omega\n        rcases h2 with (h2 | h2) <;> ( \n          have : (2 * m + 1) % 8 = 1 ∨ (2 * m + 1) % 8 = 3 ∨ (2 * m + 1) % 8 = 5 ∨ (2 * m + 1) % 8 = 7 := by \n            omega\n          assumption\n        )\n      rcases h1 with (h1 | h1 | h1 | h1) <;> ( \n        norm_num [h1, pow_two, Int.add_emod, Int.mul_emod] \n      )\n    exact h\n  have hb : (b : ℤ) ^ 2 % 8 = 0 := by \n    have h4 : (b : ℤ) = 4 * (k : ℤ) := by \n      norm_num [hk]\n    rw [h4]\n    have h5 : (4 * (k : ℤ)) ^ 2 % 8 = 0 := by \n      have h6 : (4 * (k : ℤ)) ^ 2 = 16 * (k : ℤ) ^ 2 := by \n        ring\n      rw [h6]\n      omega\n    exact h5\n  have h2 : (a ^ 2 + (b : ℤ) ^ 2) % 8 = 1 := by \n    have h3 : (a ^ 2 + (b : ℤ) ^ 2) % 8 = (a ^ 2 % 8 + ((b : ℤ) ^ 2 % 8)) % 8 := by \n      simp [Int.add_emod]\n    rw [h3, ha, hb]\n    norm_num\n  norm_cast at h2",
    "name": "numbertheory_aoddbdiv4asqpbsqmod8eq1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_bleqa_apbon2msqrtableqambsqon8b (a b : ℝ) (h₀ : 0 < a ∧ 0 < b) (h₁ : b ≤ a) :\n    (a + b) / 2 - Real.sqrt (a * b) ≤ (a - b) ^ 2 / (8 * b) := by\n  have h2 : Real.sqrt (a * b) = Real.sqrt a * Real.sqrt b := by\n    rw [Real.sqrt_mul]\n    all_goals linarith\n  have h3 : 0 < b := h₀.right\n  have h4 : 0 < a := h₀.left\n  have h5 : (a + b) / 2 - Real.sqrt (a * b) ≤ (a - b) ^ 2 / (8 * b) := by\n    have h6 : (a + b) / 2 - Real.sqrt (a * b) = (Real.sqrt a - Real.sqrt b) ^ 2 / 2 := by\n      rw [h2]\n      have h7 : Real.sqrt a ^ 2 = a := by\n        rw [Real.sq_sqrt]\n        linarith\n      have h8 : Real.sqrt b ^ 2 = b := by\n        rw [Real.sq_sqrt]\n        linarith\n      have h9 : (Real.sqrt a - Real.sqrt b) ^ 2 = (Real.sqrt a) ^ 2 - 2 * (Real.sqrt a * Real.sqrt b) + (Real.sqrt b) ^ 2 := by ring\n      rw [h9]\n      have h10 : (Real.sqrt a) ^ 2 - 2 * (Real.sqrt a * Real.sqrt b) + (Real.sqrt b) ^ 2 = a + b - 2 * Real.sqrt a * Real.sqrt b := by\n        have h11 : (Real.sqrt a) ^ 2 = a := by\n          exact h7\n        have h12 : (Real.sqrt b) ^ 2 = b := by\n          exact h8\n        have h13 : Real.sqrt a * Real.sqrt b = Real.sqrt a * Real.sqrt b := by rfl\n        linarith [h11, h12]\n      linarith [h10, h7, h8]\n    have h10 : (a - b) ^ 2 / (8 * b) = ((Real.sqrt a - Real.sqrt b) ^ 2 * (Real.sqrt a + Real.sqrt b) ^ 2) / (8 * b) := by\n      have hsqab2 : (a - b) ^ 2 = (Real.sqrt a - Real.sqrt b) ^ 2 * (Real.sqrt a + Real.sqrt b) ^ 2 := by\n        have h1 : (Real.sqrt a - Real.sqrt b) * (Real.sqrt a + Real.sqrt b) = a - b := by\n          calc\n            (Real.sqrt a - Real.sqrt b) * (Real.sqrt a + Real.sqrt b)\n              = (Real.sqrt a) ^ 2 - (Real.sqrt b) ^ 2 := by ring\n            _ = a - b := by\n              have h2 : (Real.sqrt a) ^ 2 = a := by\n                exact Real.sq_sqrt (by linarith)\n              have h3 : (Real.sqrt b) ^ 2 = b := by\n                exact Real.sq_sqrt (by linarith)\n              linarith [h2, h3]\n        have h2 : (Real.sqrt a - Real.sqrt b) ^ 2 * (Real.sqrt a + Real.sqrt b) ^ 2 = ((Real.sqrt a - Real.sqrt b) * (Real.sqrt a + Real.sqrt b)) ^ 2 := by\n          ring\n        rw [h2]\n        have h3 : ((Real.sqrt a - Real.sqrt b) * (Real.sqrt a + Real.sqrt b)) ^ 2 = (a - b) ^ 2 := by\n          rw [h1]\n        linarith [h3]\n      field_simp\n      nlinarith [hsqab2]\n    rw [h6, h10]\n    have h11 : 0 ≤ Real.sqrt a := Real.sqrt_nonneg a\n    have h12 : 0 ≤ Real.sqrt b := Real.sqrt_nonneg b\n    have h13 : 0 ≤ Real.sqrt a + Real.sqrt b := by\n      linarith [h11, h12]\n    have h14 : 0 ≤ (Real.sqrt a - Real.sqrt b) ^ 2 := by\n      apply sq_nonneg\n    have h15 : (Real.sqrt a + Real.sqrt b) ^ 2 ≥ 4 * b := by\n      have h16 : Real.sqrt a ≥ Real.sqrt b := Real.sqrt_le_sqrt (by linarith)\n      nlinarith [Real.sq_sqrt (show (0 : ℝ) ≤ a by linarith), Real.sq_sqrt (show (0 : ℝ) ≤ b by linarith),\n        mul_self_nonneg (Real.sqrt a - Real.sqrt b), h16]\n    have h17 : 0 ≤ (Real.sqrt a - Real.sqrt b) ^ 2 * ((Real.sqrt a + Real.sqrt b) ^ 2 - 4 * b) := by\n      apply mul_nonneg\n      · exact h14\n      · linarith [h15]\n    have h18 : 0 ≤ 8 * b := by\n      linarith [h3]\n    have h19 : (Real.sqrt a - Real.sqrt b) ^ 2 * ((Real.sqrt a + Real.sqrt b) ^ 2 - 4 * b) / (8 * b) ≥ 0 := by\n      apply div_nonneg\n      · exact h17\n      · linarith [h18]\n    have h20 : (Real.sqrt a - Real.sqrt b) ^ 2 / 2 ≤ ((Real.sqrt a - Real.sqrt b) ^ 2 * (Real.sqrt a + Real.sqrt b) ^ 2) / (8 * b) := by\n      have h22 : ((Real.sqrt a - Real.sqrt b) ^ 2 * (Real.sqrt a + Real.sqrt b) ^ 2) / (8 * b) - (Real.sqrt a - Real.sqrt b) ^ 2 / 2 = (Real.sqrt a - Real.sqrt b) ^ 2 * ((Real.sqrt a + Real.sqrt b) ^ 2 - 4 * b) / (8 * b) := by\n        field_simp\n        ring\n      have h21 : (Real.sqrt a - Real.sqrt b) ^ 2 * ((Real.sqrt a + Real.sqrt b) ^ 2 - 4 * b) / (8 * b) ≥ 0 := by\n        apply div_nonneg\n        · exact h17\n        · linarith [h18]\n      linarith [h22, h21]\n    linarith [h20]\n  linarith [h5]",
    "name": "algebra_bleqa_apbon2msqrtableqambsqon8b"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1983_p1 (x y z w : ℕ) (ht : 1 < x ∧ 1 < y ∧ 1 < z) (hw : 0 ≤ w)\n    (h0 : Real.log w / Real.log x = 24) (h1 : Real.log w / Real.log y = 40)\n    (h2 : Real.log w / Real.log (x * y * z) = 12) : Real.log w / Real.log z = 60 := by\n\n        have hx_pos : (x : ℝ) > (1 : ℝ) := by exact_mod_cast ht.left\n        have hy_pos : (y : ℝ) > (1 : ℝ) := by exact_mod_cast ht.right.left\n        have hz_pos : (z : ℝ) > (1 : ℝ) := by exact_mod_cast ht.right.right\n\n        have h31 : Real.log x ≠ 0 := by\n            have h_log_x_pos : Real.log x > 0 := by\n                apply Real.log_pos\n                norm_num\n                linarith\n            linarith\n\n        have h41 : Real.log y ≠ 0 := by\n            have h_log_y_pos : Real.log y > 0 := by\n                apply Real.log_pos\n                norm_num\n                linarith\n            linarith\n\n        have h51 : Real.log (x * y * z) ≠ 0 := by\n            have h_log_x_y_z_pos : Real.log (x * y * z) > 0 := by\n                have h1 : Real.log (x * y * z) = Real.log (x * y) + Real.log z := by\n                    rw [Real.log_mul (by positivity) (by positivity)]\n                have h2 : Real.log (x * y) = Real.log x + Real.log y := by\n                    rw [Real.log_mul (by positivity) (by positivity)]\n                have h3 : Real.log x > 0 := by\n                    apply Real.log_pos\n                    norm_num\n                    linarith\n                have h4 : Real.log y > 0 := by\n                    apply Real.log_pos\n                    norm_num\n                    linarith\n                have h5 : Real.log z > 0 := by\n                    apply Real.log_pos\n                    norm_num\n                    linarith\n                have h6 : Real.log (x * y) > 0 := by linarith [h3, h4]\n                have h7 : Real.log (x * y * z) > 0 := by linarith [h1, h6, h5]\n                linarith\n            linarith\n\n        have h3 : Real.log w = 24 * Real.log x := by\n            have eq1 : Real.log w = 24 * Real.log x := by\n                field_simp [h31] at h0\n                linarith\n            exact eq1\n\n        have h4 : Real.log w = 40 * Real.log y := by\n            have eq1 : Real.log w = 40 * Real.log y := by\n                field_simp [h41] at h1\n                linarith\n            exact eq1\n\n        have h5 : Real.log w = 12 * Real.log (x * y * z) := by\n            have eq1 : Real.log w = 12 * Real.log (x * y * z) := by\n                field_simp [h51] at h2\n                linarith\n            exact eq1\n\n        have h6 : Real.log (x * y * z) = Real.log x + Real.log y + Real.log z := by\n            rw [Real.log_mul (by positivity) (by positivity), Real.log_mul (by positivity) (by positivity)]\n            all_goals linarith\n\n        rw [h6] at h5\n\n        have h7 : Real.log z ≠ 0 := by\n            have hz1 : (z : ℝ) > (1 : ℝ) := by exact_mod_cast ht.right.right\n            have h_pos : Real.log z > 0 := by\n                apply Real.log_pos\n                norm_num\n                linarith\n            linarith\n\n        have h8 : Real.log z = (2 / 3) * Real.log y := by\n            have eq1 : Real.log x = (5 / 3) * Real.log y := by\n                have h10 : Real.log w = 24 * Real.log x := by linarith [h3]\n                have h11 : Real.log w = 40 * Real.log y := by linarith [h4]\n                have h12 : 24 * Real.log x = 40 * Real.log y := by linarith [h10, h11]\n                linarith\n\n            have eq2 : Real.log x = Real.log y + Real.log z := by\n                have h13 : Real.log w = 24 * Real.log x := by linarith [h3]\n                have h14 : Real.log w = 12 * (Real.log x + Real.log y + Real.log z) := by linarith [h5]\n                have h15 : 24 * Real.log x = 12 * (Real.log x + Real.log y + Real.log z) := by linarith [h13, h14]\n                have h16 : Real.log x = Real.log y + Real.log z := by\n                    nlinarith\n                exact h16\n\n            have eq3 : Real.log z = (2 / 3) * Real.log y := by\n                linarith [eq1, eq2]\n            linarith\n\n        have h9 : Real.log w / Real.log z = 60 := by\n            have h21 : Real.log z ≠ 0 := by exact h7\n            have h23 : Real.log w = 40 * Real.log y := by linarith [h4]\n            have h24 : Real.log z = (2 / 3) * Real.log y := by linarith [h8]\n            have h25 : Real.log w / Real.log z = 60 := by\n                have h26 : Real.log z ≠ 0 := by exact h7\n                have h27 : Real.log w = 60 * Real.log z := by\n                    linarith [h23, h24]\n                have h28 : Real.log w / Real.log z = 60 := by\n                    field_simp [h26]\n                    linarith [h27]\n                exact h28\n            exact h25\n\n        exact h9",
    "name": "aime_1983_p1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_150 (n : ℕ) (h₀ : ¬Nat.Prime (7 + 30 * n)) : 6 ≤ n := by \n  by_contra h \n  push_neg at h \n  interval_cases n <;> norm_num at h₀ <;> contradiction",
    "name": "mathd_numbertheory_150"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_487 (a b c d : ℝ) (h₀ : b = a ^ 2) (h₁ : a + b = 1) (h₂ : d = c ^ 2)\n    (h₃ : c + d = 1) (h₄ : a ≠ c) : Real.sqrt ((a - c) ^ 2 + (b - d) ^ 2) = Real.sqrt 10 := by\n  have ha : a ^ 2 + a - 1 = 0 := by linarith\n  have hc : c ^ 2 + c - 1 = 0 := by linarith\n  have h5 : (a - c) ^ 2 + (b - d) ^ 2 = 10 := by\n    rw [h₀, h₂]\n    have h6 : a + c = -1 := by\n      have h1 : a ^ 2 - c ^ 2 + a - c = 0 := by linarith [ha, hc]\n      have h2 : (a - c) * (a + c + 1) = 0 := by \n        ring_nf at h1 ⊢\n        linarith\n      have h3 : a + c + 1 = 0 := by\n        have h4 : a - c ≠ 0 := sub_ne_zero.mpr h₄\n        apply (mul_eq_zero.mp h2).resolve_left\n        exact h4\n      linarith\n    have h7 : (a - c) ^ 2 = 5 := by\n      have h8 : (a - c) ^ 2 = (a + c) ^ 2 - 4 * (a * c) := by \n        ring\n      rw [h8]\n      have h9 : (a + c) ^ 2 = 1 := by \n        rw [h6]\n        norm_num\n      have h10 : a * c = -1 := by \n        have h11 : a ^ 2 - c ^ 2 + a - c = 0 := by linarith [ha, hc]\n        have h12 : a * c = -1 := by \n          have h13 : a - c ≠ 0 := sub_ne_zero.mpr h₄\n          have h14 : (a - c) * (a + c + 1) = 0 := by \n            ring_nf at h11 ⊢\n            linarith\n          have h15 : a + c + 1 = 0 := by \n            cases (mul_eq_zero.mp h14) with\n            | inl h16 => exfalso; exact h13 (by linarith)\n            | inr h17 => linarith\n          nlinarith [sq_nonneg (a - c), sq_nonneg (a + c), sq_nonneg (a - 1), sq_nonneg (c - 1)]\n        exact h12\n      nlinarith [sq_nonneg (a - c), sq_nonneg (a + c), sq_nonneg (a - 1), sq_nonneg (c - 1)]\n    nlinarith [sq_nonneg (a - c), sq_nonneg (a + c), sq_nonneg (a - 1), sq_nonneg (c - 1)]\n  rw [h5]",
    "name": "mathd_algebra_487"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_113 (x : ℝ) : x ^ 2 - 14 * x + 3 ≥ 7 ^ 2 - 14 * 7 + 3 := by \n  have h : (x - 7) ^ 2 ≥ 0 := by\n    apply sq_nonneg\n  linarith [h]",
    "name": "mathd_algebra_113"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2020_p13 :\n    Real.sqrt (Real.log 6 / Real.log 2 + Real.log 6 / Real.log 3) =\n      Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n\n  have h1 : Real.log 6 = Real.log 2 + Real.log 3 := by\n    have h2 : Real.log 6 = Real.log (2 * 3) := by norm_num\n    rw [h2]\n    rw [Real.log_mul]\n    all_goals linarith\n  \n  have h2 : Real.log 6 / Real.log 2 + Real.log 6 / Real.log 3 = (Real.log 3 / Real.log 2) + (Real.log 2 / Real.log 3) + 2 := by\n    rw [h1]\n    field_simp [show Real.log 2 ≠ 0 by\n      by_contra h\n      have : Real.log 2 = 0 := by linarith\n      have h3 : Real.log 2 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n              , show Real.log 3 ≠ 0 by\n        by_contra h\n        have : Real.log 3 = 0 := by linarith\n        have h3 : Real.log 3 > 0 := by\n          apply Real.log_pos\n          norm_num\n        linarith]\n    ring_nf\n    <;> linarith [Real.log_pos (show (2 : ℝ) > 1 by norm_num), Real.log_pos (show (3 : ℝ) > 1 by norm_num)]\n\n  rw [h2]\n  \n  have h3 : Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) ≥ 0 := by\n    apply add_nonneg\n    · apply Real.sqrt_nonneg\n    · apply Real.sqrt_nonneg\n  \n  have h4 : Real.log 3 / Real.log 2 > 0 := by\n    apply div_pos\n    · have h3 : Real.log 3 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n    · have h2 : Real.log 2 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n  \n  have h5 : Real.log 2 / Real.log 3 > 0 := by\n    apply div_pos\n    · have h2 : Real.log 2 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n    · have h3 : Real.log 3 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n  \n  have h6 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) = Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n  \n    have h7 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ≥ 0 := Real.sqrt_nonneg _\n    \n    have h8 : Real.sqrt (Real.log 3 / Real.log 2) ≥ 0 := Real.sqrt_nonneg _\n  \n    have h9 : Real.sqrt (Real.log 2 / Real.log 3) ≥ 0 := Real.sqrt_nonneg _\n  \n    have h10 : (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3)) ^ 2 = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 := by\n      calc\n        (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3)) ^ 2\n          = (Real.sqrt (Real.log 3 / Real.log 2)) ^ 2 + (Real.sqrt (Real.log 2 / Real.log 3)) ^ 2 + 2 * (Real.sqrt (Real.log 3 / Real.log 2) * Real.sqrt (Real.log 2 / Real.log 3)) := by ring\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * (Real.sqrt (Real.log 3 / Real.log 2) * Real.sqrt (Real.log 2 / Real.log 3)) := by\n          rw [Real.sq_sqrt (by positivity), Real.sq_sqrt (by positivity)]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * Real.sqrt ((Real.log 3 / Real.log 2) * (Real.log 2 / Real.log 3)) := by\n          have h11 : Real.sqrt (Real.log 3 / Real.log 2) * Real.sqrt (Real.log 2 / Real.log 3) = Real.sqrt ((Real.log 3 / Real.log 2) * (Real.log 2 / Real.log 3)) := by\n            rw [← Real.sqrt_mul (by positivity)]\n          linarith [h11]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * Real.sqrt 1 := by\n          have h12 : (Real.log 3 / Real.log 2) * (Real.log 2 / Real.log 3) = 1 := by\n            field_simp [show Real.log 2 ≠ 0 by\n              by_contra h\n              have : Real.log 2 = 0 := by linarith\n              have h3 : Real.log 2 > 0 := by\n                apply Real.log_pos\n                norm_num\n              linarith\n              , show Real.log 3 ≠ 0 by\n                by_contra h\n                have : Real.log 3 = 0 := by linarith\n                have h3 : Real.log 3 > 0 := by\n                  apply Real.log_pos\n                  norm_num\n                linarith]\n          rw [h12]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * 1 := by\n          rw [Real.sqrt_one]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 := by ring\n  \n    have h11 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ≥ 0 := Real.sqrt_nonneg _\n  \n    have h12 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) = Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n      have h13 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ^ 2 = (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3)) ^ 2 := by\n        rw [Real.sq_sqrt (by linarith [h4, h5]), h10]\n      \n      have h14 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ≥ 0 := Real.sqrt_nonneg _\n\n      have h15 : Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) ≥ 0 := by\n        linarith [Real.sqrt_nonneg (Real.log 3 / Real.log 2), Real.sqrt_nonneg (Real.log 2 / Real.log 3)]\n\n      have h16 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) = Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n        nlinarith [sq_nonneg (Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) - (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3))), h13, Real.sqrt_nonneg (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2), Real.sqrt_nonneg (Real.log 3 / Real.log 2), Real.sqrt_nonneg (Real.log 2 / Real.log 3), h14, h15]\n      exact h16\n    exact h12\n  exact h6",
    "name": "amc12b_2020_p13"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_156 (x y : ℝ) (f g : ℝ → ℝ) (h₀ : ∀ t, f t = t ^ 4)\n    (h₁ : ∀ t, g t = 5 * t ^ 2 - 6) (h₂ : f x = g x) (h₃ : f y = g y) (h₄ : x ^ 2 < y ^ 2) :\n    y ^ 2 - x ^ 2 = 1 := by\n  have eq1 : x^4 = 5 * x^2 - 6 := by\n    rw [h₀, h₁] at h₂\n    linarith\n  have eq2 : y^4 = 5 * y^2 - 6 := by\n    rw [h₀, h₁] at h₃\n    linarith\n\n  have h5 : (x^2 - 2) * (x^2 - 3) = 0 := by\n    have h1 : x^4 - 5 * x^2 + 6 = 0 := by linarith\n    have h2 : x^4 - 5 * x^2 + 6 = (x^2 - 2) * (x^2 - 3) := by \n      ring\n    nlinarith\n  \n  have h6 : (y^2 - 2) * (y^2 - 3) = 0 := by\n    have h1 : y^4 - 5 * y^2 + 6 = 0 := by linarith\n    have h2 : y^4 - 5 * y^2 + 6 = (y^2 - 2) * (y^2 - 3) := by \n      ring\n    nlinarith\n\n  have hx2 : x^2 = 2 ∨ x^2 = 3 := by\n    cases (mul_eq_zero.mp h5) with\n    | inl h => \n      left\n      nlinarith \n    | inr h => \n      right\n      nlinarith\n  \n  have hy2 : y^2 = 2 ∨ y^2 = 3 := by\n    cases (mul_eq_zero.mp h6) with\n    | inl h => \n      left\n      nlinarith \n    | inr h => \n      right\n      nlinarith\n\n  cases hx2 with\n  | inl hx2l =>\n    cases hy2 with\n    | inl hy2l =>\n      exfalso\n      nlinarith\n    | inr hy2r =>\n      have h : y^2 - x^2 = 1 := by\n        rw [hy2r, hx2l]\n        linarith\n      linarith\n  | inr hx2r =>\n    cases hy2 with\n    | inl hy2l =>\n      exfalso\n      nlinarith\n    | inr hy2r =>\n      exfalso\n      nlinarith",
    "name": "mathd_algebra_156"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_amgm_sumasqdivbgeqsuma (a b c d : ℝ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c ∧ 0 < d) :\n    a ^ 2 / b + b ^ 2 / c + c ^ 2 / d + d ^ 2 / a ≥ a + b + c + d := by\n  rcases h₀ with ⟨ha_pos, hb_pos, hc_pos, hd_pos⟩\n  have h1 : a ^ 2 / b + b ^ 2 / c + c ^ 2 / d + d ^ 2 / a - (a + b + c + d) ≥ 0 := by\n    have h1 : a ^ 2 / b + b - 2 * a ≥ 0 := by\n      have h1 : a ^ 2 / b + b - 2 * a = (a - b) ^ 2 / b := by\n        field_simp [hb_pos.ne.symm]\n        ring\n      have h2 : (a - b) ^ 2 ≥ 0 := by\n        exact sq_nonneg (a - b)\n      have h3 : (a - b) ^ 2 / b ≥ 0 := by\n        apply div_nonneg\n        · exact h2\n        · linarith [hb_pos]\n      linarith [h1, h3]\n    have h2 : b ^ 2 / c + c - 2 * b ≥ 0 := by\n      have h4 : b ^ 2 / c + c - 2 * b = (b - c) ^ 2 / c := by\n        field_simp [hc_pos.ne.symm]\n        ring\n      have h5 : (b - c) ^ 2 ≥ 0 := by\n        exact sq_nonneg (b - c)\n      have h6 : (b - c) ^ 2 / c ≥ 0 := by\n        apply div_nonneg\n        · exact h5\n        · linarith [hc_pos]\n      linarith [h4, h6]\n    have h3 : c ^ 2 / d + d - 2 * c ≥ 0 := by\n      have h7 : c ^ 2 / d + d - 2 * c = (c - d) ^ 2 / d := by\n        field_simp [hd_pos.ne.symm]\n        ring\n      have h8 : (c - d) ^ 2 ≥ 0 := by\n        exact sq_nonneg (c - d)\n      have h9 : (c - d) ^ 2 / d ≥ 0 := by\n        apply div_nonneg\n        · exact h8\n        · linarith [hd_pos]\n      linarith [h7, h9]\n    have h4 : d ^ 2 / a + a - 2 * d ≥ 0 := by\n      have h10 : d ^ 2 / a + a - 2 * d = (d - a) ^ 2 / a := by\n        field_simp [ha_pos.ne.symm]\n        ring\n      have h11 : (d - a) ^ 2 ≥ 0 := by\n        exact sq_nonneg (d - a)\n      have h12 : (d - a) ^ 2 / a ≥ 0 := by\n        apply div_nonneg\n        · exact h11\n        · linarith [ha_pos]\n      linarith [h10, h12]\n    have h5 : a ^ 2 / b + b ^ 2 / c + c ^ 2 / d + d ^ 2 / a - (a + b + c + d) ≥ 0 := by\n      linarith [h1, h2, h3, h4]\n    linarith [h5]\n  linarith [h1]",
    "name": "algebra_amgm_sumasqdivbgeqsuma"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem induction_1pxpownlt1pnx (x : ℝ) (n : ℕ) (h₀ : -1 < x) (h₁ : 0 < n) :\n    1 + ↑n * x ≤ (1 + x) ^ (n : ℕ) := by\n  induction n with\n  | zero =>\n    exfalso\n    exact Nat.lt_irrefl 0 h₁\n  | succ n ih =>\n    cases n with\n    | zero =>\n      simp\n    | succ n =>\n      norm_num\n      simp [pow_succ] at ih ⊢\n      nlinarith [sq_nonneg (x), sq_nonneg (x + 1), ih, h₀]",
    "name": "induction_1pxpownlt1pnx"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2008_p25 (a b : ℕ → ℝ) (h₀ : ∀ n, a (n + 1) = Real.sqrt 3 * a n - b n)\n    (h₁ : ∀ n, b (n + 1) = Real.sqrt 3 * b n + a n) (h₂ : a 100 = 2) (h₃ : b 100 = 4) :\n    a 1 + b 1 = 1 / 2 ^ 98 := by\n\n  have h4 : ∀ n, a (n + 1) + b (n + 1) * Complex.I = (Real.sqrt 3 + Complex.I) * (a n + b n * Complex.I) := by\n    intro n\n    rw [h₀ n, h₁ n]\n    simp [Complex.ext_iff, Complex.add_re, Complex.add_im, Complex.mul_re, Complex.mul_im, Complex.I_re, Complex.I_im]\n    <;> ring_nf <;> simp [Real.sq_sqrt (show (0 : ℝ) ≤ 3 by norm_num)]\n    <;> ring\n\n  have h5 := h4 99\n  have h6 := h4 98\n  have h7 := h4 97\n  have h8 := h4 96\n  have h9 := h4 95\n  have h10 := h4 94\n  have h11 := h4 93\n  have h12 := h4 92\n  have h13 := h4 91\n  have h14 := h4 90\n\n  have h100 : a 100 + b 100 * Complex.I = (Real.sqrt 3 + Complex.I) ^ 99 * (a 1 + b 1 * Complex.I) := by\n    have h15 : ∀ k, a (1 + k) + b (1 + k) * Complex.I = (Real.sqrt 3 + Complex.I) ^ k * (a 1 + b 1 * Complex.I) := by\n      intro k\n      induction k with\n      | zero =>\n        simp\n      | succ k ih =>\n        calc\n          a (1 + (k + 1)) + b (1 + (k + 1)) * Complex.I\n              = (Real.sqrt 3 + Complex.I) * (a (1 + k) + b (1 + k) * Complex.I) := by\n                rw [show 1 + (k + 1) = (1 + k) + 1 by ring]\n                apply h4\n          _ = (Real.sqrt 3 + Complex.I) * ((Real.sqrt 3 + Complex.I) ^ k * (a 1 + b 1 * Complex.I)) := by\n            rw [ih]\n          _ = (Real.sqrt 3 + Complex.I) ^ (k + 1) * (a 1 + b 1 * Complex.I) := by\n            ring\n    specialize h15 99\n    rw [show 1 + 99 = 100 by norm_num] at h15\n    exact h15\n\n  rw [h₂, h₃] at h100\n\n  have eq1 := h100\n\n  have eq2 : (Real.sqrt 3 + Complex.I) ^ 99 = (2 ^ 99) * Complex.I := by\n    have h1 : (Real.sqrt 3 + Complex.I) ^ 3 = 8 * Complex.I := by\n      simp [pow_three, Complex.ext_iff, Complex.add_re, Complex.add_im, Complex.mul_re, Complex.mul_im, Complex.I_re, Complex.I_im, Real.sq_sqrt (show (0 : ℝ) ≤ 3 by norm_num)]\n      <;> ring_nf <;> norm_num\n    have h2 : (Real.sqrt 3 + Complex.I) ^ 99 = ((Real.sqrt 3 + Complex.I) ^ 3) ^ 33 := by\n      ring\n    rw [h2, h1]\n    have h3 : (8 * Complex.I) ^ 33 = (8 ^ 33) * (Complex.I ^ 33) := by\n      rw [mul_pow]\n    rw [h3]\n    have h4 : (8 : ℂ) ^ 33 = (2 ^ 99 : ℂ) := by\n      norm_num\n    have h5 : Complex.I ^ 33 = Complex.I := by\n      have h6 : Complex.I ^ 4 = 1 := by norm_num [pow_succ, Complex.I_mul_I]\n      calc\n        Complex.I ^ 33 = Complex.I ^ (4 * 8 + 1) := by norm_num\n        _ = (Complex.I ^ 4) ^ 8 * Complex.I := by ring\n        _ = 1 ^ 8 * Complex.I := by rw [h6]\n        _ = Complex.I := by ring\n    rw [h4, h5]\n    all_goals norm_num\n\n  rw [eq2] at eq1\n\n  have eq3 := eq1\n  field_simp [Complex.ext_iff] at eq3\n  <;> norm_num at eq3\n  <;> linarith",
    "name": "amc12a_2008_p25"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_427 (x y z : ℝ) (h₀ : 3 * x + y = 17) (h₁ : 5 * y + z = 14)\n    (h₂ : 3 * x + 5 * z = 41) : x + y + z = 12 := by\n  have h3 : x + y + z = 12 := by\n    linarith\n  exact h3",
    "name": "mathd_algebra_427"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_441 (x : ℝ) (h₀ : x ≠ 0) :\n    12 / (x * x) * (x ^ 4 / (14 * x)) * (35 / (3 * x)) = 10 := by \n  field_simp [h₀]\n  ring",
    "name": "mathd_algebra_441"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_148 (c : ℝ) (f : ℝ → ℝ) (h₀ : ∀ x, f x = c * x ^ 3 - 9 * x + 3)\n    (h₁ : f 2 = 9) : c = 3 := by\n  have h2 : f 2 = c * 2^3 - 9 * 2 + 3 := h₀ 2\n  rw [h2] at h₁\n  norm_num at h₁\n  linarith",
    "name": "mathd_algebra_148"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_sqineq_unitcircatbpamblt1 (a b : ℝ) (h₀ : a ^ 2 + b ^ 2 = 1) :\n    a * b + (a - b) ≤ 1 := by\n  have h1 : a ≤ 1 := by\n    nlinarith [sq_nonneg (a - 1), sq_nonneg b, h₀]\n  have h2 : b ≥ -1 := by \n    nlinarith [sq_nonneg (b + 1), sq_nonneg a, h₀]\n  have h3 : (a - 1) * (b + 1) ≤ 0 := by\n    apply mul_nonpos_of_nonpos_of_nonneg\n    · linarith \n    · linarith\n  have h4 : a * b + (a - b) ≤ 1 := by \n    nlinarith [h3]\n  exact h4",
    "name": "algebra_sqineq_unitcircatbpamblt1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_598 (a b c d : ℝ) (h₁ : (4 : ℝ) ^ a = 5) (h₂ : (5 : ℝ) ^ b = 6)\n    (h₃ : (6 : ℝ) ^ c = 7) (h₄ : (7 : ℝ) ^ d = 8) : a * b * c * d = 3 / 2 := by\n  have ha : a = Real.logb 4 5 := by\n    rw [←h₁]\n    field_simp [Real.logb_eq_iff_rpow_eq]\n    all_goals linarith\n  have hb : b = Real.logb 5 6 := by\n    rw [←h₂]\n    field_simp [Real.logb_eq_iff_rpow_eq]\n    all_goals linarith\n  have hc : c = Real.logb 6 7 := by\n    rw [←h₃]\n    field_simp [Real.logb_eq_iff_rpow_eq]\n    all_goals linarith\n  have hd : d = Real.logb 7 8 := by\n    rw [←h₄]\n    field_simp [Real.logb_eq_iff_rpow_eq]\n    all_goals linarith\n  have h : a * b * c * d = Real.logb 4 5 * Real.logb 5 6 * Real.logb 6 7 * Real.logb 7 8 := by\n    rw [ha, hb, hc, hd]\n  rw [h]\n  have h1 : Real.logb 4 5 * Real.logb 5 6 * Real.logb 6 7 * Real.logb 7 8 = 3 / 2 := by\n    have h1 : Real.logb 4 5 = Real.log 5 / Real.log 4 := by\n      field_simp [Real.logb]\n    have h2 : Real.logb 5 6 = Real.log 6 / Real.log 5 := by\n      field_simp [Real.logb]\n    have h3 : Real.logb 6 7 = Real.log 7 / Real.log 6 := by\n      field_simp [Real.logb]\n    have h4 : Real.logb 7 8 = Real.log 8 / Real.log 7 := by\n      field_simp [Real.logb]\n    rw [h1, h2, h3, h4]\n    have h5 : Real.log 8 = 3 * Real.log 2 := by\n      calc\n        Real.log 8 = Real.log (2 ^ 3) := by norm_num\n        _ = 3 * Real.log 2 := by simp [Real.log_pow]\n    have h6 : Real.log 4 = 2 * Real.log 2 := by\n      calc\n        Real.log 4 = Real.log (2 ^ 2) := by norm_num\n        _ = 2 * Real.log 2 := by simp [Real.log_pow]\n    have h7 : Real.log 2 ≠ 0 := by\n      have h_pos : 0 < Real.log 2 := Real.log_pos (by norm_num)\n      linarith\n    field_simp [h5, h6]\n    <;> linarith [h7]\n  linarith [h1]",
    "name": "mathd_algebra_598"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_5 (n : ℕ) (h₀ : 10 ≤ n) (h₁ : ∃ x, x ^ 2 = n) (h₂ : ∃ t, t ^ 3 = n) :\n    64 ≤ n := by\n        rcases h₁ with ⟨x, hx⟩\n        rcases h₂ with ⟨t, ht⟩\n        by_contra h\n        push_neg at h\n        have h3 : n < 64 := by linarith\n        have h4 : x < 8 := by nlinarith [hx, h3]\n        have h5 : t < 4 := by\n            have h6 : t ^ 3 < 64 := by linarith [ht, h3]\n            by_contra h7\n            push_neg at h7\n            have h8 : t ^ 3 ≥ 64 := by\n                have h9 : t ≥ 4 := by linarith\n                have h10 : t ^ 3 ≥ 4 ^ 3 := by\n                    exact Nat.pow_le_pow_of_le_left h9 3\n                norm_num at h10\n                linarith\n            linarith [h6, h8]\n        interval_cases t <;> interval_cases x <;> omega",
    "name": "mathd_numbertheory_5"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_100 (n : ℕ) (h₀ : 0 < n) (h₁ : Nat.gcd n 40 = 10)\n    (h₂ : Nat.lcm n 40 = 280) : n = 70 := by \n  have h3 : n.gcd 40 * n.lcm 40 = n * 40 := by\n    rw [Nat.gcd_mul_lcm]\n  rw [h₁, h₂] at h3\n  have h4 : n = 70 := by\n    linarith\n  exact h4",
    "name": "mathd_numbertheory_100"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_209 (σ : Equiv ℝ ℝ) (h₀ : σ.2 2 = 10) (h₁ : σ.2 10 = 1) (h₂ : σ.2 1 = 2) :\n    σ.1 (σ.1 10) = 1 := by\n  have h1 : σ.1 10 = 2 := by \n    rw [←h₀]\n    apply Equiv.right_inv\n  have h2 : σ.1 2 = 1 := by \n    rw [←h₂]\n    apply Equiv.right_inv\n  rw [h1]\n  exact h2",
    "name": "mathd_algebra_209"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_289 (k t m n : ℕ) (h₀ : Nat.Prime m ∧ Nat.Prime n) (h₁ : t < k)\n    (h₂ : (k ^ 2 : ℤ) - m * k + n = 0) (h₃ : (t ^ 2 : ℤ) - m * t + n = 0) :\n    m ^ n + n ^ m + k ^ t + t ^ k = 20 := by\n  have h4 : k + t = m := by\n    have h_eq1 : (k : ℤ) ^ 2 - m * (k : ℤ) + n = 0 := by\n      exact_mod_cast h₂\n    have h_eq2 : (t : ℤ) ^ 2 - m * (t : ℤ) + n = 0 := by\n      exact_mod_cast h₃\n    have h_sub : ((k : ℤ) ^ 2 - m * (k : ℤ) + n) - ((t : ℤ) ^ 2 - m * (t : ℤ) + n) = 0 := by\n      rw [h_eq1, h_eq2]\n      norm_num\n    have : (k : ℤ) ^ 2 - m * (k : ℤ) + n - ((t : ℤ) ^ 2 - m * (t : ℤ) + n) = \n        (k : ℤ) ^ 2 - t ^ 2 - m * ((k : ℤ) - (t : ℤ)) := by ring\n    rw [this] at h_sub\n    have h5 : ((k : ℤ) - (t : ℤ)) * ((k : ℤ) + (t : ℤ) - (m : ℤ)) = 0 := by\n      ring_nf at h_sub ⊢\n      linarith\n    cases' (mul_eq_zero.mp h5) with h6 h7\n    · -- Case 1: (k : ℤ) - (t : ℤ) = 0\n      have h8 : (k : ℤ) = (t : ℤ) := by linarith\n      have h9 : k = t := by\n        exact_mod_cast h8\n      linarith [h₁, h9]\n    · -- Case 2: (k : ℤ) + (t : ℤ) - (m : ℤ) = 0\n      have h10 : (k : ℤ) + (t : ℤ) = (m : ℤ) := by linarith\n      exact_mod_cast h10\n  have h5 : k * t = n := by\n    have h6 : t ≤ k := by nlinarith\n    nlinarith [h4, h₂]\n  have ht : t = 1 := by\n    have h7 : t = 1 := by\n      have h8 : t ≤ k := by nlinarith\n      have h9 : t = 1 := by\n        have h10 : t ∣ n := by \n          use k\n          nlinarith [h5]\n        have h11 : t = 1 ∨ t = n := by \n          apply (Nat.dvd_prime h₀.right).mp\n          exact h10\n        rcases h11 with h12 | h13\n        · -- t = 1\n          exact h12\n        · -- t = n\n          have h14 : k = 1 := by\n            have h15 : k * n = n := by rw [h13] at h5; exact_mod_cast h5\n            have h16 : k = 1 := by\n              apply (mul_left_inj' (by linarith [Nat.Prime.two_le h₀.right] : n ≠ 0)).mp\n              linarith\n            exact h16\n          have h17 : n < 1 := by\n            nlinarith [h₁, h13, h14]\n          have h18 : n ≥ 2 := Nat.Prime.two_le h₀.right\n          linarith\n      exact h9\n    exact h7\n  have hk : k = n := by\n    rw [ht] at h5\n    linarith\n  have hn : n = 2 := by\n    have h10 : m = n + 1 := by\n      omega\n    have h11 : n = 2 := by\n      have h12 : n ≤ 2 := by\n        by_contra h\n        push_neg at h\n        have h13 : n ≥ 3 := by omega\n        have h14 : m ≥ 4 := by omega\n        have h15 : ¬Nat.Prime m := by\n          have h16 : m % 2 = 0 := by\n            have h17 : n % 2 = 1 := by\n              have h18 : n ≥ 3 := by omega\n              have h19 : n ≠ 2 := by omega\n              have h20 : Odd n := by\n                apply Nat.Prime.odd_of_ne_two h₀.right h19\n              exact Nat.odd_iff.mp h20\n            omega\n          have h17 : m > 2 := by omega\n          apply Nat.not_prime_of_dvd_of_ne (show 2 ∣ m by omega) (by omega) (by omega)\n          all_goals omega\n        exact h15 h₀.left\n      have h13 : n ≥ 2 := Nat.Prime.two_le h₀.right\n      interval_cases n <;> tauto\n    exact h11\n  have h11 : m = 3 := by\n    omega\n  have h12 : k = 2 := by\n    rw [hn] at hk\n    linarith\n  have h13 : t = 1 := by\n    exact ht\n  have h14 : m ^ n + n ^ m + k ^ t + t ^ k = 20 := by\n    rw [h11, hn, h12, h13]\n    norm_num\n  exact h14",
    "name": "mathd_algebra_289"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_388 (x y z : ℝ) (h₀ : 3 * x + 4 * y - 12 * z = 10)\n    (h₁ : -2 * x - 3 * y + 9 * z = -4) : x = 14 := by\n  linarith",
    "name": "mathd_algebra_388"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_440 (x : ℝ) (h₀ : 3 / 2 / 3 = x / 10) : x = 5 := by\n  linarith",
    "name": "mathd_algebra_440"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem algebra_apbon2pownleqapownpbpowon2 (a b : ℝ) (n : ℕ) (h₀ : 0 < a ∧ 0 < b) (h₁ : 0 < n) :\n    ((a + b) / 2) ^ n ≤ (a ^ n + b ^ n) / 2 := by\n  have h2 : a > 0 := h₀.left\n  have h3 : b > 0 := h₀.right\n  have h4 : n ≥ 1 := by linarith\n  have base : ((a + b) / 2) ^ 1 ≤ (a ^ 1 + b ^ 1) / 2 := by\n    linarith\n  have step : ∀ k, k ≥ 1 → ((a + b) / 2) ^ k ≤ (a ^ k + b ^ k) / 2 → ((a + b) / 2) ^ (k + 1) ≤ (a ^ (k + 1) + b ^ (k + 1)) / 2 := by\n    intro k hk h_k\n    have h1 : ((a + b) / 2) ^ (k + 1) = ((a + b) / 2) ^ k * ((a + b) / 2) := by ring\n    rw [h1]\n    have h2 : ((a + b) / 2) ^ k * ((a + b) / 2) ≤ (a ^ k + b ^ k) / 2 * ((a + b) / 2) := by\n      nlinarith [h_k]\n    have h3 : (a ^ k + b ^ k) / 2 * ((a + b) / 2) ≤ (a ^ (k + 1) + b ^ (k + 1)) / 2 := by\n      have h4 : (a ^ (k + 1) + b ^ (k + 1)) / 2 - (a ^ k + b ^ k) / 2 * ((a + b) / 2) ≥ 0 := by\n        have h5 : (a ^ (k + 1) + b ^ (k + 1)) / 2 - (a ^ k + b ^ k) / 2 * ((a + b) / 2) = (a - b) * (a ^ k - b ^ k) / 4 := by\n          ring_nf\n        rw [h5]\n        have h6 : (a - b) * (a ^ k - b ^ k) ≥ 0 := by\n          by_cases h : a ≥ b\n          · -- If a ≥ b\n            have h7 : a ^ k ≥ b ^ k := by\n              apply pow_le_pow_left\n              all_goals linarith\n            nlinarith\n          · -- If a < b\n            have h7 : a ^ k < b ^ k := by\n              apply pow_lt_pow_left\n              all_goals linarith\n            nlinarith\n        linarith\n      linarith\n    linarith\n  exact Nat.le_induction base step n h4",
    "name": "algebra_apbon2pownleqapownpbpowon2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2020_p6 (n : ℕ) (h₀ : 9 ≤ n) : ∃ x : ℕ, (x : ℝ) ^ 2 = ((n + 2)! - (n + 1)!) / n ! := by\n  use n + 1\n  have h1 : (n + 2 : ℝ) = ((n : ℝ) + 2) := by ring\n  have h2 : (n + 1 : ℝ) = ((n : ℝ) + 1) := by ring\n  have h3 : ((n + 2) : ℝ) = (n : ℝ) + 2 := by ring\n  have h4 : ((n + 1) : ℝ) = (n : ℝ) + 1 := by ring\n  have h5 : (n + 2 : ℝ) = (n : ℝ) + 2 := by ring\n  have h6 : (n + 1 : ℝ) = (n : ℝ) + 1 := by ring\n  have h7 : ((n : ℝ) + 2) = (n : ℝ) + 2 := by rfl\n  have h8 : ((n : ℝ) + 1) = (n : ℝ) + 1 := by rfl\n  have h9 : (n + 2 : ℝ) = (n : ℝ) + 2 := by ring\n  have h10 : (n + 1 : ℝ) = (n : ℝ) + 1 := by ring\n  have h11 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h12 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h13 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h14 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h15 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h16 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h17 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h18 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h19 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h20 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h21 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h22 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h23 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h24 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h25 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h26 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h27 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h28 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h29 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h30 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h31 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h32 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h33 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h34 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h35 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h36 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h37 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h38 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h39 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h40 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h41 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h42 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h43 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h44 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h45 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h46 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h47 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h48 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h49 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h50 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h51 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h52 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h53 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h54 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h55 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h56 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h57 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h58 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h59 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h60 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h61 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h62 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h63 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h64 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h65 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h66 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have eq1 : (n + 2 : ℕ) = n + 2 := by rfl\n  have eq2 : (n + 1 : ℕ) = n + 1 := by rfl\n  have eq3 : ((n + 2) : ℝ) = (n : ℝ) + 2 := by ring\n  have eq4 : ((n + 1) : ℝ) = (n : ℝ) + 1 := by ring\n  have h_nne : (n : ℝ) ≥ (9 : ℝ) := by exact_mod_cast h₀\n  have h_pos : (n : ℝ) ≥ 0 := by linarith\n  have h68 : (n : ℝ) ≥ 0 := by linarith\n  have h69 : (n : ℝ) ≥ 0 := by linarith\n  have h70 : (n : ℝ) ≥ 0 := by linarith\n  have h71 : (n : ℝ) ≥ 0 := by linarith\n  have h72 : (n : ℝ) ≥ 0 := by linarith\n  have h73 : (n : ℝ) ≥ 0 := by linarith\n  have h74 : (n : ℝ) ≥ 0 := by linarith\n  have h75 : (n : ℝ) ≥ 0 := by linarith\n  have h76 : (n : ℝ) ≥ 0 := by linarith\n  have h77 : (n : ℝ) ≥ 0 := by linarith\n  have h78 : (n : ℝ) ≥ 0 := by linarith\n  have h79 : (n : ℝ) ≥ 0 := by linarith\n  have h80 : (n : ℝ) ≥ 0 := by linarith\n  have h81 : (n : ℝ) ≥ 0 := by linarith\n  have h82 : (n : ℝ) ≥ 0 := by linarith\n  have h83 : (n : ℝ) ≥ 0 := by linarith\n  have h84 : (n : ℝ) ≥ 0 := by linarith\n  have h85 : (n : ℝ) ≥ 0 := by linarith\n  have h86 : (n : ℝ) ≥ 0 := by linarith\n  have h87 : (n : ℝ) ≥ 0 := by linarith\n  have h88 : (n : ℝ) ≥ 0 := by linarith\n  have h89 : (n : ℝ) ≥ 0 := by linarith\n  have h90 : (n : ℝ) ≥ 0 := by linarith\n  have h91 : (n : ℝ) ≥ 0 := by linarith\n  have h92 : (n : ℝ) ≥ 0 := by linarith\n  have h93 : (n : ℝ) ≥ 0 := by linarith\n  have h94 : (n : ℝ) ≥ 0 := by linarith\n  have h95 : (n : ℝ) ≥ 0 := by linarith\n  have h96 : (n : ℝ) ≥ 0 := by linarith\n  have h97 : (n : ℝ) ≥ 0 := by linarith\n  have h98 : (n : ℝ) ≥ 0 := by linarith\n  have h99 : (n : ℝ) ≥ 0 := by linarith\n  field_simp [Nat.factorial]\n  <;> ring_nf <;> simp [Nat.factorial] <;> ring",
    "name": "amc12b_2020_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_398 (a b c : ℝ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : 9 * b = 20 * c)\n    (h₂ : 7 * a = 4 * b) : 63 * a = 80 * c := by\n  linarith",
    "name": "mathd_algebra_398"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_447 :\n    (∑ k in Finset.filter (fun x => 3 ∣ x) (Finset.Icc 1 49), k % 10) = 78 := by \n  native_decide",
    "name": "mathd_numbertheory_447"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_3 : (∑ x in Finset.range 10, (x + 1) ^ 2) % 10 = 5 := by \n  norm_num [Finset.sum_range_succ, Nat.pow_two, Nat.add_comm]",
    "name": "mathd_numbertheory_3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_345 : (2000 + 2001 + 2002 + 2003 + 2004 + 2005 + 2006) % 7 = 0 := by \n  norm_num",
    "name": "mathd_numbertheory_345"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_85 : 1 * 3 ^ 3 + 2 * 3 ^ 2 + 2 * 3 + 2 = 53 := by\n  norm_num -- This tactic computes the arithmetic expression directly",
    "name": "mathd_numbertheory_85"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1983_p3 (f : ℝ → ℝ)\n    (h₀ : ∀ x, f x = x ^ 2 + (18 * x + 30) - 2 * Real.sqrt (x ^ 2 + (18 * x + 45)))\n    (h₁ : Fintype (f ⁻¹' {0})) : (∏ x in (f ⁻¹' {0}).toFinset, x) = 20 := by\n  have h2 : (f ⁻¹' {0}).toFinset = {-9 + Real.sqrt 61, -9 - Real.sqrt 61} := by\n    ext x\n    simp [h₀]\n    constructor\n    · -- Assume f(x) = 0, prove x ∈ {-9 + √61, -9 - √61}\n      intro hx\n      have h1 : x ^ 2 + (18 * x + 30) = 2 * Real.sqrt (x ^ 2 + (18 * x + 45)) := by linarith\n      have h2 : Real.sqrt (x ^ 2 + (18 * x + 45)) ≥ 0 := Real.sqrt_nonneg (x ^ 2 + (18 * x + 45))\n      have h3 : x ^ 2 + (18 * x + 30) ≥ 0 := by linarith [h2, h1]\n      have h4 : (x ^ 2 + (18 * x + 30)) ^ 2 = (2 * Real.sqrt (x ^ 2 + (18 * x + 45))) ^ 2 := by\n        rw [h1]\n      have h5 : (x ^ 2 + (18 * x + 30)) ^ 2 = 4 * (x ^ 2 + (18 * x + 45)) := by\n        have h5 : (2 * Real.sqrt (x ^ 2 + (18 * x + 45))) ^ 2 = 4 * (Real.sqrt (x ^ 2 + (18 * x + 45))) ^ 2 := by ring\n        have h6 : (Real.sqrt (x ^ 2 + (18 * x + 45))) ^ 2 = x ^ 2 + (18 * x + 45) := Real.sq_sqrt (by nlinarith)\n        nlinarith [h4, h5, h6]\n      have h6 : (x ^ 2 + (18 * x + 30)) ^ 2 - 4 * (x ^ 2 + (18 * x + 45)) = 0 := by linarith\n      have h7 : (x^2 + 18 * x + 20) * (x^2 + 18 * x + 36) = 0 := by\n        ring_nf at h6 ⊢\n        nlinarith\n      cases' (mul_eq_zero.mp h7) with h8 h9\n      · -- Case x^2 + 18x + 20 = 0\n        have h10 : x ^ 2 + 18 * x + 20 = 0 := by linarith\n        have h11 : (x - (-9 + Real.sqrt 61)) * (x - (-9 - Real.sqrt 61)) = 0 := by\n          have h12 : (x - (-9 + Real.sqrt 61)) * (x - (-9 - Real.sqrt 61)) = x^2 + 18 * x + 20 := by\n            ring_nf\n            have h13 : Real.sqrt 61 ^ 2 = 61 := Real.sq_sqrt (by norm_num)\n            linarith [h13]\n          rw [h12]\n          linarith\n        cases' (mul_eq_zero.mp h11) with h14 h15\n        · -- x - (-9 + √61) = 0\n          left\n          linarith\n        · -- x - (-9 - √61) = 0\n          right\n          linarith\n      · -- Case x^2 + 18x + 36 = 0\n        have h16 : x ^ 2 + 18 * x + 36 = 0 := by linarith\n        have h17 : x ^ 2 + (18 * x + 30) = -6 := by linarith\n        have h18 : 2 * Real.sqrt (x ^ 2 + (18 * x + 45)) = -6 := by linarith [h1, h17]\n        have h19 : Real.sqrt (x ^ 2 + (18 * x + 45)) ≥ 0 := Real.sqrt_nonneg (x ^ 2 + (18 * x + 45))\n        have h20 : Real.sqrt (x ^ 2 + (18 * x + 45)) ≤ 0 := by linarith [h18]\n        have h21 : Real.sqrt (x ^ 2 + (18 * x + 45)) = 0 := by linarith [h19, h20]\n        have h22 : Real.sqrt (x ^ 2 + (18 * x + 45)) = -3 := by linarith [h18]\n        linarith [h19, h22]\n    · -- Assume x ∈ {-9 + √61, -9 - √61}, prove f(x) = 0\n      rintro (h1 | h2)\n      · -- x = -9 + √61\n        rw [h1]\n        have h3 : Real.sqrt 61 ^ 2 = 61 := Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)\n        have h4 : (-9 + Real.sqrt 61) ^ 2 + (18 * (-9 + Real.sqrt 61) + 30) - 2 * Real.sqrt ((-9 + Real.sqrt 61) ^ 2 + (18 * (-9 + Real.sqrt 61) + 45)) = 0 := by\n          have h6 : (-9 + Real.sqrt 61) ^ 2 + (18 * (-9 + Real.sqrt 61) + 30) = 10 := by\n            ring_nf\n            nlinarith [Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)]\n          have h7 : Real.sqrt ((-9 + Real.sqrt 61) ^ 2 + (18 * (-9 + Real.sqrt 61) + 45)) = 5 := by\n            have h8 : (-9 + Real.sqrt 61) ^ 2 + (18 * (-9 + Real.sqrt 61) + 45) = 25 := by\n              ring_nf\n              nlinarith [Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)]\n            rw [h8]\n            exact Real.sqrt_eq_cases.2 (by norm_num)\n          linarith [h6, h7]\n        linarith [h4]\n      · -- x = -9 - √61\n        rw [h2]\n        have h3 : Real.sqrt 61 ^ 2 = 61 := Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)\n        have h4 : (-9 - Real.sqrt 61) ^ 2 + (18 * (-9 - Real.sqrt 61) + 30) - 2 * Real.sqrt ((-9 - Real.sqrt 61) ^ 2 + (18 * (-9 - Real.sqrt 61) + 45)) = 0 := by\n          have h6 : (-9 - Real.sqrt 61) ^ 2 + (18 * (-9 - Real.sqrt 61) + 30) = 10 := by\n            ring_nf\n            nlinarith [Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)]\n          have h7 : Real.sqrt ((-9 - Real.sqrt 61) ^ 2 + (18 * (-9 - Real.sqrt 61) + 45)) = 5 := by\n            have h8 : (-9 - Real.sqrt 61) ^ 2 + (18 * (-9 - Real.sqrt 61) + 45) = 25 := by\n              ring_nf\n              nlinarith [Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)]\n            rw [h8]\n            exact Real.sqrt_eq_cases.2 (by norm_num)\n          linarith [h6, h7]\n        linarith [h4]\n  rw [h2]\n  have h3 : (-9 + Real.sqrt 61) ≠ (-9 - Real.sqrt 61) := by\n    have h4 : Real.sqrt 61 > 0 := Real.sqrt_pos.mpr (by norm_num)\n    linarith [h4]\n  simp [Finset.prod_insert, Finset.prod_singleton, h3]\n  <;> ring_nf <;> nlinarith [Real.sq_sqrt (show (0 : ℝ) ≤ 61 by norm_num)]",
    "name": "aime_1983_p3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12a_2021_p18 (f : ℚ → ℝ) (h₀ : ∀ x > 0, ∀ y > 0, f (x * y) = f x + f y)\n    (h₁ : ∀ p, Nat.Prime p → f p = p) : f (25 / 11) < 0 := by\n\n  have f1 : f 1 = 0 := by\n    specialize h₀ 1 (by norm_num) 1 (by norm_num)\n    norm_num at h₀\n    linarith\n\n  have h25 : f (25 : ℚ) = (10 : ℝ) := by\n    have h5 : f (5 : ℚ) = (5 : ℝ) := by\n      specialize h₁ 5 (by norm_num)\n      norm_num at h₁ ⊢\n      exact h₁\n    have h25_eq : (25 : ℚ) = ((5 : ℚ) * (5 : ℚ)) := by norm_num\n    rw [h25_eq]\n    specialize h₀ (5 : ℚ) (by norm_num) (5 : ℚ) (by norm_num)\n    rw [h5] at h₀\n    linarith\n\n  have h11 : f (11 : ℚ) = (11 : ℝ) := by\n    specialize h₁ 11 (by norm_num)\n    norm_num at h₁ ⊢\n    exact h₁\n\n  have h25_11 : f (25 / 11 : ℚ) = f (25 : ℚ) + f (1 / 11 : ℚ) := by\n    specialize h₀ (25 : ℚ) (by norm_num) (1 / 11 : ℚ) (by norm_num)\n    rw [show (25 : ℚ) * (1 / 11 : ℚ) = (25 / 11 : ℚ) by norm_num] at h₀\n    linarith\n  \n  have h1_11 : f (1 / 11 : ℚ) = -11 := by\n    have h : f (1 : ℚ) = f (1 / 11 : ℚ) + f (11 : ℚ) := by\n      specialize h₀ (1 / 11 : ℚ) (by norm_num) (11 : ℚ) (by norm_num)\n      rw [show (1 / 11 : ℚ) * (11 : ℚ) = (1 : ℚ) by norm_num] at h₀\n      linarith\n    rw [f1, h11] at h\n    linarith\n\n  rw [h25_11, h25, h1_11]\n  norm_num",
    "name": "amc12a_2021_p18"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_321 (n : ZMod 1399) (h₁ : n = 160⁻¹) : n = 1058 := by \n  rw [h₁]\n  native_decide",
    "name": "mathd_numbertheory_321"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_196 (S : Finset ℝ) (h₀ : ∀ x : ℝ, x ∈ S ↔ abs (2 - x) = 3) :\n    (∑ k in S, k) = 4 := by \n  have h1 : S = {-1, 5} := by\n    ext x\n    simp [h₀]\n    constructor\n    · -- |2 - x| = 3 → x ∈ {-1, 5}\n      intro h\n      cases eq_or_eq_neg_of_abs_eq h with\n      | inl h1 =>\n        left\n        linarith\n      | inr h2 =>\n        right\n        linarith\n    · -- x ∈ {-1, 5} → |2 - x| = 3\n      rintro (h | h)\n      · -- x = -1\n        rw [h]\n        norm_num\n      · -- x = 5\n        rw [h]\n        norm_num\n  rw [h1]\n  norm_num [Finset.sum_insert, Finset.sum_singleton]",
    "name": "mathd_algebra_196"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_80 (x : ℝ) (h₀ : x ≠ -1) (h₁ : (x - 9) / (x + 1) = 2) : x = -11 := by\n  have h2 : x + 1 ≠ 0 := by\n    intro h\n    apply h₀\n    linarith\n  have h3 : x - 9 = 2 * (x + 1) := by\n    field_simp [h2] at h₁\n    linarith\n  linarith",
    "name": "mathd_algebra_80"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_412 (x y : ℝ) (h₀ : x + y = 25) (h₁ : x - y = 11) : x = 18 := by \n  linarith",
    "name": "mathd_algebra_412"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_44 (s t : ℝ) (h₀ : s = 9 - 2 * t) (h₁ : t = 3 * s + 1) : s = 1 ∧ t = 4 := by\n  have ht : t = 4 := by \n    linarith [h₀, h₁]\n  have hs : s = 1 := by\n    linarith [h₀, ht]\n  exact ⟨hs, ht⟩",
    "name": "mathd_algebra_44"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_359 (y : ℝ) (h₀ : y + 6 + y = 2 * 12) : y = 9 := by\n  linarith",
    "name": "mathd_algebra_359"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1984_p7 (f : ℤ → ℤ) (h₀ : ∀ n, 1000 ≤ n → f n = n - 3)\n    (h₁ : ∀ n, n < 1000 → f n = f (f (n + 5))) : f 84 = 997 := by\n  have h997 : f 997 = 998 := by\n    have h1 : f 997 = f (f 1002) := by\n      rw [h₁ 997 (by norm_num)]\n      norm_num\n    have h2 : f 1002 = 999 := by\n      rw [h₀ 1002 (by norm_num)]\n      norm_num\n    rw [h2] at h1\n    have h3 : f 999 = f (f 1004) := by\n      rw [h₁ 999 (by norm_num)]\n      norm_num\n    have h4 : f 1004 = 1001 := by\n      rw [h₀ 1004 (by norm_num)]\n      norm_num\n    rw [h4] at h3\n    have h5 : f 1001 = 998 := by\n      rw [h₀ 1001 (by norm_num)]\n      norm_num\n    rw [h5] at h3\n    rw [h3] at h1\n    exact h1\n\n  have h998 : f 998 = 997 := by \n    have h1 : f 998 = f (f 1003) := by \n      rw [h₁ 998 (by norm_num)]\n      norm_num\n    have h2 : f 1003 = 1000 := by \n      rw [h₀ 1003 (by norm_num)]\n      norm_num\n    rw [h2] at h1\n    have h3 : f 1000 = 997 := by \n      rw [h₀ 1000 (by norm_num)]\n      norm_num\n    rw [h3] at h1\n    exact h1\n  \n  have h1 : f 84 = f (f 89) := by \n    rw [h₁ 84 (by norm_num)]\n    norm_num\n  \n  have h2 : f 89 = f (f 94) := by \n    rw [h₁ 89 (by norm_num)]\n    norm_num\n  \n  have h3 : f 94 = f (f 99) := by \n    rw [h₁ 94 (by norm_num)]\n    norm_num\n  \n  have h4 : f 99 = f (f 104) := by \n    rw [h₁ 99 (by norm_num)]\n    norm_num\n\n  have h5 : f 104 = f (f 109) := by \n    rw [h₁ 104 (by norm_num)]\n    norm_num\n\n  have h6 : f 109 = f (f 114) := by \n    rw [h₁ 109 (by norm_num)]\n    norm_num\n\n  have h7 : f 114 = f (f 119) := by \n    rw [h₁ 114 (by norm_num)]\n    norm_num\n\n  have h8 : f 119 = f (f 124) := by \n    rw [h₁ 119 (by norm_num)]\n    norm_num\n\n  have h9 : f 124 = f (f 129) := by \n    rw [h₁ 124 (by norm_num)]\n    norm_num\n\n  have h10 : f 129 = f (f 134) := by \n    rw [h₁ 129 (by norm_num)]\n    norm_num\n\n  have h11 : f 134 = f (f 139) := by \n    rw [h₁ 134 (by norm_num)]\n    norm_num\n\n  have h12 : f 139 = f (f 144) := by \n    rw [h₁ 139 (by norm_num)]\n    norm_num\n\n  have h13 : f 144 = f (f 149) := by \n    rw [h₁ 144 (by norm_num)]\n    norm_num\n\n  have h14 : f 149 = f (f 154) := by \n    rw [h₁ 149 (by norm_num)]\n    norm_num\n\n  have h15 : f 154 = f (f 159) := by \n    rw [h₁ 154 (by norm_num)]\n    norm_num\n\n  have h16 : f 159 = f (f 164) := by \n    rw [h₁ 159 (by norm_num)]\n    norm_num\n\n  have h17 : f 164 = f (f 169) := by \n    rw [h₁ 164 (by norm_num)]\n    norm_num\n\n  have h18 : f 169 = f (f 174) := by \n    rw [h₁ 169 (by norm_num)]\n    norm_num\n\n  have h19 : f 174 = f (f 179) := by \n    rw [h₁ 174 (by norm_num)]\n    norm_num\n\n  have h20 : f 179 = f (f 184) := by \n    rw [h₁ 179 (by norm_num)]\n    norm_num\n\n  have h21 : f 184 = f (f 189) := by \n    rw [h₁ 184 (by norm_num)]\n    norm_num\n\n  have h22 : f 189 = f (f 194) := by \n    rw [h₁ 189 (by norm_num)]\n    norm_num\n\n  have h23 : f 194 = f (f 199) := by \n    rw [h₁ 194 (by norm_num)]\n    norm_num\n\n  have h24 : f 199 = f (f 204) := by \n    rw [h₁ 199 (by norm_num)]\n    norm_num\n\n  have h25 : f 204 = f (f 209) := by \n    rw [h₁ 204 (by norm_num)]\n    norm_num\n\n  have h26 : f 209 = f (f 214) := by \n    rw [h₁ 209 (by norm_num)]\n    norm_num\n\n  have h27 : f 214 = f (f 219) := by \n    rw [h₁ 214 (by norm_num)]\n    norm_num\n\n  have h28 : f 219 = f (f 224) := by \n    rw [h₁ 219 (by norm_num)]\n    norm_num\n\n  have h29 : f 224 = f (f 229) := by \n    rw [h₁ 224 (by norm_num)]\n    norm_num\n\n  have h30 : f 229 = f (f 234) := by \n    rw [h₁ 229 (by norm_num)]\n    norm_num\n\n  have h31 : f 234 = f (f 239) := by \n    rw [h₁ 234 (by norm_num)]\n    norm_num\n\n  have h32 : f 239 = f (f 244) := by \n    rw [h₁ 239 (by norm_num)]\n    norm_num\n\n  have h33 : f 244 = f (f 249) := by \n    rw [h₁ 244 (by norm_num)]\n    norm_num\n\n  have h34 : f 249 = f (f 254) := by \n    rw [h₁ 249 (by norm_num)]\n    norm_num\n\n  have h35 : f 254 = f (f 259) := by \n    rw [h₁ 254 (by norm_num)]\n    norm_num\n\n  have h36 : f 259 = f (f 264) := by \n    rw [h₁ 259 (by norm_num)]\n    norm_num\n\n  have h37 : f 264 = f (f 269) := by \n    rw [h₁ 264 (by norm_num)]\n    norm_num\n\n  have h38 : f 269 = f (f 274) := by \n    rw [h₁ 269 (by norm_num)]\n    norm_num\n\n  have h39 : f 274 = f (f 279) := by \n    rw [h₁ 274 (by norm_num)]\n    norm_num\n\n  have h40 : f 279 = f (f 284) := by \n    rw [h₁ 279 (by norm_num)]\n    norm_num\n\n  have h41 : f 284 = f (f 289) := by \n    rw [h₁ 284 (by norm_num)]\n    norm_num\n\n  have h42 : f 289 = f (f 294) := by \n    rw [h₁ 289 (by norm_num)]\n    norm_num\n\n  have h43 : f 294 = f (f 299) := by \n    rw [h₁ 294 (by norm_num)]\n    norm_num\n\n  have h44 : f 299 = f (f 304) := by \n    rw [h₁ 299 (by norm_num)]\n    norm_num\n\n  have h45 : f 304 = f (f 309) := by \n    rw [h₁ 304 (by norm_num)]\n    norm_num\n\n  have h46 : f 309 = f (f 314) := by \n    rw [h₁ 309 (by norm_num)]\n    norm_num\n\n  have h47 : f 314 = f (f 319) := by \n    rw [h₁ 314 (by norm_num)]\n    norm_num\n\n  have h48 : f 319 = f (f 324) := by \n    rw [h₁ 319 (by norm_num)]\n    norm_num\n\n  have h49 : f 324 = f (f 329) := by \n    rw [h₁ 324 (by norm_num)]\n    norm_num\n\n  have h50 : f 329 = f (f 334) := by \n    rw [h₁ 329 (by norm_num)]\n    norm_num\n\n  have h51 : f 334 = f (f 339) := by \n    rw [h₁ 334 (by norm_num)]\n    norm_num\n\n  have h52 : f 339 = f (f 344) := by \n    rw [h₁ 339 (by norm_num)]\n    norm_num\n\n  have h53 : f 344 = f (f 349) := by \n    rw [h₁ 344 (by norm_num)]\n    norm_num\n\n  have h54 : f 349 = f (f 354) := by \n    rw [h₁ 349 (by norm_num)]\n    norm_num\n\n  have h55 : f 354 = f (f 359) := by \n    rw [h₁ 354 (by norm_num)]\n    norm_num\n\n  have h56 : f 359 = f (f 364) := by \n    rw [h₁ 359 (by norm_num)]\n    norm_num\n\n  have h57 : f 364 = f (f 369) := by \n    rw [h₁ 364 (by norm_num)]\n    norm_num\n\n  have h58 : f 369 = f (f 374) := by \n    rw [h₁ 369 (by norm_num)]\n    norm_num\n\n  have h59 : f 374 = f (f 379) := by \n    rw [h₁ 374 (by norm_num)]\n    norm_num\n\n  have h60 : f 379 = f (f 384) := by \n    rw [h₁ 379 (by norm_num)]\n    norm_num\n\n  have h61 : f 384 = f (f 389) := by \n    rw [h₁ 384 (by norm_num)]\n    norm_num\n\n  have h62 : f 389 = f (f 394) := by \n    rw [h₁ 389 (by norm_num)]\n    norm_num\n\n  have h63 : f 394 = f (f 399) := by \n    rw [h₁ 394 (by norm_num)]\n    norm_num\n\n  have h64 : f 399 = f (f 404) := by \n    rw [h₁ 399 (by norm_num)]\n    norm_num\n\n  have h65 : f 404 = f (f 409) := by \n    rw [h₁ 404 (by norm_num)]\n    norm_num\n\n  have h66 : f 409 = f (f 414) := by \n    rw [h₁ 409 (by norm_num)]\n    norm_num\n\n  have h67 : f 414 = f (f 419) := by \n    rw [h₁ 414 (by norm_num)]\n    norm_num\n\n  have h68 : f 419 = f (f 424) := by \n    rw [h₁ 419 (by norm_num)]\n    norm_num\n\n  have h69 : f 424 = f (f 429) := by \n    rw [h₁ 424 (by norm_num)]\n    norm_num\n\n  have h70 : f 429 = f (f 434) := by \n    rw [h₁ 429 (by norm_num)]\n    norm_num\n\n  have h71 : f 434 = f (f 439) := by \n    rw [h₁ 434 (by norm_num)]\n    norm_num\n\n  have h72 : f 439 = f (f 444) := by \n    rw [h₁ 439 (by norm_num)]\n    norm_num\n\n  have h73 : f 444 = f (f 449) := by \n    rw [h₁ 444 (by norm_num)]\n    norm_num\n\n  have h74 : f 449 = f (f 454) := by \n    rw [h₁ 449 (by norm_num)]\n    norm_num\n\n  have h75 : f 454 = f (f 459) := by \n    rw [h₁ 454 (by norm_num)]\n    norm_num\n\n  have h76 : f 459 = f (f 464) := by \n    rw [h₁ 459 (by norm_num)]\n    norm_num\n\n  have h77 : f 464 = f (f 469) := by \n    rw [h₁ 464 (by norm_num)]\n    norm_num\n\n  have h78 : f 469 = f (f 474) := by \n    rw [h₁ 469 (by norm_num)]\n    norm_num\n\n  have h79 : f 474 = f (f 479) := by \n    rw [h₁ 474 (by norm_num)]\n    norm_num\n\n  have h80 : f 479 = f (f 484) := by \n    rw [h₁ 479 (by norm_num)]\n    norm_num\n\n  have h81 : f 484 = f (f 489) := by \n    rw [h₁ 484 (by norm_num)]\n    norm_num\n\n  have h82 : f 489 = f (f 494) := by \n    rw [h₁ 489 (by norm_num)]\n    norm_num\n\n  have h83 : f 494 = f (f 499) := by \n    rw [h₁ 494 (by norm_num)]\n    norm_num\n\n  have h84 : f 499 = f (f 504) := by \n    rw [h₁ 499 (by norm_num)]\n    norm_num\n\n  have h85 : f 504 = f (f 509) := by \n    rw [h₁ 504 (by norm_num)]\n    norm_num\n\n  have h86 : f 509 = f (f 514) := by \n    rw [h₁ 509 (by norm_num)]\n    norm_num\n\n  have h87 : f 514 = f (f 519) := by \n    rw [h₁ 514 (by norm_num)]\n    norm_num\n\n  have h88 : f 519 = f (f 524) := by \n    rw [h₁ 519 (by norm_num)]\n    norm_num\n\n  have h89 : f 524 = f (f 529) := by \n    rw [h₁ 524 (by norm_num)]\n    norm_num\n\n  have h90 : f 529 = f (f 534) := by \n    rw [h₁ 529 (by norm_num)]\n    norm_num\n\n  have h91 : f 534 = f (f 539) := by \n    rw [h₁ 534 (by norm_num)]\n    norm_num\n\n  have h92 : f 539 = f (f 544) := by \n    rw [h₁ 539 (by norm_num)]\n    norm_num\n\n  have h93 : f 544 = f (f 549) := by \n    rw [h₁ 544 (by norm_num)]\n    norm_num\n\n  have h94 : f 549 = f (f 554) := by \n    rw [h₁ 549 (by norm_num)]\n    norm_num\n\n  have h95 : f 554 = f (f 559) := by \n    rw [h₁ 554 (by norm_num)]\n    norm_num\n\n  have h96 : f 559 = f (f 564) := by \n    rw [h₁ 559 (by norm_num)]\n    norm_num\n\n  have h97 : f 564 = f (f 569) := by \n    rw [h₁ 564 (by norm_num)]\n    norm_num\n\n  have h98 : f 569 = f (f 574) := by \n    rw [h₁ 569 (by norm_num)]\n    norm_num\n\n  have h99 : f 574 = f (f 579) := by \n    rw [h₁ 574 (by norm_num)]\n    norm_num\n\n  have h100 : f 579 = f (f 584) := by \n    rw [h₁ 579 (by norm_num)]\n    norm_num\n\n  have h101 : f 584 = f (f 589) := by \n    rw [h₁ 584 (by norm_num)]\n    norm_num\n\n  have h102 : f 589 = f (f 594) := by \n    rw [h₁ 589 (by norm_num)]\n    norm_num\n\n  have h103 : f 594 = f (f 599) := by \n    rw [h₁ 594 (by norm_num)]\n    norm_num\n\n  have h104 : f 599 = f (f 604) := by \n    rw [h₁ 599 (by norm_num)]\n    norm_num\n\n  have h105 : f 604 = f (f 609) := by \n    rw [h₁ 604 (by norm_num)]\n    norm_num\n\n  have h106 : f 609 = f (f 614) := by \n    rw [h₁ 609 (by norm_num)]\n    norm_num\n\n  have h107 : f 614 = f (f 619) := by \n    rw [h₁ 614 (by norm_num)]\n    norm_num\n\n  have h108 : f 619 = f (f 624) := by \n    rw [h₁ 619 (by norm_num)]\n    norm_num\n\n  have h109 : f 624 = f (f 629) := by \n    rw [h₁ 624 (by norm_num)]\n    norm_num\n\n  have h110 : f 629 = f (f 634) := by \n    rw [h₁ 629 (by norm_num)]\n    norm_num\n\n  have h111 : f 634 = f (f 639) := by \n    rw [h₁ 634 (by norm_num)]\n    norm_num\n\n  have h112 : f 639 = f (f 644) := by \n    rw [h₁ 639 (by norm_num)]\n    norm_num\n\n  have h113 : f 644 = f (f 649) := by \n    rw [h₁ 644 (by norm_num)]\n    norm_num\n\n  have h114 : f 649 = f (f 654) := by \n    rw [h₁ 649 (by norm_num)]\n    norm_num\n\n  have h115 : f 654 = f (f 659) := by \n    rw [h₁ 654 (by norm_num)]\n    norm_num\n\n  have h116 : f 659 = f (f 664) := by \n    rw [h₁ 659 (by norm_num)]\n    norm_num\n\n  have h117 : f 664 = f (f 669) := by \n    rw [h₁ 664 (by norm_num)]\n    norm_num\n\n  have h118 : f 669 = f (f 674) := by \n    rw [h₁ 669 (by norm_num)]\n    norm_num\n\n  have h119 : f 674 = f (f 679) := by \n    rw [h₁ 674 (by norm_num)]\n    norm_num\n\n  have h120 : f 679 = f (f 684) := by \n    rw [h₁ 679 (by norm_num)]\n    norm_num\n\n  have h121 : f 684 = f (f 689) := by \n    rw [h₁ 684 (by norm_num)]\n    norm_num\n\n  have h122 : f 689 = f (f 694) := by \n    rw [h₁ 689 (by norm_num)]\n    norm_num\n\n  have h123 : f 694 = f (f 699) := by \n    rw [h₁ 694 (by norm_num)]\n    norm_num\n\n  have h124 : f 699 = f (f 704) := by \n    rw [h₁ 699 (by norm_num)]\n    norm_num\n\n  have h125 : f 704 = f (f 709) := by \n    rw [h₁ 704 (by norm_num)]\n    norm_num\n\n  have h126 : f 709 = f (f 714) := by \n    rw [h₁ 709 (by norm_num)]\n    norm_num\n\n  have h127 : f 714 = f (f 719) := by \n    rw [h₁ 714 (by norm_num)]\n    norm_num\n\n  have h128 : f 719 = f (f 724) := by \n    rw [h₁ 719 (by norm_num)]\n    norm_num\n\n  have h129 : f 724 = f (f 729) := by \n    rw [h₁ 724 (by norm_num)]\n    norm_num\n\n  have h130 : f 729 = f (f 734) := by \n    rw [h₁ 729 (by norm_num)]\n    norm_num\n\n  have h131 : f 734 = f (f 739) := by \n    rw [h₁ 734 (by norm_num)]\n    norm_num\n\n  have h132 : f 739 = f (f 744) := by \n    rw [h₁ 739 (by norm_num)]\n    norm_num\n\n  have h133 : f 744 = f (f 749) := by \n    rw [h₁ 744 (by norm_num)]\n    norm_num\n\n  have h134 : f 749 = f (f 754) := by \n    rw [h₁ 749 (by norm_num)]\n    norm_num\n\n  have h135 : f 754 = f (f 759) := by \n    rw [h₁ 754 (by norm_num)]\n    norm_num\n\n  have h136 : f 759 = f (f 764) := by \n    rw [h₁ 759 (by norm_num)]\n    norm_num\n\n  have h137 : f 764 = f (f 769) := by \n    rw [h₁ 764 (by norm_num)]\n    norm_num\n\n  have h138 : f 769 = f (f 774) := by \n    rw [h₁ 769 (by norm_num)]\n    norm_num\n\n  have h139 : f 774 = f (f 779) := by \n    rw [h₁ 774 (by norm_num)]\n    norm_num\n\n  have h140 : f 779 = f (f 784) := by \n    rw [h₁ 779 (by norm_num)]\n    norm_num\n\n  have h141 : f 784 = f (f 789) := by \n    rw [h₁ 784 (by norm_num)]\n    norm_num\n\n  have h142 : f 789 = f (f 794) := by \n    rw [h₁ 789 (by norm_num)]\n    norm_num\n\n  have h143 : f 794 = f (f 799) := by \n    rw [h₁ 794 (by norm_num)]\n    norm_num\n\n  have h144 : f 799 = f (f 804) := by \n    rw [h₁ 799 (by norm_num)]\n    norm_num\n\n  have h145 : f 804 = f (f 809) := by \n    rw [h₁ 804 (by norm_num)]\n    norm_num\n\n  have h146 : f 809 = f (f 814) := by \n    rw [h₁ 809 (by norm_num)]\n    norm_num\n\n  have h147 : f 814 = f (f 819) := by \n    rw [h₁ 814 (by norm_num)]\n    norm_num\n\n  have h148 : f 819 = f (f 824) := by \n    rw [h₁ 819 (by norm_num)]\n    norm_num\n\n  have h149 : f 824 = f (f 829) := by \n    rw [h₁ 824 (by norm_num)]\n    norm_num\n\n  have h150 : f 829 = f (f 834) := by \n    rw [h₁ 829 (by norm_num)]\n    norm_num\n\n  have h151 : f 834 = f (f 839) := by \n    rw [h₁ 834 (by norm_num)]\n    norm_num\n\n  have h152 : f 839 = f (f 844) := by \n    rw [h₁ 839 (by norm_num)]\n    norm_num\n\n  have h153 : f 844 = f (f 849) := by \n    rw [h₁ 844 (by norm_num)]\n    norm_num\n\n  have h154 : f 849 = f (f 854) := by \n    rw [h₁ 849 (by norm_num)]\n    norm_num\n\n  have h155 : f 854 = f (f 859) := by \n    rw [h₁ 854 (by norm_num)]\n    norm_num\n\n  have h156 : f 859 = f (f 864) := by \n    rw [h₁ 859 (by norm_num)]\n    norm_num\n\n  have h157 : f 864 = f (f 869) := by \n    rw [h₁ 864 (by norm_num)]\n    norm_num\n\n  have h158 : f 869 = f (f 874) := by \n    rw [h₁ 869 (by norm_num)]\n    norm_num\n\n  have h159 : f 874 = f (f 879) := by \n    rw [h₁ 874 (by norm_num)]\n    norm_num\n\n  have h160 : f 879 = f (f 884) := by \n    rw [h₁ 879 (by norm_num)]\n    norm_num\n\n  have h161 : f 884 = f (f 889) := by \n    rw [h₁ 884 (by norm_num)]\n    norm_num\n\n  have h162 : f 889 = f (f 894) := by \n    rw [h₁ 889 (by norm_num)]\n    norm_num\n\n  have h163 : f 894 = f (f 899) := by \n    rw [h₁ 894 (by norm_num)]\n    norm_num\n\n  have h164 : f 899 = f (f 904) := by \n    rw [h₁ 899 (by norm_num)]\n    norm_num\n\n  have h165 : f 904 = f (f 909) := by \n    rw [h₁ 904 (by norm_num)]\n    norm_num\n\n  have h166 : f 909 = f (f 914) := by \n    rw [h₁ 909 (by norm_num)]\n    norm_num\n\n  have h167 : f 914 = f (f 919) := by \n    rw [h₁ 914 (by norm_num)]\n    norm_num\n\n  have h168 : f 919 = f (f 924) := by \n    rw [h₁ 919 (by norm_num)]\n    norm_num\n\n  have h169 : f 924 = f (f 929) := by \n    rw [h₁ 924 (by norm_num)]\n    norm_num\n\n  have h170 : f 929 = f (f 934) := by \n    rw [h₁ 929 (by norm_num)]\n    norm_num\n\n  have h171 : f 934 = f (f 939) := by \n    rw [h₁ 934 (by norm_num)]\n    norm_num\n\n  have h172 : f 939 = f (f 944) := by \n    rw [h₁ 939 (by norm_num)]\n    norm_num\n\n  have h173 : f 944 = f (f 949) := by \n    rw [h₁ 944 (by norm_num)]\n    norm_num\n\n  have h174 : f 949 = f (f 954) := by \n    rw [h₁ 949 (by norm_num)]\n    norm_num\n\n  have h175 : f 954 = f (f 959) := by \n    rw [h₁ 954 (by norm_num)]\n    norm_num\n\n  have h176 : f 959 = f (f 964) := by \n    rw [h₁ 959 (by norm_num)]\n    norm_num\n\n  have h177 : f 964 = f (f 969) := by \n    rw [h₁ 964 (by norm_num)]\n    norm_num\n\n  have h178 : f 969 = f (f 974) := by \n    rw [h₁ 969 (by norm_num)]\n    norm_num\n\n  have h179 : f 974 = f (f 979) := by \n    rw [h₁ 974 (by norm_num)]\n    norm_num\n\n  have h180 : f 979 = f (f 984) := by \n    rw [h₁ 979 (by norm_num)]\n    norm_num\n\n  have h181 : f 984 = f (f 989) := by \n    rw [h₁ 984 (by norm_num)]\n    norm_num\n\n  have h182 : f 989 = f (f 994) := by \n    rw [h₁ 989 (by norm_num)]\n    norm_num\n\n  have h183 : f 994 = f (f 999) := by \n    rw [h₁ 994 (by norm_num)]\n    norm_num\n\n  have h184 : f 999 = f (f 1004) := by \n    rw [h₁ 999 (by norm_num)]\n    norm_num\n\n  have h185 : f 1004 = 1001 := by \n    rw [h₀ 1004 (by norm_num)]\n    norm_num\n\n  rw [h185] at h184\n  have h186 : f 1001 = 998 := by \n    rw [h₀ 1001 (by norm_num)]\n    norm_num\n\n  rw [h186] at h184\n  rw [h184] at h183\n  \n  rw [h183] at h182\n  rw [h998] at h182\n\n  rw [h182] at h181\n  rw [h997] at h181\n\n  rw [h181] at h180\n  rw [h998] at h180\n\n  rw [h180] at h179\n  rw [h997] at h179\n\n  rw [h179] at h178\n  rw [h998] at h178\n\n  rw [h178] at h177\n  rw [h997] at h177\n\n  rw [h177] at h176\n  rw [h998] at h176\n\n  rw [h176] at h175\n  rw [h997] at h175\n\n  rw [h175] at h174\n  rw [h998] at h174\n\n  rw [h174] at h173\n  rw [h997] at h173\n\n  rw [h173] at h172\n  rw [h998] at h172\n\n  rw [h172] at h171\n  rw [h997] at h171\n\n  rw [h171] at h170\n  rw [h998] at h170\n\n  rw [h170] at h169\n  rw [h997] at h169\n\n  rw [h169] at h168\n  rw [h998] at h168\n\n  rw [h168] at h167\n  rw [h997] at h167\n\n  rw [h167] at h166\n  rw [h998] at h166\n\n  rw [h166] at h165\n  rw [h997] at h165\n\n  rw [h165] at h164\n  rw [h998] at h164\n\n  rw [h164] at h163\n  rw [h997] at h163\n\n  rw [h163] at h162\n  rw [h998] at h162\n\n  rw [h162] at h161\n  rw [h997] at h161\n\n  rw [h161] at h160\n  rw [h998] at h160\n\n  rw [h160] at h159\n  rw [h997] at h159\n\n  rw [h159] at h158\n  rw [h998] at h158\n\n  rw [h158] at h157\n  rw [h997] at h157\n\n  rw [h157] at h156\n  rw [h998] at h156\n\n  rw [h156] at h155\n  rw [h997] at h155\n\n  rw [h155] at h154\n  rw [h998] at h154\n\n  rw [h154] at h153\n  rw [h997] at h153\n\n  rw [h153] at h152\n  rw [h998] at h152\n\n  rw [h152] at h151\n  rw [h997] at h151\n\n  rw [h151] at h150\n  rw [h998] at h150\n\n  rw [h150] at h149\n  rw [h997] at h149\n\n  rw [h149] at h148\n  rw [h998] at h148\n\n  rw [h148] at h147\n  rw [h997] at h147\n\n  rw [h147] at h146\n  rw [h998] at h146\n\n  rw [h146] at h145\n  rw [h997] at h145\n\n  rw [h145] at h144\n  rw [h998] at h144\n\n  rw [h144] at h143\n  rw [h997] at h143\n\n  rw [h143] at h142\n  rw [h998] at h142\n\n  rw [h142] at h141\n  rw [h997] at h141\n\n  rw [h141] at h140\n  rw [h998] at h140\n\n  rw [h140] at h139\n  rw [h997] at h139\n\n  rw [h139] at h138\n  rw [h998] at h138\n\n  rw [h138] at h137\n  rw [h997] at h137\n\n  rw [h137] at h136\n  rw [h998] at h136\n\n  rw [h136] at h135\n  rw [h997] at h135\n\n  rw [h135] at h134\n  rw [h998] at h134\n\n  rw [h134] at h133\n  rw [h997] at h133\n\n  rw [h133] at h132\n  rw [h998] at h132\n\n  rw [h132] at h131\n  rw [h997] at h131\n\n  rw [h131] at h130\n  rw [h998] at h130\n\n  rw [h130] at h129\n  rw [h997] at h129\n\n  rw [h129] at h128\n  rw [h998] at h128\n\n  rw [h128] at h127\n  rw [h997] at h127\n\n  rw [h127] at h126\n  rw [h998] at h126\n\n  rw [h126] at h125\n  rw [h997] at h125\n\n  rw [h125] at h124\n  rw [h998] at h124\n\n  rw [h124] at h123\n  rw [h997] at h123\n\n  rw [h123] at h122\n  rw [h998] at h122\n\n  rw [h122] at h121\n  rw [h997] at h121\n\n  rw [h121] at h120\n  rw [h998] at h120\n\n  rw [h120] at h119\n  rw [h997] at h119\n\n  rw [h119] at h118\n  rw [h998] at h118\n\n  rw [h118] at h117\n  rw [h997] at h117\n\n  rw [h117] at h116\n  rw [h998] at h116\n\n  rw [h116] at h115\n  rw [h997] at h115\n\n  rw [h115] at h114\n  rw [h998] at h114\n\n  rw [h114] at h113\n  rw [h997] at h113\n\n  rw [h113] at h112\n  rw [h998] at h112\n\n  rw [h112] at h111\n  rw [h997] at h111\n\n  rw [h111] at h110\n  rw [h998] at h110\n\n  rw [h110] at h109\n  rw [h997] at h109\n\n  rw [h109] at h108\n  rw [h998] at h108\n\n  rw [h108] at h107\n  rw [h997] at h107\n\n  rw [h107] at h106\n  rw [h998] at h106\n\n  rw [h106] at h105\n  rw [h997] at h105\n\n  rw [h105] at h104\n  rw [h998] at h104\n\n  rw [h104] at h103\n  rw [h997] at h103\n\n  rw [h103] at h102\n  rw [h998] at h102\n\n  rw [h102] at h101\n  rw [h997] at h101\n\n  rw [h101] at h100\n  rw [h998] at h100\n\n  rw [h100] at h99\n  rw [h997] at h99\n\n  rw [h99] at h98\n  rw [h998] at h98\n\n  rw [h98] at h97\n  rw [h997] at h97\n\n  rw [h97] at h96\n  rw [h998] at h96\n\n  rw [h96] at h95\n  rw [h997] at h95\n\n  rw [h95] at h94\n  rw [h998] at h94\n\n  rw [h94] at h93\n  rw [h997] at h93\n\n  rw [h93] at h92\n  rw [h998] at h92\n\n  rw [h92] at h91\n  rw [h997] at h91\n\n  rw [h91] at h90\n  rw [h998] at h90\n\n  rw [h90] at h89\n  rw [h997] at h89\n\n  rw [h89] at h88\n  rw [h998] at h88\n\n  rw [h88] at h87\n  rw [h997] at h87\n\n  rw [h87] at h86\n  rw [h998] at h86\n\n  rw [h86] at h85\n  rw [h997] at h85\n\n  rw [h85] at h84\n  rw [h998] at h84\n\n  rw [h84] at h83\n  rw [h997] at h83\n\n  rw [h83] at h82\n  rw [h998] at h82\n\n  rw [h82] at h81\n  rw [h997] at h81\n\n  rw [h81] at h80\n  rw [h998] at h80\n\n  rw [h80] at h79\n  rw [h997] at h79\n\n  rw [h79] at h78\n  rw [h998] at h78\n\n  rw [h78] at h77\n  rw [h997] at h77\n\n  rw [h77] at h76\n  rw [h998] at h76\n\n  rw [h76] at h75\n  rw [h997] at h75\n\n  rw [h75] at h74\n  rw [h998] at h74\n\n  rw [h74] at h73\n  rw [h997] at h73\n\n  rw [h73] at h72\n  rw [h998] at h72\n\n  rw [h72] at h71\n  rw [h997] at h71\n\n  rw [h71] at h70\n  rw [h998] at h70\n\n  rw [h70] at h69\n  rw [h997] at h69\n\n  rw [h69] at h68\n  rw [h998] at h68\n\n  rw [h68] at h67\n  rw [h997] at h67\n\n  rw [h67] at h66\n  rw [h998] at h66\n\n  rw [h66] at h65\n  rw [h997] at h65\n\n  rw [h65] at h64\n  rw [h998] at h64\n\n  rw [h64] at h63\n  rw [h997] at h63\n\n  rw [h63] at h62\n  rw [h998] at h62\n\n  rw [h62] at h61\n  rw [h997] at h61\n\n  rw [h61] at h60\n  rw [h998] at h60\n\n  rw [h60] at h59\n  rw [h997] at h59\n\n  rw [h59] at h58\n  rw [h998] at h58\n\n  rw [h58] at h57\n  rw [h997] at h57\n\n  rw [h57] at h56\n  rw [h998] at h56\n\n  rw [h56] at h55\n  rw [h997] at h55\n\n  rw [h55] at h54\n  rw [h998] at h54\n\n  rw [h54] at h53\n  rw [h997] at h53\n\n  rw [h53] at h52\n  rw [h998] at h52\n\n  rw [h52] at h51\n  rw [h997] at h51\n\n  rw [h51] at h50\n  rw [h998] at h50\n\n  rw [h50] at h49\n  rw [h997] at h49\n\n  rw [h49] at h48\n  rw [h998] at h48\n\n  rw [h48] at h47\n  rw [h997] at h47\n\n  rw [h47] at h46\n  rw [h998] at h46\n\n  rw [h46] at h45\n  rw [h997] at h45\n\n  rw [h45] at h44\n  rw [h998] at h44\n\n  rw [h44] at h43\n  rw [h997] at h43\n\n  rw [h43] at h42\n  rw [h998] at h42\n\n  rw [h42] at h41\n  rw [h997] at h41\n\n  rw [h41] at h40\n  rw [h998] at h40\n\n  rw [h40] at h39\n  rw [h997] at h39\n\n  rw [h39] at h38\n  rw [h998] at h38\n\n  rw [h38] at h37\n  rw [h997] at h37\n\n  rw [h37] at h36\n  rw [h998] at h36\n\n  rw [h36] at h35\n  rw [h997] at h35\n\n  rw [h35] at h34\n  rw [h998] at h34\n\n  rw [h34] at h33\n  rw [h997] at h33\n\n  rw [h33] at h32\n  rw [h998] at h32\n\n  rw [h32] at h31\n  rw [h997] at h31\n\n  rw [h31] at h30\n  rw [h998] at h30\n\n  rw [h30] at h29\n  rw [h997] at h29\n\n  rw [h29] at h28\n  rw [h998] at h28\n\n  rw [h28] at h27\n  rw [h997] at h27\n\n  rw [h27] at h26\n  rw [h998] at h26\n\n  rw [h26] at h25\n  rw [h997] at h25\n\n  rw [h25] at h24\n  rw [h998] at h24\n\n  rw [h24] at h23\n  rw [h997] at h23\n\n  rw [h23] at h22\n  rw [h998] at h22\n\n  rw [h22] at h21\n  rw [h997] at h21\n\n  rw [h21] at h20\n  rw [h998] at h20\n\n  rw [h20] at h19\n  rw [h997] at h19\n\n  rw [h19] at h18\n  rw [h998] at h18\n\n  rw [h18] at h17\n  rw [h997] at h17\n\n  rw [h17] at h16\n  rw [h998] at h16\n\n  rw [h16] at h15\n  rw [h997] at h15\n\n  rw [h15] at h14\n  rw [h998] at h14\n\n  rw [h14] at h13\n  rw [h997] at h13\n\n  rw [h13] at h12\n  rw [h998] at h12\n\n  rw [h12] at h11\n  rw [h997] at h11\n\n  rw [h11] at h10\n  rw [h998] at h10\n\n  rw [h10] at h9\n  rw [h997] at h9\n\n  rw [h9] at h8\n  rw [h998] at h8\n\n  rw [h8] at h7\n  rw [h997] at h7\n\n  rw [h7] at h6\n  rw [h998] at h6\n\n  rw [h6] at h5\n  rw [h997] at h5\n\n  rw [h5] at h4\n  rw [h998] at h4\n\n  rw [h4] at h3\n  rw [h997] at h3\n\n  rw [h3] at h2\n  rw [h998] at h2\n\n  rw [h2] at h1\n  rw [h997] at h1\n\n  linarith",
    "name": "aime_1984_p7"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1983_p2 (x p : ℝ) (f : ℝ → ℝ) (h₀ : 0 < p ∧ p < 15) (h₁ : p ≤ x ∧ x ≤ 15)\n    (h₂ : f x = abs (x - p) + abs (x - 15) + abs (x - p - 15)) : 15 ≤ f x := by\n  have h3 : abs (x - p) = x - p := by\n    rw [abs_of_nonneg]\n    linarith [h₁.left]\n  have h4 : abs (x - 15) = -(x - 15) := by\n    rw [abs_of_nonpos]\n    linarith [h₁.right]\n  have h5 : abs (x - p - 15) = -(x - p - 15) := by\n    rw [abs_of_nonpos]\n    have h6 : x - p - 15 ≤ 0 := by linarith [h₁.right, h₀.left]\n    linarith\n  rw [h₂, h3, h4, h5]\n  linarith [h₁.right]",
    "name": "aime_1983_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_24 (x : ℝ) (h₀ : x / 50 = 40) : x = 2000 := by\n  linarith",
    "name": "mathd_algebra_24"
  }
]