[
  {
    "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_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_314 (n : ℕ) (h₀ : n = 11) : (1 / 4) ^ (n + 1) * 2 ^ (2 * n) = 1 / 4 := by\n  rw [h₀]\n  norm_num",
    "name": "mathd_algebra_314"
  },
  {
    "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 mathd_algebra_17 (a : ℝ)\n    (h₀ : Real.sqrt (4 + Real.sqrt (16 + 16 * a)) + Real.sqrt (1 + Real.sqrt (1 + a)) = 6) : a = 8 := by\n  have h1 : Real.sqrt (4 + Real.sqrt (16 + 16 * a)) = 2 * Real.sqrt (1 + Real.sqrt (1 + a)) := by\n    have h16 : Real.sqrt (16 + 16 * a) = 4 * Real.sqrt (1 + a) := by\n      have h16_nonneg : 0 ≤ Real.sqrt (1 + a) := Real.sqrt_nonneg (1 + a)\n      have h1 : Real.sqrt (16 + 16 * a) = Real.sqrt (4^2 * (1 + a)) := by\n        have h2 : 16 + 16 * a = (4 : ℝ) ^ 2 * (1 + a) := by ring\n        rw [h2]\n      rw [h1]\n      rw [Real.sqrt_mul (by norm_num)]\n      rw [Real.sqrt_sq (by norm_num)]\n    have h2 : Real.sqrt (4 + Real.sqrt (16 + 16 * a)) = Real.sqrt (4 + 4 * Real.sqrt (1 + a)) := by\n      rw [h16]\n    rw [h2]\n    have h3 : Real.sqrt (4 + 4 * Real.sqrt (1 + a)) = 2 * Real.sqrt (1 + Real.sqrt (1 + a)) := by\n      have h3_nonneg : 0 ≤ Real.sqrt (1 + a) := Real.sqrt_nonneg (1 + a)\n      have h4_nonneg : 0 ≤ Real.sqrt (1 + Real.sqrt (1 + a)) := Real.sqrt_nonneg (1 + Real.sqrt (1 + a))\n      have h4 : Real.sqrt (4 + 4 * Real.sqrt (1 + a)) = 2 * Real.sqrt (1 + Real.sqrt (1 + a)) := by\n        have h5 : (Real.sqrt (4 + 4 * Real.sqrt (1 + a))) ^ 2 = (2 * Real.sqrt (1 + Real.sqrt (1 + a))) ^ 2 := by\n          have h5_left : (Real.sqrt (4 + 4 * Real.sqrt (1 + a))) ^ 2 = 4 + 4 * Real.sqrt (1 + a) := by\n            rw [Real.sq_sqrt]\n            nlinarith [Real.sqrt_nonneg (1 + a), Real.sqrt_nonneg (1 + Real.sqrt (1 + a))]\n          have h5_right : (2 * Real.sqrt (1 + Real.sqrt (1 + a))) ^ 2 = 4 + 4 * Real.sqrt (1 + a) := by\n            calc\n              (2 * Real.sqrt (1 + Real.sqrt (1 + a))) ^ 2\n                  = 2^2 * (Real.sqrt (1 + Real.sqrt (1 + a)))^2 := by ring\n              _ = 4 * (1 + Real.sqrt (1 + a)) := by\n                have h6 : (Real.sqrt (1 + Real.sqrt (1 + a)))^2 = 1 + Real.sqrt (1 + a) := by\n                  rw [Real.sq_sqrt]\n                  linarith [Real.sqrt_nonneg (1 + a), Real.sqrt_nonneg (1 + Real.sqrt (1 + a))]\n                rw [h6]\n                all_goals linarith\n              _ = 4 + 4 * Real.sqrt (1 + a) := by ring\n          rw [h5_left, h5_right]\n        have h6 : 0 ≤ Real.sqrt (4 + 4 * Real.sqrt (1 + a)) := Real.sqrt_nonneg (4 + 4 * Real.sqrt (1 + a))\n        have h7 : 0 ≤ 2 * Real.sqrt (1 + Real.sqrt (1 + a)) := by\n          apply mul_nonneg\n          norm_num\n          exact Real.sqrt_nonneg (1 + Real.sqrt (1 + a))\n        have h8 : Real.sqrt (4 + 4 * Real.sqrt (1 + a)) = 2 * Real.sqrt (1 + Real.sqrt (1 + a)) := by\n          apply (sq_eq_sq h6 h7).mp\n          linarith\n        exact h8\n      exact h4\n    linarith [h3]\n  rw [h1] at h₀\n  have h2 : Real.sqrt (1 + Real.sqrt (1 + a)) = 2 := by\n    have h2_pos : 0 ≤ Real.sqrt (1 + Real.sqrt (1 + a)) := Real.sqrt_nonneg (1 + Real.sqrt (1 + a))\n    nlinarith [Real.sqrt_nonneg (1 + Real.sqrt (1 + a)), h₀]\n  have h3 : 1 + Real.sqrt (1 + a) = 4 := by\n    have h3_pos : 0 ≤ Real.sqrt (1 + Real.sqrt (1 + a)) := Real.sqrt_nonneg (1 + Real.sqrt (1 + a))\n    have h3_eq : (Real.sqrt (1 + Real.sqrt (1 + a))) ^ 2 = (2 : ℝ) ^ 2 := by\n      rw [h2]\n    have h3_left : (Real.sqrt (1 + Real.sqrt (1 + a))) ^ 2 = 1 + Real.sqrt (1 + a) := by\n      rw [Real.sq_sqrt]\n      have h4 : 0 ≤ Real.sqrt (1 + a) := Real.sqrt_nonneg (1 + a)\n      linarith [h4, Real.sqrt_nonneg (1 + Real.sqrt (1 + a))]\n    have h3_right : (2 : ℝ) ^ 2 = 4 := by norm_num\n    rw [h3_left, h3_right] at h3_eq\n    linarith\n  have h4 : Real.sqrt (1 + a) = 3 := by linarith [h3]\n  have h5 : 1 + a = 9 := by\n    have h5_nonneg : 0 ≤ Real.sqrt (1 + a) := Real.sqrt_nonneg (1 + a)\n    have h5_eq : (Real.sqrt (1 + a)) ^ 2 = (3 : ℝ) ^ 2 := by\n      rw [h4]\n    have h5_left : (Real.sqrt (1 + a)) ^ 2 = 1 + a := by\n      rw [Real.sq_sqrt]\n      have h4_pos : 0 ≤ 1 + a := by\n        by_contra h\n        push_neg at h\n        have h5 : Real.sqrt (1 + a) = 0 := by\n          apply Real.sqrt_eq_zero_of_nonpos\n          linarith\n        rw [h5] at h4\n        linarith\n      exact h4_pos\n    have h5_right : (3 : ℝ) ^ 2 = 9 := by norm_num\n    rw [h5_left, h5_right] at h5_eq\n    linarith\n  linarith [h5]",
    "name": "mathd_algebra_17"
  },
  {
    "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 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_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 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 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 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_127 : (∑ k in Finset.range 101, 2 ^ k) % 7 = 3 := by\n  native_decide",
    "name": "mathd_numbertheory_127"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_270 (f : ℝ → ℝ) (h₀ : ∀ (x) (_ : x ≠ -2), f x = 1 / (x + 2)) :\n    f (f 1) = 3 / 7 := by\n  have h1 : f 1 = 1 / 3 := by\n    rw [h₀ 1 (by norm_num)]\n    norm_num\n  have h2 : f (1 / 3) = 3 / 7 := by \n    rw [h₀ (1 / 3) (by norm_num)]\n    norm_num\n  rw [h1]\n  exact h2",
    "name": "mathd_algebra_270"
  },
  {
    "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 imo_1964_p2 (a b c : ℝ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : c < a + b) (h₂ : b < a + c)\n    (h₃ : a < b + c) :\n    a ^ 2 * (b + c - a) + b ^ 2 * (c + a - b) + c ^ 2 * (a + b - c) ≤ 3 * a * b * c := by\n  nlinarith [sq_nonneg (a * b - b * c), sq_nonneg (b * c - c * a), sq_nonneg (c * a - a * b),\n    sq_nonneg (a - b), sq_nonneg (b - c), sq_nonneg (c - a),\n    h₀.left, h₀.right.left, h₀.right.right,\n    mul_pos h₀.left h₀.right.left, mul_pos h₀.left h₀.right.right, mul_pos h₀.right.left h₀.right.right]",
    "name": "imo_1964_p2"
  },
  {
    "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 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 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_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_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_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_142 (m b : ℝ) (h₀ : m * 7 + b = -1) (h₁ : m * -1 + b = 7) : m + b = 5 := by\n  have eq1 : m = -1 := by \n    linarith \n  have eq2 : b = 6 := by \n    rw [eq1] at h₀ \n    linarith\n  linarith [eq1, eq2]",
    "name": "mathd_algebra_142"
  },
  {
    "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 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 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 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 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 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 imo_1962_p2 (x : ℝ) (h₀ : 0 ≤ 3 - x) (h₁ : 0 ≤ x + 1)\n    (h₂ : 1 / 2 < Real.sqrt (3 - x) - Real.sqrt (x + 1)) : -1 ≤ x ∧ x < 1 - Real.sqrt 31 / 8 := by \n  constructor\n  · linarith [h₁]\n  · have h3 : Real.sqrt (3 - x) - Real.sqrt (x + 1) > 1 / 2 := by linarith\n    have h4 : Real.sqrt (3 - x) > Real.sqrt (x + 1) + 1 / 2 := by linarith\n    have h5 : Real.sqrt (x + 1) ≥ 0 := Real.sqrt_nonneg (x + 1)\n    have h6 : Real.sqrt (3 - x) ≥ 0 := Real.sqrt_nonneg (3 - x)\n    have h7 : Real.sqrt (3 - x) > 0 := by linarith [h6, h5]\n    have h8 : (Real.sqrt (3 - x)) ^ 2 > (Real.sqrt (x + 1) + 1 / 2) ^ 2 := by\n      apply sq_lt_sq'\n      all_goals linarith [h4, h5, h7]\n    have h9 : (Real.sqrt (3 - x)) ^ 2 = 3 - x := by \n      rw [Real.sq_sqrt]\n      linarith\n    have h10 : (Real.sqrt (x + 1) + 1 / 2) ^ 2 = (Real.sqrt (x + 1)) ^ 2 + Real.sqrt (x + 1) + 1 / 4 := by\n      ring_nf\n      <;> simp [Real.sqrt_nonneg]\n    rw [h9, h10] at h8\n    have h11 : (Real.sqrt (x + 1)) ^ 2 = x + 1 := by\n      rw [Real.sq_sqrt]\n      linarith\n    have h12 : Real.sqrt (x + 1) < 7 / 4 - 2 * x := by nlinarith [h8, h11, Real.sqrt_nonneg (x + 1)]\n    have h13 : x < 1 - Real.sqrt 31 / 8 := by\n      have h14 : Real.sqrt (x + 1) + 2 * x < 7 / 4 := by linarith [h12]\n      have h15 : Real.sqrt 31 ^ 2 = 31 := by\n        rw [Real.sq_sqrt]\n        norm_num\n      nlinarith [h14, Real.sq_sqrt (show 0 ≤ x + 1 by linarith), Real.sq_sqrt (show 0 ≤ 3 - x by linarith), Real.sqrt_nonneg (3 - x), Real.sqrt_nonneg (x + 1), Real.sq_sqrt (show 0 ≤ (31 : ℝ) by norm_num), Real.sq_sqrt (show 0 ≤ (8 : ℝ) by norm_num)]\n    linarith [h13]",
    "name": "imo_1962_p2"
  },
  {
    "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 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 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_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_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 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_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_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 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_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 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 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 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_numbertheory_314 (r n : ℕ) (h₀ : r = 1342 % 13) (h₁ : 0 < n) (h₂ : 1342 ∣ n)\n    (h₃ : n % 13 < r) : 6710 ≤ n := by\n  have hr : r = 3 := by \n    norm_num [h₀]\n  have h4 : r = 3 := hr\n\n  rcases h₂ with ⟨k, hk⟩\n  have h5 : n % 13 < 3 := by\n    rw [h4] at h₃\n    exact h₃\n\n  rw [hk] at h5\n  \n  have h6 : k ≥ 5 := by\n    by_contra h\n    push_neg at h\n    have h7 : k < 5 := h\n    have h8 : k ≠ 0 := by\n      omega\n    interval_cases k <;> norm_num at h5 <;> omega\n\n  have h9 : n = 1342 * k := by\n    linarith\n\n  have h10 : n ≥ 6710 := by\n    omega\n\n  linarith",
    "name": "mathd_numbertheory_314"
  },
  {
    "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_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 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 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 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_338 (a b c : ℝ) (h₀ : 3 * a + b + c = -3) (h₁ : a + 3 * b + c = 9)\n    (h₂ : a + b + 3 * c = 19) : a * b * c = -56 := by\n  have h3 : a + b + c = 5 := by\n    linarith\n  have ha : a = -4 := by \n    linarith [h₀, h3]\n  have hb : b = 2 := by \n    linarith [h₁, h3]\n  have hc : c = 7 := by \n    linarith [h₂, h3] \n  rw [ha, hb, hc]\n  norm_num",
    "name": "mathd_algebra_338"
  },
  {
    "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_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_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_numbertheory_229 : 5 ^ 30 % 7 = 1 := by \n  norm_num",
    "name": "mathd_numbertheory_229"
  },
  {
    "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 amc12a_2009_p6 (m n p q : ℝ) (h₀ : p = 2 ^ m) (h₁ : q = 3 ^ n) :\n    p ^ (2 * n) * q ^ m = 12 ^ (m * n) := by\n  rw [h₀, h₁]\n  have h2 : (2 : ℝ) ^ (m * (2 * n)) * (3 : ℝ) ^ (n * m) = (12 : ℝ) ^ (m * n) := by\n    have h3 : (12 : ℝ) = 2 ^ (2 : ℝ) * 3 ^ (1 : ℝ) := by norm_num\n    rw [h3]\n    have h4 : (2 ^ (2 : ℝ) * 3 ^ (1 : ℝ)) ^ (m * n) = (2 : ℝ) ^ (2 * (m * n)) * (3 : ℝ) ^ (1 * (m * n)) := by\n      rw [Real.mul_rpow (by norm_num) (by norm_num)]\n      simp [Real.rpow_mul]\n      all_goals linarith\n    rw [h4]\n    ring_nf\n  rw [←h2]\n  <;> simp [Real.rpow_mul]\n  all_goals linarith",
    "name": "amc12a_2009_p6"
  },
  {
    "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_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 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 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 mathd_algebra_24 (x : ℝ) (h₀ : x / 50 = 40) : x = 2000 := by\n  linarith",
    "name": "mathd_algebra_24"
  },
  {
    "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 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 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 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 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 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 amc12_2001_p21 (a b c d : ℕ) (h₀ : a * b * c * d = 8!) (h₁ : a * b + a + b = 524)\n    (h₂ : b * c + b + c = 146) (h₃ : c * d + c + d = 104) : ↑a - ↑d = (10 : ℤ) := by\n\n  have h4 : (a + 1) * (b + 1) = 525 := by nlinarith\n  have h5 : (b + 1) * (c + 1) = 147 := by nlinarith\n  have h6 : (c + 1) * (d + 1) = 105 := by nlinarith\n  \n  have h7 : b + 1 ≤ 525 := by nlinarith\n  have h8 : c + 1 ≤ 147 := by nlinarith\n  have h9 : d + 1 ≤ 105 := by nlinarith\n  \n  have h10 : b + 1 ≤ 147 := by nlinarith\n  \n  have h11 : (b + 1) ∣ 21 := by \n    have h4a : (b + 1) ∣ 525 := by\n      use a + 1\n      nlinarith\n    have h5a : (b + 1) ∣ 147 := by\n      use c + 1\n      nlinarith\n    have h11 : (b + 1) ∣ Nat.gcd 525 147 := by\n      apply Nat.dvd_gcd h4a h5a\n    rw [show Nat.gcd 525 147 = 21 by norm_num] at h11\n    exact h11\n  \n  have h12 : b + 1 ≤ 21 := by \n    exact Nat.le_of_dvd (by norm_num) h11\n  \n  have h13 : b + 1 = 1 ∨ b + 1 = 3 ∨ b + 1 = 7 ∨ b + 1 = 21 := by\n    interval_cases hb1 : b + 1 <;> norm_num at h11 <;> omega\n  \n  rcases h13 with (h21 | h23 | h27 | h221)\n\n  · -- Case b + 1 = 1\n    have hc1 : c + 1 = 147 := by \n      rw [h21] at h5\n      omega\n    have hd1 : d + 1 = 0 := by \n      rw [hc1] at h6\n      omega\n    have h_d : d = 0 := by omega\n    have h_d1 : d ≥ 0 := by omega\n    omega\n\n  · -- Case b + 1 = 3\n    have hc1 : c + 1 = 49 := by \n      rw [h23] at h5\n      omega\n    have hd1 : d + 1 = 0 := by \n      rw [hc1] at h6\n      omega\n    have h_d : d = 0 := by omega\n    have h_d1 : d ≥ 0 := by omega\n    omega\n\n  · -- Case b + 1 = 7\n    have hc1 : c + 1 = 21 := by \n      rw [h27] at h5\n      omega\n    have hd1 : d + 1 = 5 := by \n      rw [hc1] at h6\n      omega\n    have h_d : d = 4 := by omega\n    have ha1 : a + 1 = 75 := by \n      rw [h27] at h4\n      omega\n    have h_a : a = 74 := by omega\n    have h74 : a * b * c * d = 40320 := by \n      calc \n        a * b * c * d = 8! := h₀\n        _ = 40320 := by rfl\n    have h75 : a * b * c * d = 74 * 6 * 20 * 4 := by\n      rw [h_a]\n      have hb : b = 6 := by omega\n      have hc : c = 20 := by omega\n      rw [hb, hc, h_d]\n    norm_num at h75\n    omega\n\n  · -- Case b + 1 = 21\n    have hc1 : c + 1 = 7 := by \n      rw [h221] at h5\n      omega\n    have hd1 : d + 1 = 15 := by \n      rw [hc1] at h6\n      omega\n    have h_d : d = 14 := by omega\n    have ha1 : a + 1 = 25 := by \n      rw [h221] at h4\n      omega\n    have h_a : a = 24 := by omega\n    have h_diff : (a : ℤ) - (d : ℤ) = 10 := by \n      rw [h_a, h_d]\n      norm_num\n    exact h_diff",
    "name": "amc12_2001_p21"
  },
  {
    "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 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 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 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_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_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_353 (s : ℕ) (h₀ : s = ∑ k in Finset.Icc 2010 4018, k) : s % 2009 = 0 := by \n  rw [h₀]\n  native_decide",
    "name": "mathd_numbertheory_353"
  },
  {
    "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 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_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_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 mathd_numbertheory_99 (n : ℕ) (h₀ : 2 * n % 47 = 15) : n % 47 = 31 := by\n  omega",
    "name": "mathd_numbertheory_99"
  },
  {
    "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 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_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_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 mathd_algebra_392 (n : ℕ) (h₀ : Even n)\n    (h₁ : (↑n - 2) ^ 2 + ↑n ^ 2 + (↑n + 2) ^ 2 = (12296 : ℤ)) :\n    (↑n - 2) * ↑n * (↑n + 2) / 8 = (32736 : ℤ) := by \n  have h2 : (n : ℤ) ^ 2 = 4096 := by\n    ring_nf at h₁\n    nlinarith\n  \n  have hn : (n : ℤ) = 64 := by \n    have h3 : (n : ℤ) ^ 2 - 4096 = 0 := by linarith\n  \n    have h4 : ((n : ℤ) - 64) * ((n : ℤ) + 64) = 0 := by \n      ring_nf at h3 ⊢ \n      linarith\n  \n    cases' (mul_eq_zero.mp h4) with h5 h6 \n    · -- n - 64 = 0 \n      linarith \n    · -- n + 64 = 0 \n      have h7 : (n : ℤ) = -64 := by linarith \n      have h8 : n = 0 := by \n        norm_num at h7 \n        omega \n      have h9 : n ≥ 2 := by \n        rcases h₀ with ⟨k, hk⟩ \n        omega \n      omega\n  \n  rw [hn]\n  norm_num",
    "name": "mathd_algebra_392"
  },
  {
    "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 mathd_numbertheory_207 : 8 * 9 ^ 2 + 5 * 9 + 2 = 695 := by \n  norm_num",
    "name": "mathd_numbertheory_207"
  },
  {
    "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 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 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 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 aime_1990_p15 (a b x y : ℝ) (h₀ : a * x + b * y = 3) (h₁ : a * x ^ 2 + b * y ^ 2 = 7)\n    (h₂ : a * x ^ 3 + b * y ^ 3 = 16) (h₃ : a * x ^ 4 + b * y ^ 4 = 42) :\n    a * x ^ 5 + b * y ^ 5 = 20 := by\n  \n  have eq1 : a * x ^ 3 + b * y ^ 3 = (x + y) * (a * x ^ 2 + b * y ^ 2) - x * y * (a * x + b * y) := by\n    ring\n  rw [h₀, h₁, h₂] at eq1\n  \n  have eq2 : a * x ^ 4 + b * y ^ 4 = (x + y) * (a * x ^ 3 + b * y ^ 3) - x * y * (a * x ^ 2 + b * y ^ 2) := by\n    ring\n  rw [h₁, h₂, h₃] at eq2\n\n  have h4 : (x + y) = -14 := by\n    have eq1' : (x + y) * 7 - x * y * 3 = 16 := by linarith\n    have eq2' : (x + y) * 16 - x * y * 7 = 42 := by linarith\n    have h4 : (x + y) = -14 := by\n      nlinarith [sq_nonneg (x + y), sq_nonneg (x - y), sq_nonneg (a * x^2 - b * y^2), sq_nonneg (a * x - b * y)]\n    linarith\n  \n  have h5 : x * y = -38 := by\n    have eq1' : (x + y) * 7 - x * y * 3 = 16 := by linarith\n    rw [h4] at eq1'\n    linarith\n    \n  have h6 : a * x^5 + b * y^5 = (x + y) * (a * x^4 + b * y^4) - x * y * (a * x^3 + b * y^3) := by\n    ring\n  rw [h₃, h₂, h4, h5] at h6\n  linarith",
    "name": "aime_1990_p15"
  },
  {
    "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_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_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_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 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 mathd_algebra_107 (x y : ℝ) (h₀ : x ^ 2 + 8 * x + y ^ 2 - 6 * y = 0) :\n    (x + 4) ^ 2 + (y - 3) ^ 2 = 5 ^ 2 := by \n  nlinarith [sq_nonneg (x + 4), sq_nonneg (y - 3), h₀]",
    "name": "mathd_algebra_107"
  },
  {
    "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 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_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 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 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_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 aime_1997_p9 (a : ℝ) (h₀ : 0 < a)\n    (h₁ : 1 / a - Int.floor (1 / a) = a ^ 2 - Int.floor (a ^ 2)) (h₂ : 2 < a ^ 2) (h₃ : a ^ 2 < 3) :\n    a ^ 12 - 144 * (1 / a) = 233 := by\n  have h4 : Int.floor (a ^ 2) = 2 := by\n    have h_floor : 2 ≤ a ^ 2 ∧ a ^ 2 < 3 := ⟨by nlinarith, by linarith⟩\n    rw [Int.floor_eq_iff]\n    constructor <;> (try norm_num) <;> nlinarith\n\n  have h5 : Int.floor (1 / a) = 0 := by\n    have h6 : 1 / a < 1 := by\n      have h7 : 1 < a := by nlinarith [h₂, mul_pos h₀ (show 0 < a by linarith)]\n      have h8 : 1 / a < 1 := by\n        rw [div_lt_iff (by linarith)]\n        linarith\n      linarith\n    have h9 : 0 ≤ 1 / a := by \n      apply div_nonneg\n      · norm_num \n      · linarith\n    rw [Int.floor_eq_iff]\n    constructor\n    · -- Show that 0 ≤ 1/a\n      linarith\n    · -- Show that 1/a < 1\n      linarith [h6]\n\n  have h7 : 1 / a = a ^ 2 - 2 := by \n    rw [h5, h4] at h₁\n    linarith\n\n  have h8 : a ^ 3 - 2 * a - 1 = 0 := by \n    field_simp at h7 \n    nlinarith [h₀]\n\n  have h9 : a ^ 2 - a - 1 = 0 := by\n    have h10 : a ^ 3 - 2 * a - 1 = 0 := h8\n    have h11 : a ^ 2 - a - 1 = 0 := by\n      have h12 : (a + 1) * (a ^ 2 - a - 1) = 0 := by \n        ring_nf at h10 ⊢\n        linarith\n      cases' (mul_eq_zero.mp h12) with h13 h14\n      · -- Case a + 1 = 0, but a > 0, contradiction\n        nlinarith\n      · -- Case a^2 - a - 1 = 0, which is our goal\n        linarith\n    exact h11\n\n  have ha2 : a ^ 2 = a + 1 := by linarith\n\n  have ha3 : a ^ 3 = 2 * a + 1 := by \n    calc\n      a ^ 3 = a ^ 2 * a := by ring\n      _ = (a + 1) * a := by rw [ha2]\n      _ = a ^ 2 + a := by ring\n      _ = (a + 1) + a := by rw [ha2]\n      _ = 2 * a + 1 := by ring\n\n  have ha4 : a ^ 4 = 3 * a + 2 := by \n    calc \n      a ^ 4 = a ^ 3 * a := by ring\n      _ = (2 * a + 1) * a := by rw [ha3]\n      _ = 2 * a ^ 2 + a := by ring\n      _ = 2 * (a + 1) + a := by rw [ha2]\n      _ = 3 * a + 2 := by ring\n\n  have ha5 : a ^ 5 = 5 * a + 3 := by \n    calc \n      a ^ 5 = a ^ 4 * a := by ring\n      _ = (3 * a + 2) * a := by rw [ha4]\n      _ = 3 * a ^ 2 + 2 * a := by ring\n      _ = 3 * (a + 1) + 2 * a := by rw [ha2]\n      _ = 5 * a + 3 := by ring\n\n  have ha6 : a ^ 6 = 8 * a + 5 := by \n    calc \n      a ^ 6 = a ^ 5 * a := by ring\n      _ = (5 * a + 3) * a := by rw [ha5]\n      _ = 5 * a ^ 2 + 3 * a := by ring\n      _ = 5 * (a + 1) + 3 * a := by rw [ha2]\n      _ = 8 * a + 5 := by ring\n\n  have ha7 : a ^ 7 = 13 * a + 8 := by \n    calc \n      a ^ 7 = a ^ 6 * a := by ring\n      _ = (8 * a + 5) * a := by rw [ha6]\n      _ = 8 * a ^ 2 + 5 * a := by ring\n      _ = 8 * (a + 1) + 5 * a := by rw [ha2]\n      _ = 13 * a + 8 := by ring\n\n  have ha8 : a ^ 8 = 21 * a + 13 := by \n    calc \n      a ^ 8 = a ^ 7 * a := by ring\n      _ = (13 * a + 8) * a := by rw [ha7]\n      _ = 13 * a ^ 2 + 8 * a := by ring\n      _ = 13 * (a + 1) + 8 * a := by rw [ha2]\n      _ = 21 * a + 13 := by ring\n\n  have ha9 : a ^ 9 = 34 * a + 21 := by \n    calc \n      a ^ 9 = a ^ 8 * a := by ring\n      _ = (21 * a + 13) * a := by rw [ha8]\n      _ = 21 * a ^ 2 + 13 * a := by ring\n      _ = 21 * (a + 1) + 13 * a := by rw [ha2]\n      _ = 34 * a + 21 := by ring\n\n  have ha10 : a ^ 10 = 55 * a + 34 := by \n    calc \n      a ^ 10 = a ^ 9 * a := by ring\n      _ = (34 * a + 21) * a := by rw [ha9]\n      _ = 34 * a ^ 2 + 21 * a := by ring\n      _ = 34 * (a + 1) + 21 * a := by rw [ha2]\n      _ = 55 * a + 34 := by ring\n\n  have ha11 : a ^ 11 = 89 * a + 55 := by \n    calc \n      a ^ 11 = a ^ 10 * a := by ring\n      _ = (55 * a + 34) * a := by rw [ha10]\n      _ = 55 * a ^ 2 + 34 * a := by ring\n      _ = 55 * (a + 1) + 34 * a := by rw [ha2]\n      _ = 89 * a + 55 := by ring\n\n  have ha12 : a ^ 12 = 144 * a + 89 := by \n    calc \n      a ^ 12 = a ^ 11 * a := by ring\n      _ = (89 * a + 55) * a := by rw [ha11]\n      _ = 89 * a ^ 2 + 55 * a := by ring\n      _ = 89 * (a + 1) + 55 * a := by rw [ha2]\n      _ = 144 * a + 89 := by ring\n\n  have h10 : 1 / a = a - 1 := by \n    have h11 : a ^ 2 = a + 1 := ha2\n    have h12 : 1 / a = a - 1 := by \n      field_simp at h7 ⊢\n      nlinarith\n    linarith\n\n  rw [ha12, h10]\n  nlinarith [sq_nonneg (a - 1), sq_nonneg (a + 1)]",
    "name": "aime_1997_p9"
  },
  {
    "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 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 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_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 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_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_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 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 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 algebra_absapbon1pabsapbleqsumabsaon1pabsa (a b : ℝ) :\n    abs (a + b) / (1 + abs (a + b)) ≤ abs a / (1 + abs a) + abs b / (1 + abs b) := by\n  have h1 : abs (a + b) ≤ abs a + abs b := by\n    apply abs_add\n  have h2 : abs (a + b) / (1 + abs (a + b)) ≤ (abs a + abs b) / (1 + abs a + abs b) := by\n    have h2a : abs (a + b) ≤ abs a + abs b := by\n      apply abs_add\n    have h2b : 0 ≤ abs (a + b) := abs_nonneg (a + b)\n    have h2c : 0 ≤ abs a + abs b := by\n      apply add_nonneg\n      · apply abs_nonneg a\n      · apply abs_nonneg b\n    have h2d : 0 ≤ (1 + abs (a + b)) := by\n      linarith [abs_nonneg (a + b)]\n    have h2e : 0 ≤ (1 + abs a + abs b) := by\n      linarith [abs_nonneg a, abs_nonneg b]\n    have h2f : abs (a + b) / (1 + abs (a + b)) ≤ (abs a + abs b) / (1 + abs a + abs b) := by\n      apply (div_le_div_iff (by linarith) (by linarith)).mpr\n      nlinarith [abs_nonneg (a + b), abs_nonneg a, abs_nonneg b, h2a]\n    exact h2f\n  have h3 : (abs a + abs b) / (1 + abs a + abs b) ≤ abs a / (1 + abs a) + abs b / (1 + abs b) := by\n    have h3a : 0 ≤ (1 + abs a + abs b) := by\n      linarith [abs_nonneg a, abs_nonneg b]\n    have h3b : 0 ≤ (1 + abs a) := by\n      linarith [abs_nonneg a]\n    have h3c : 0 ≤ (1 + abs b) := by\n      linarith [abs_nonneg b]\n    have h4 : (abs a + abs b) / (1 + abs a + abs b) ≤ abs a / (1 + abs a) + abs b / (1 + abs b) := by\n      have h4a : abs a ≥ 0 := abs_nonneg a\n      have h4b : abs b ≥ 0 := abs_nonneg b\n      have h4c : 1 + abs a + abs b > 0 := by linarith [abs_nonneg a, abs_nonneg b]\n      have h4d : 1 + abs a > 0 := by linarith [abs_nonneg a]\n      have h4e : 1 + abs b > 0 := by linarith [abs_nonneg b]\n      have h5 : abs a / (1 + abs a) + abs b / (1 + abs b) - (abs a + abs b) / (1 + abs a + abs b) ≥ 0 := by\n        have h5a : abs a / (1 + abs a) + abs b / (1 + abs b) - (abs a + abs b) / (1 + abs a + abs b) = \n          (abs a * (1 + abs b) * (1 + abs a + abs b) + \n          abs b * (1 + abs a) * (1 + abs a + abs b) - \n          (abs a + abs b) * (1 + abs a) * (1 + abs b)) / \n          ((1 + abs a) * (1 + abs b) * (1 + abs a + abs b)) := by\n          field_simp\n          <;> ring\n        rw [h5a]\n        have h5b : 0 ≤ (abs a * (1 + abs b) * (1 + abs a + abs b) + \n          abs b * (1 + abs a) * (1 + abs a + abs b) - \n          (abs a + abs b) * (1 + abs a) * (1 + abs b)) := by \n          nlinarith [sq_nonneg (abs a), sq_nonneg (abs b), mul_nonneg (abs_nonneg a) (abs_nonneg b)]\n        have h5c : 0 < (1 + abs a) * (1 + abs b) * (1 + abs a + abs b) := by\n          apply mul_pos\n          apply mul_pos\n          · linarith [abs_nonneg a]\n          · linarith [abs_nonneg b]\n          · linarith [abs_nonneg a, abs_nonneg b]\n        apply div_nonneg\n        · linarith\n        · nlinarith [abs_nonneg a, abs_nonneg b]\n      linarith [h5]\n    linarith [h4]\n  linarith [h2, h3]",
    "name": "algebra_absapbon1pabsapbleqsumabsaon1pabsa"
  },
  {
    "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 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_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_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 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_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 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_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_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_400 (x : ℝ) (h₀ : 5 + 500 / 100 * 10 = 110 / 100 * x) : x = 50 := by\n  linarith",
    "name": "mathd_algebra_400"
  },
  {
    "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 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 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"
  }
]