[
  {
    "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 amc12b_2002_p2 (x : ℤ) (h₀ : x = 4) :\n    (3 * x - 2) * (4 * x + 1) - (3 * x - 2) * (4 * x) + 1 = 11 := by \n  rw [h₀]\n  norm_num",
    "name": "amc12b_2002_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1989_p8 (a b c d e f g : ℝ)\n    (h₀ : a + 4 * b + 9 * c + 16 * d + 25 * e + 36 * f + 49 * g = 1)\n    (h₁ : 4 * a + 9 * b + 16 * c + 25 * d + 36 * e + 49 * f + 64 * g = 12)\n    (h₂ : 9 * a + 16 * b + 25 * c + 36 * d + 49 * e + 64 * f + 81 * g = 123) :\n    16 * a + 25 * b + 36 * c + 49 * d + 64 * e + 81 * f + 100 * g = 334 := by\n  \n  have eq1 : 3 * a + 5 * b + 7 * c + 9 * d + 11 * e + 13 * f + 15 * g = 11 := by \n    linarith\n  \n  have eq2 : 5 * a + 7 * b + 9 * c + 11 * d + 13 * e + 15 * f + 17 * g = 111 := by \n    linarith\n\n  have h_sum : a + b + c + d + e + f + g = 50 := by\n    have temp : 2 * a + 2 * b + 2 * c + 2 * d + 2 * e + 2 * f + 2 * g = 100 := by \n      linarith [eq1, eq2]\n    linarith\n\n  have eq3 : 7 * a + 9 * b + 11 * c + 13 * d + 15 * e + 17 * f + 19 * g = 211 := by \n    linarith [eq2, h_sum]\n\n  have h3 : 16 * a + 25 * b + 36 * c + 49 * d + 64 * e + 81 * f + 100 * g = 334 := by \n    linarith [h₂, eq3]\n\n  exact h3",
    "name": "aime_1989_p8"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_299 : 1 * 3 * 5 * 7 * 9 * 11 * 13 % 10 = 5 := by \n  norm_num",
    "name": "mathd_numbertheory_299"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_320 (n : ℕ) (h₀ : n < 101) (h₁ : 101 ∣ 123456 - n) : n = 34 := by\n  have h2 : n = 34 := by \n    omega\n  exact h2",
    "name": "mathd_numbertheory_320"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_288 (x y : ℝ) (n : NNReal) (h₀ : x < 0 ∧ y < 0) (h₁ : abs y = 6)\n    (h₂ : Real.sqrt ((x - 8) ^ 2 + (y - 3) ^ 2) = 15)\n    (h₃ : Real.sqrt (x ^ 2 + y ^ 2) = Real.sqrt n) : n = 52 := by\n        have hy : y = -6 := by\n            cases eq_or_eq_neg_of_abs_eq h₁ with\n            | inl h => linarith [h₀.right]\n            | inr h => linarith\n        have h2' : (x - 8) ^ 2 + (y - 3) ^ 2 = 15 ^ 2 := by\n            calc\n                (x - 8) ^ 2 + (y - 3) ^ 2 = (Real.sqrt ((x - 8) ^ 2 + (y - 3) ^ 2)) ^ 2 := by rw [Real.sq_sqrt]; positivity\n                _ = 15 ^ 2 := by rw [h₂]\n        rw [hy] at h2'\n        have hx_eq : x = -4 := by\n            have h4 : (x - 8) ^ 2 = 144 := by\n                nlinarith\n            have h5 : x - 8 = 12 ∨ x - 8 = -12 := by\n                apply eq_or_eq_neg_of_sq_eq_sq\n                norm_num\n                linarith\n            cases h5 with\n            | inl h12 =>\n                have hx : x = 20 := by linarith\n                linarith [h₀.left, hx]\n            | inr h_neg12 =>\n                have hx : x = -4 := by linarith\n                exact hx\n        have h3 : (x : ℝ) ^ 2 + (y : ℝ) ^ 2 = (n : ℝ) := by\n            have h3_1 : Real.sqrt (x^2 + y^2) = Real.sqrt n := h₃\n            have h3_2 : (x^2 + y^2 : ℝ) = (n : ℝ) := by\n                have h4 : (Real.sqrt (x ^ 2 + y ^ 2)) ^ 2 = (Real.sqrt n) ^ 2 := by rw [h3_1]\n                rw [Real.sq_sqrt (by positivity), Real.sq_sqrt (by positivity)] at h4\n                linarith\n            exact_mod_cast h3_2\n        rw [hx_eq, hy] at h3\n        norm_num at h3\n        have hn : (n : ℝ) = 52 := by linarith\n        exact_mod_cast hn",
    "name": "mathd_algebra_288"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_296 (n : ℕ) (h₀ : 2 ≤ n) (h₁ : ∃ x, x ^ 3 = n) (h₂ : ∃ t, t ^ 4 = n) :\n    4096 ≤ n := by \n  rcases h₁ with ⟨x, hx⟩\n  rcases h₂ with ⟨t, ht⟩\n  by_contra h\n  push_neg at h\n  have h3 : n < 4096 := h\n  have h4 : x ^ 3 = t ^ 4 := by linarith\n  have h5 : x ≤ 15 := by\n    have h6 : x ^ 3 < 4096 := by linarith\n    by_contra h7\n    push_neg at h7\n    have h8 : x ^ 3 ≥ 4096 := by\n      have h9 : x ≥ 16 := by linarith\n      have h10 : x ^ 3 ≥ 16 ^ 3 := by\n        apply Nat.pow_le_pow_of_le_left h9 3\n      norm_num at h10\n      linarith\n    linarith\n  have h6 : t ≤ 7 := by\n    have h7 : t ^ 4 < 4096 := by linarith\n    by_contra h8\n    push_neg at h8\n    have h9 : t ≥ 8 := by linarith\n    have h10 : t ^ 4 ≥ 4096 := by\n      have h11 : t ^ 4 ≥ 8 ^ 4 := by\n        apply Nat.pow_le_pow_of_le_left h9 4\n      norm_num at h11\n      linarith\n    linarith\n  interval_cases x <;> interval_cases t <;> omega",
    "name": "mathd_numbertheory_296"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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 algebra_others_exirrpowirrrat : ∃ a b, Irrational a ∧ Irrational b ∧ ¬Irrational (a ^ b) := by\n  by_cases h : Irrational ((Real.sqrt 2) ^ (Real.sqrt 2 : ℝ))\n  · -- Assume $\\sqrt{2}^{\\sqrt{2}}$ is irrational\n    use (Real.sqrt 2) ^ (Real.sqrt 2 : ℝ), Real.sqrt 2\n    constructor\n    · -- Show that $\\sqrt{2}^{\\sqrt{2}}$ is irrational (from assumption)\n      exact h\n    constructor\n    · -- Show that $\\sqrt{2}$ is irrational\n      apply irrational_sqrt_two\n    · -- Show that $(\\sqrt{2}^{\\sqrt{2}})^{\\sqrt{2}}$ is rational\n      have h1 : Real.sqrt 2 > (0 : ℝ) := by\n        apply Real.sqrt_pos.mpr\n        norm_num\n      have h2 : ((Real.sqrt 2) ^ (Real.sqrt 2 : ℝ)) ^ (Real.sqrt 2 : ℝ) = (Real.sqrt 2) ^ ((Real.sqrt 2 : ℝ) * (Real.sqrt 2 : ℝ)) := by\n        rw [Real.rpow_mul]\n        all_goals linarith [h1]\n      have h3 : (Real.sqrt 2 : ℝ) * (Real.sqrt 2 : ℝ) = (2 : ℝ) := by\n        exact Real.mul_self_sqrt (by norm_num)\n      rw [h2, h3]\n      have h4 : (Real.sqrt 2 : ℝ) ^ (2 : ℝ) = (2 : ℝ) := by\n        rw [show (2 : ℝ) = (2 : ℕ) by norm_num]\n        simp [Real.rpow_natCast, Real.sq_sqrt]\n        all_goals norm_num\n      rw [h4]\n      norm_num\n  · -- Assume $\\sqrt{2}^{\\sqrt{2}}$ is rational\n    use Real.sqrt 2, Real.sqrt 2\n    constructor\n    · -- Show that $\\sqrt{2}$ is irrational\n      apply irrational_sqrt_two\n    constructor\n    · -- Show that $\\sqrt{2}$ is irrational\n      apply irrational_sqrt_two\n    · -- Show that $\\sqrt{2}^{\\sqrt{2}}$ is rational\n      simpa using h",
    "name": "algebra_others_exirrpowirrrat"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem numbertheory_x5neqy2p4 (x y : ℤ) : x ^ 5 ≠ y ^ 2 + 4 := by\n  by_contra h\n  have h1 : x ^ 5 % 11 = 0 ∨ x ^ 5 % 11 = 1 ∨ x ^ 5 % 11 = 10 := by \n    have h1 : x % 11 = 0 ∨ x % 11 = 1 ∨ x % 11 = 2 ∨ x % 11 = 3 ∨ x % 11 = 4 ∨ x % 11 = 5 ∨ x % 11 = 6 ∨ x % 11 = 7 ∨ x % 11 = 8 ∨ x % 11 = 9 ∨ x % 11 = 10 := by \n      omega \n    rcases h1 with (h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1 | h1) <;> ( \n      norm_num [h1, pow_succ, Int.add_emod, Int.sub_emod, Int.mul_emod] at * \n    )\n  have h2 : (y ^ 2 + 4) % 11 = 2 ∨ (y ^ 2 + 4) % 11 = 4 ∨ (y ^ 2 + 4) % 11 = 5 ∨ (y ^ 2 + 4) % 11 = 6 ∨ (y ^ 2 + 4) % 11 = 7 ∨ (y ^ 2 + 4) % 11 = 8 ∨ (y ^ 2 + 4) % 11 = 9 := by \n    have h2 : y % 11 = 0 ∨ y % 11 = 1 ∨ y % 11 = 2 ∨ y % 11 = 3 ∨ y % 11 = 4 ∨ y % 11 = 5 ∨ y % 11 = 6 ∨ y % 11 = 7 ∨ y % 11 = 8 ∨ y % 11 = 9 ∨ y % 11 = 10 := by \n      omega \n    rcases h2 with (h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2 | h2) <;> ( \n      norm_num [h2, pow_succ, Int.add_emod, Int.sub_emod, Int.mul_emod] at * \n    )\n  -- Using omega to derive the contradiction from modular constraints\n  omega",
    "name": "numbertheory_x5neqy2p4"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem 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 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 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 amc12_2000_p20 (x y z : ℝ) (h₀ : 0 < x ∧ 0 < y ∧ 0 < z) (h₁ : x + 1 / y = 4)\n    (h₂ : y + 1 / z = 1) (h₃ : z + 1 / x = 7 / 3) : x * y * z = 1 := by\n  have pos_x : 0 < x := h₀.left\n  have pos_y : 0 < y := h₀.right.left\n  have pos_z : 0 < z := h₀.right.right\n  have eq1 : x * y + 1 = 4 * y := by \n    field_simp at h₁\n    nlinarith\n  have eq2 : y * z + 1 = z := by \n    field_simp at h₂\n    nlinarith [pos_z]\n  have eq3 : z * x + 1 = (7 / 3) * x := by \n    field_simp at h₃\n    nlinarith [pos_x]\n  have sum_eq : x + 1 / y + y + 1 / z + z + 1 / x = 22 / 3 := by\n    have h1 := h₁\n    have h2 := h₂\n    have h3 := h₃\n    have h4 : x + 1 / y + (y + 1 / z) + (z + 1 / x) = 4 + 1 + (7 / 3 : ℝ) := by\n      linarith [h₁, h₂, h₃]\n    have h5 : x + 1 / y + (y + 1 / z) + (z + 1 / x) = x + 1 / y + y + 1 / z + z + 1 / x := by\n      ring\n    rw [h5] at h4\n    linarith\n  have h4 : (x + 1 / y) * (y + 1 / z) * (z + 1 / x) = 4 * 1 * (7 / 3 : ℝ) := by\n    rw [h₁, h₂, h₃]\n  have eq4 : (x + 1 / y) * (y + 1 / z) * (z + 1 / x) = x * y * z + (x + 1 / y + y + 1 / z + z + 1 / x) + 1 / (x * y * z) := by\n    field_simp\n    ring_nf\n  rw [eq4] at h4\n  have eq5 : x * y * z + 1 / (x * y * z) = 2 := by\n    have h_sum : x + 1 / y + y + 1 / z + z + 1 / x = 22 / 3 := sum_eq\n    have h_eq : x * y * z + (x + 1 / y + y + 1 / z + z + 1 / x) + 1 / (x * y * z) = 28 / 3 := by\n      linarith\n    rw [h_sum] at h_eq\n    have h : x * y * z + 1 / (x * y * z) = 2 := by\n      linarith\n    exact h\n  have pos_xyz : x * y * z ≠ 0 := by\n    apply mul_ne_zero\n    apply mul_ne_zero\n    · linarith\n    · linarith\n    · linarith\n  have h5 : x * y * z = 1 := by\n    have h6 : x * y * z = 1 := by\n      have h7 : x * y * z > 0 := by\n        apply mul_pos\n        apply mul_pos\n        · linarith\n        · linarith\n        · linarith\n      have h8 : x * y * z > 0 := h7\n      have h9 : x * y * z ≠ 0 := pos_xyz\n      have h10 : (x * y * z - 1) ^ 2 = 0 := by\n        have h11 : x * y * z + 1 / (x * y * z) = 2 := eq5\n        field_simp at h11\n        nlinarith [sq_nonneg (x * y * z - 1)]\n      have h12 : x * y * z - 1 = 0 := by\n        rw [sq_eq_zero_iff] at h10\n        exact h10\n      linarith\n    exact h6\n  exact h5",
    "name": "amc12_2000_p20"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_559 (x y : ℕ) (h₀ : x % 3 = 2) (h₁ : y % 5 = 4) (h₂ : x % 10 = y % 10) :\n    14 ≤ x := by\n  have hy1 : y % 10 = 4 ∨ y % 10 = 9 := by\n    have h4 : y % 5 = 4 := h₁\n    omega\n  rcases hy1 with hy1 | hy1\n  · -- Case 1: y % 10 = 4\n    have hx1 : x % 10 = 4 := by omega\n    omega\n  · -- Case 2: y % 10 = 9\n    have hx1 : x % 10 = 9 := by omega\n    omega",
    "name": "mathd_numbertheory_559"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem 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 algebra_sqineq_unitcircatbpamblt1 (a b : ℝ) (h₀ : a ^ 2 + b ^ 2 = 1) :\n    a * b + (a - b) ≤ 1 := by\n  have h1 : a ≤ 1 := by\n    nlinarith [sq_nonneg (a - 1), sq_nonneg b, h₀]\n  have h2 : b ≥ -1 := by \n    nlinarith [sq_nonneg (b + 1), sq_nonneg a, h₀]\n  have h3 : (a - 1) * (b + 1) ≤ 0 := by\n    apply mul_nonpos_of_nonpos_of_nonneg\n    · linarith \n    · linarith\n  have h4 : a * b + (a - b) ≤ 1 := by \n    nlinarith [h3]\n  exact h4",
    "name": "algebra_sqineq_unitcircatbpamblt1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 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_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 amc12_2000_p6 (p q : ℕ) (h₀ : Nat.Prime p ∧ Nat.Prime q) (h₁ : 4 ≤ p ∧ p ≤ 18)\n    (h₂ : 4 ≤ q ∧ q ≤ 18) : ↑p * ↑q - (↑p + ↑q) ≠ (194 : ℕ) := by\n\n  rcases h₀ with ⟨hp, hq⟩\n  rcases h₁ with ⟨hp_ge, hp_le⟩\n  rcases h₂ with ⟨hq_ge, hq_le⟩\n  interval_cases p <;> interval_cases q <;> norm_num at *\n  <;> try { tauto }",
    "name": "amc12_2000_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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_numbertheory_85 : 1 * 3 ^ 3 + 2 * 3 ^ 2 + 2 * 3 + 2 = 53 := by\n  norm_num -- This tactic computes the arithmetic expression directly",
    "name": "mathd_numbertheory_85"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_156 (x y : ℝ) (f g : ℝ → ℝ) (h₀ : ∀ t, f t = t ^ 4)\n    (h₁ : ∀ t, g t = 5 * t ^ 2 - 6) (h₂ : f x = g x) (h₃ : f y = g y) (h₄ : x ^ 2 < y ^ 2) :\n    y ^ 2 - x ^ 2 = 1 := by\n  have eq1 : x^4 = 5 * x^2 - 6 := by\n    rw [h₀, h₁] at h₂\n    linarith\n  have eq2 : y^4 = 5 * y^2 - 6 := by\n    rw [h₀, h₁] at h₃\n    linarith\n\n  have h5 : (x^2 - 2) * (x^2 - 3) = 0 := by\n    have h1 : x^4 - 5 * x^2 + 6 = 0 := by linarith\n    have h2 : x^4 - 5 * x^2 + 6 = (x^2 - 2) * (x^2 - 3) := by \n      ring\n    nlinarith\n  \n  have h6 : (y^2 - 2) * (y^2 - 3) = 0 := by\n    have h1 : y^4 - 5 * y^2 + 6 = 0 := by linarith\n    have h2 : y^4 - 5 * y^2 + 6 = (y^2 - 2) * (y^2 - 3) := by \n      ring\n    nlinarith\n\n  have hx2 : x^2 = 2 ∨ x^2 = 3 := by\n    cases (mul_eq_zero.mp h5) with\n    | inl h => \n      left\n      nlinarith \n    | inr h => \n      right\n      nlinarith\n  \n  have hy2 : y^2 = 2 ∨ y^2 = 3 := by\n    cases (mul_eq_zero.mp h6) with\n    | inl h => \n      left\n      nlinarith \n    | inr h => \n      right\n      nlinarith\n\n  cases hx2 with\n  | inl hx2l =>\n    cases hy2 with\n    | inl hy2l =>\n      exfalso\n      nlinarith\n    | inr hy2r =>\n      have h : y^2 - x^2 = 1 := by\n        rw [hy2r, hx2l]\n        linarith\n      linarith\n  | inr hx2r =>\n    cases hy2 with\n    | inl hy2l =>\n      exfalso\n      nlinarith\n    | inr hy2r =>\n      exfalso\n      nlinarith",
    "name": "mathd_algebra_156"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem aime_1983_p1 (x y z w : ℕ) (ht : 1 < x ∧ 1 < y ∧ 1 < z) (hw : 0 ≤ w)\n    (h0 : Real.log w / Real.log x = 24) (h1 : Real.log w / Real.log y = 40)\n    (h2 : Real.log w / Real.log (x * y * z) = 12) : Real.log w / Real.log z = 60 := by\n\n        have hx_pos : (x : ℝ) > (1 : ℝ) := by exact_mod_cast ht.left\n        have hy_pos : (y : ℝ) > (1 : ℝ) := by exact_mod_cast ht.right.left\n        have hz_pos : (z : ℝ) > (1 : ℝ) := by exact_mod_cast ht.right.right\n\n        have h31 : Real.log x ≠ 0 := by\n            have h_log_x_pos : Real.log x > 0 := by\n                apply Real.log_pos\n                norm_num\n                linarith\n            linarith\n\n        have h41 : Real.log y ≠ 0 := by\n            have h_log_y_pos : Real.log y > 0 := by\n                apply Real.log_pos\n                norm_num\n                linarith\n            linarith\n\n        have h51 : Real.log (x * y * z) ≠ 0 := by\n            have h_log_x_y_z_pos : Real.log (x * y * z) > 0 := by\n                have h1 : Real.log (x * y * z) = Real.log (x * y) + Real.log z := by\n                    rw [Real.log_mul (by positivity) (by positivity)]\n                have h2 : Real.log (x * y) = Real.log x + Real.log y := by\n                    rw [Real.log_mul (by positivity) (by positivity)]\n                have h3 : Real.log x > 0 := by\n                    apply Real.log_pos\n                    norm_num\n                    linarith\n                have h4 : Real.log y > 0 := by\n                    apply Real.log_pos\n                    norm_num\n                    linarith\n                have h5 : Real.log z > 0 := by\n                    apply Real.log_pos\n                    norm_num\n                    linarith\n                have h6 : Real.log (x * y) > 0 := by linarith [h3, h4]\n                have h7 : Real.log (x * y * z) > 0 := by linarith [h1, h6, h5]\n                linarith\n            linarith\n\n        have h3 : Real.log w = 24 * Real.log x := by\n            have eq1 : Real.log w = 24 * Real.log x := by\n                field_simp [h31] at h0\n                linarith\n            exact eq1\n\n        have h4 : Real.log w = 40 * Real.log y := by\n            have eq1 : Real.log w = 40 * Real.log y := by\n                field_simp [h41] at h1\n                linarith\n            exact eq1\n\n        have h5 : Real.log w = 12 * Real.log (x * y * z) := by\n            have eq1 : Real.log w = 12 * Real.log (x * y * z) := by\n                field_simp [h51] at h2\n                linarith\n            exact eq1\n\n        have h6 : Real.log (x * y * z) = Real.log x + Real.log y + Real.log z := by\n            rw [Real.log_mul (by positivity) (by positivity), Real.log_mul (by positivity) (by positivity)]\n            all_goals linarith\n\n        rw [h6] at h5\n\n        have h7 : Real.log z ≠ 0 := by\n            have hz1 : (z : ℝ) > (1 : ℝ) := by exact_mod_cast ht.right.right\n            have h_pos : Real.log z > 0 := by\n                apply Real.log_pos\n                norm_num\n                linarith\n            linarith\n\n        have h8 : Real.log z = (2 / 3) * Real.log y := by\n            have eq1 : Real.log x = (5 / 3) * Real.log y := by\n                have h10 : Real.log w = 24 * Real.log x := by linarith [h3]\n                have h11 : Real.log w = 40 * Real.log y := by linarith [h4]\n                have h12 : 24 * Real.log x = 40 * Real.log y := by linarith [h10, h11]\n                linarith\n\n            have eq2 : Real.log x = Real.log y + Real.log z := by\n                have h13 : Real.log w = 24 * Real.log x := by linarith [h3]\n                have h14 : Real.log w = 12 * (Real.log x + Real.log y + Real.log z) := by linarith [h5]\n                have h15 : 24 * Real.log x = 12 * (Real.log x + Real.log y + Real.log z) := by linarith [h13, h14]\n                have h16 : Real.log x = Real.log y + Real.log z := by\n                    nlinarith\n                exact h16\n\n            have eq3 : Real.log z = (2 / 3) * Real.log y := by\n                linarith [eq1, eq2]\n            linarith\n\n        have h9 : Real.log w / Real.log z = 60 := by\n            have h21 : Real.log z ≠ 0 := by exact h7\n            have h23 : Real.log w = 40 * Real.log y := by linarith [h4]\n            have h24 : Real.log z = (2 / 3) * Real.log y := by linarith [h8]\n            have h25 : Real.log w / Real.log z = 60 := by\n                have h26 : Real.log z ≠ 0 := by exact h7\n                have h27 : Real.log w = 60 * Real.log z := by\n                    linarith [h23, h24]\n                have h28 : Real.log w / Real.log z = 60 := by\n                    field_simp [h26]\n                    linarith [h27]\n                exact h28\n            exact h25\n\n        exact h9",
    "name": "aime_1983_p1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_332 (x y : ℝ) (h₀ : (x + y) / 2 = 7) (h₁ : Real.sqrt (x * y) = Real.sqrt 19) :\n    x ^ 2 + y ^ 2 = 158 := by\n\n  have h2 : x + y = 14 := by linarith\n\n  have h3 : x * y = 19 := by\n    have h4 : Real.sqrt (x * y) = Real.sqrt 19 := h₁\n    have h5 : x * y ≥ 0 := by\n      have h6 : Real.sqrt 19 > 0 := by\n        apply Real.sqrt_pos.2\n        norm_num\n      have h7 : Real.sqrt (x * y) > 0 := by linarith [h₁, h6]\n      have h8 : Real.sqrt (x * y) ≥ 0 := Real.sqrt_nonneg (x * y)\n      by_contra h9\n      push_neg at h9\n      have h10 : Real.sqrt (x * y) = 0 := by\n        apply Real.sqrt_eq_zero_of_nonpos\n        linarith\n      linarith\n    have h9 : (19 : ℝ) ≥ 0 := by norm_num\n    have h11 : x * y = 19 := by\n      have h10 : Real.sqrt (x * y) = Real.sqrt 19 := h₁\n      have h12 : x * y = 19 := by\n        have h13 : x * y ≥ 0 := by linarith\n        have h14 : (19 : ℝ) ≥ 0 := by norm_num\n        have h15 : Real.sqrt (x * y) = Real.sqrt 19 := h₁\n        have h16 : x * y = 19 := by\n          rw [Real.sqrt_inj (by linarith) (by linarith)] at h15\n          linarith\n        linarith\n      linarith\n    linarith\n  have h4 : x^2 + y^2 = (x + y) ^ 2 - 2 * (x * y) := by\n    ring\n  rw [h4, h2, h3]\n  norm_num",
    "name": "mathd_algebra_332"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem 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_algebra_170 (S : Finset ℤ) (h₀ : ∀ n : ℤ, n ∈ S ↔ abs (n - 2) ≤ 5 + 6 / 10) :\n    S.card = 11 := by \n  have h1 : S = {-3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7} := by \n    ext n\n    simp [h₀]\n    constructor\n    · -- Assume $n \\in S$, we need to prove $n \\in \\{-3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7\\}$\n      intro h\n      rw [abs_le] at h\n      norm_num at h \n      have h1 : -3 ≤ n := by linarith \n      have h2 : n ≤ 7 := by linarith \n      have h3 : n = -3 ∨ n = -2 ∨ n = -1 ∨ n = 0 ∨ n = 1 ∨ n = 2 ∨ n = 3 ∨ n = 4 ∨ n = 5 ∨ n = 6 ∨ n = 7 := by \n        omega \n      exact h3\n    · -- Assume $n \\in \\{-3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 7\\}$, we need to prove $n \\in S$\n      rintro (rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl | rfl)\n      · -- n = -3\n        norm_num [abs_le]\n      · -- n = -2\n        norm_num [abs_le]\n      · -- n = -1\n        norm_num [abs_le]\n      · -- n = 0\n        norm_num [abs_le]\n      · -- n = 1\n        norm_num [abs_le]\n      · -- n = 2\n        norm_num [abs_le]\n      · -- n = 3\n        norm_num [abs_le]\n      · -- n = 4\n        norm_num [abs_le]\n      · -- n = 5\n        norm_num [abs_le]\n      · -- n = 6\n        norm_num [abs_le]\n      · -- n = 7\n        norm_num [abs_le]\n  rw [h1]\n  native_decide",
    "name": "mathd_algebra_170"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_354 (a d : ℝ) (h₀ : a + 6 * d = 30) (h₁ : a + 10 * d = 60) :\n    a + 20 * d = 135 := by \n  linarith",
    "name": "mathd_algebra_354"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_618 (n : ℕ) (hn : n > 0) (p : ℕ → ℕ) (h₀ : ∀ x, p x = x ^ 2 - x + 41)\n    (h₁ : 1 < Nat.gcd (p n) (p (n + 1))) : 41 ≤ n := by\n  have h2 : p n = n ^ 2 - n + 41 := h₀ n\n  have h3 : p (n + 1) = (n + 1) ^ 2 - (n + 1) + 41 := h₀ (n + 1)\n  rw [h2, h3] at h₁\n  by_contra h\n  push_neg at h\n  interval_cases n <;> norm_num [h₀] at h₁ <;> contradiction",
    "name": "mathd_numbertheory_618"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_148 (c : ℝ) (f : ℝ → ℝ) (h₀ : ∀ x, f x = c * x ^ 3 - 9 * x + 3)\n    (h₁ : f 2 = 9) : c = 3 := by\n  have h2 : f 2 = c * 2^3 - 9 * 2 + 3 := h₀ 2\n  rw [h2] at h₁\n  norm_num at h₁\n  linarith",
    "name": "mathd_algebra_148"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_100 (n : ℕ) (h₀ : 0 < n) (h₁ : Nat.gcd n 40 = 10)\n    (h₂ : Nat.lcm n 40 = 280) : n = 70 := by \n  have h3 : n.gcd 40 * n.lcm 40 = n * 40 := by\n    rw [Nat.gcd_mul_lcm]\n  rw [h₁, h₂] at h3\n  have h4 : n = 70 := by\n    linarith\n  exact h4",
    "name": "mathd_numbertheory_100"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 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 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 mathd_numbertheory_345 : (2000 + 2001 + 2002 + 2003 + 2004 + 2005 + 2006) % 7 = 0 := by \n  norm_num",
    "name": "mathd_numbertheory_345"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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 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 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_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 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 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 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_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 imo_1960_p2 (x : ℝ) (h₀ : 0 ≤ 1 + 2 * x) (h₁ : (1 - Real.sqrt (1 + 2 * x)) ^ 2 ≠ 0)\n    (h₂ : 4 * x ^ 2 / (1 - Real.sqrt (1 + 2 * x)) ^ 2 < 2 * x + 9) : -(1 / 2) ≤ x ∧ x < 45 / 8 := by\n  have h3 : 0 ≤ Real.sqrt (1 + 2 * x) := Real.sqrt_nonneg (1 + 2 * x)\n  have h4 : (1 - Real.sqrt (1 + 2 * x)) ≠ 0 := by\n    intro h\n    have : (1 - Real.sqrt (1 + 2 * x)) ^ 2 = 0 := by\n      rw [h]\n      ring\n    contradiction\n  have h5 : (1 - Real.sqrt (1 + 2 * x)) ^ 2 > 0 := by\n    apply pow_two_pos_of_ne_zero\n    exact h4\n  have h6 : 4 * x^2 < (2 * x + 9) * (1 - Real.sqrt (1 + 2 * x)) ^ 2 := by\n    have h_pos : 0 < (1 - Real.sqrt (1 + 2 * x)) ^ 2 := by linarith\n    apply (div_lt_iff h_pos).mp at h₂\n    nlinarith\n  have h8 : x < 45 / 8 := by\n    by_contra h\n    push_neg at h\n    have h9 : Real.sqrt (1 + 2 * x) ≥ 7 / 2 := by\n      have h10 : 1 + 2 * x ≥ (7 / 2) ^ 2 := by\n        nlinarith [h]\n      have h11 : Real.sqrt (1 + 2 * x) ≥ Real.sqrt ((7 / 2) ^ 2) := Real.sqrt_le_sqrt (by linarith)\n      have h12 : Real.sqrt ((7 / 2) ^ 2) = 7 / 2 := by\n        rw [Real.sqrt_sq]\n        all_goals linarith\n      linarith\n    have h13 : (1 - Real.sqrt (1 + 2 * x)) ^ 2 ≥ (5 / 2) ^ 2 := by\n      nlinarith [h9, Real.sqrt_nonneg (1 + 2 * x)]\n    nlinarith [h6, h13, sq_nonneg (Real.sqrt (1 + 2 * x)), sq_nonneg (x - 45 / 8), Real.sq_sqrt (show 0 ≤ 1 + 2 * x by linarith)]\n  have h14 : -(1 / 2) ≤ x := by linarith\n  exact ⟨h14, h8⟩",
    "name": "imo_1960_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_153 (n : ℝ) (h₀ : n = 1 / 3) :\n    Int.floor (10 * n) + Int.floor (100 * n) + Int.floor (1000 * n) + Int.floor (10000 * n) = 3702 := by \n  rw [h₀]\n  norm_num [Int.floor_eq_iff]",
    "name": "mathd_algebra_153"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 amc12b_2021_p18 (z : ℂ)\n    (h₀ : 12 * Complex.normSq z = 2 * Complex.normSq (z + 2) + Complex.normSq (z ^ 2 + 1) + 31) :\n    z + 6 / z = -2 := by\n\n  have hne : z ≠ 0 := by\n    by_contra h\n    rw [h] at h₀\n    simp [Complex.normSq] at h₀\n    all_goals linarith\n\n  have h1 : z.re ^ 2 + z.im ^ 2 = 6 := by\n    have eq1 := h₀\n    simp [Complex.normSq, pow_two, Complex.add_re, Complex.add_im, Complex.mul_re, Complex.mul_im, Complex.ofReal_re, Complex.ofReal_im] at eq1\n    nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), sq_nonneg (z.re ^ 2 + z.im ^ 2 - 6)]\n\n  have h2 : z.re = -1 := by\n    have eq1 := h₀\n    simp [Complex.normSq, pow_two, Complex.add_re, Complex.add_im, Complex.mul_re, Complex.mul_im, Complex.ofReal_re, Complex.ofReal_im] at eq1\n    have h_eq : (z.re + 1) ^ 2 + (z.im ^ 2 - 5) ^ 2 = 0 := by \n      nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), h1]\n    have h_re : (z.re + 1) ^ 2 = 0 := by nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), h_eq]\n    have h_im : (z.im ^ 2 - 5) ^ 2 = 0 := by nlinarith [sq_nonneg (z.re + 1), sq_nonneg (z.im ^ 2 - 5), h_eq]\n    have h_re_zero : z.re + 1 = 0 := by nlinarith [h_re]\n    linarith\n\n  have him : z.im ^ 2 = 5 := by \n    have h_re : z.re = -1 := h2\n    have h : z.re ^ 2 + z.im ^ 2 = 6 := h1\n    rw [h_re] at h\n    nlinarith\n\n  have h3 : z + 6 / z = -2 := by \n    have hz_ne_zero : z ≠ 0 := hne\n    have hz_re : z.re = -1 := h2\n    have hz_im_sq : z.im ^ 2 = 5 := him\n\n    have h2 : z.im = Real.sqrt 5 ∨ z.im = -Real.sqrt 5 := by\n      have h3 : z.im ^ 2 - 5 = 0 := by linarith\n      have h4 : z.im ^ 2 = 5 := by linarith\n      have h5 : z.im = Real.sqrt 5 ∨ z.im = -Real.sqrt 5 := by \n        apply eq_or_eq_neg_of_sq_eq_sq\n        norm_num\n        linarith\n      exact h5\n\n    cases h2 with\n    | inl him_pos =>\n      have him : z.im = Real.sqrt 5 := him_pos\n      have hz : z = -1 + Real.sqrt 5 * Complex.I := by \n        rw [Complex.ext_iff]\n        simp [hz_re, him]\n      rw [hz]\n      field_simp [Complex.ext_iff, hz_re, him, mul_add, pow_two, Complex.I_mul_I]\n      <;> ring_nf <;> norm_num [Real.sq_sqrt]\n    \n    | inr him_neg =>\n      have him : z.im = -Real.sqrt 5 := him_neg\n      have hz : z = -1 + (-Real.sqrt 5) * Complex.I := by \n        rw [Complex.ext_iff]\n        simp [hz_re, him]\n      rw [hz]\n      field_simp [Complex.ext_iff, hz_re, him, mul_add, pow_two, Complex.I_mul_I]\n      <;> ring_nf <;> norm_num [Real.sq_sqrt]\n    \n  exact h3",
    "name": "amc12b_2021_p18"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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_numbertheory_541 (m n : ℕ) (h₀ : 1 < m) (h₁ : 1 < n) (h₂ : m * n = 2005) :\n    m + n = 406 := by\n  have h3 : m ≤ 2005 := by nlinarith\n  have h4 : n ≤ 2005 := by nlinarith\n  interval_cases m <;> omega",
    "name": "mathd_numbertheory_541"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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_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 amc12a_2021_p14 :\n    ((∑ k in Finset.Icc 1 20, Real.logb (5 ^ k) (3 ^ k ^ 2)) *\n        ∑ k in Finset.Icc 1 100, Real.logb (9 ^ k) (25 ^ k)) = 21000 := by\n\n  have h1 : (∑ k in Finset.Icc 1 20, Real.logb (5 ^ k) (3 ^ k ^ 2)) = (210 : ℝ) * (Real.logb 5 3) := by\n    simp [Finset.sum_Icc_succ_top, Real.logb]\n    <;> ring_nf <;> field_simp <;> ring\n    <;> norm_num\n\n  have h2 : (∑ k in Finset.Icc 1 100, Real.logb (9 ^ k) (25 ^ k)) = (100 : ℝ) * (Real.logb 9 25) := by\n    simp [Finset.sum_Icc_succ_top, Real.logb]\n    <;> ring_nf <;> field_simp <;> ring\n    <;> norm_num\n\n  rw [h1, h2]\n  \n  have h3 : Real.logb 9 25 = Real.logb 3 5 := by\n    have h31 : Real.logb 9 25 = Real.log 25 / Real.log 9 := by\n      simp [Real.logb]\n    have h32 : Real.logb 3 5 = Real.log 5 / Real.log 3 := by\n      simp [Real.logb]\n    rw [h31, h32]\n    have h33 : Real.log 25 = 2 * Real.log 5 := by\n      rw [show (25 : ℝ) = 5 ^ 2 by norm_num]\n      simp [Real.log_pow]\n    have h34 : Real.log 9 = 2 * Real.log 3 := by\n      rw [show (9 : ℝ) = 3 ^ 2 by norm_num]\n      simp [Real.log_pow]\n    rw [h33, h34]\n    ring\n  \n  rw [h3]\n  have h4 : Real.logb 5 3 * Real.logb 3 5 = 1 := by\n    have h41 : Real.logb 5 3 = Real.log 3 / Real.log 5 := by\n      simp [Real.logb]\n    have h42 : Real.logb 3 5 = Real.log 5 / Real.log 3 := by\n      simp [Real.logb]\n    rw [h41, h42]\n    field_simp\n\n  have h5 : (210 : ℝ) * Real.logb 5 3 * (100 : ℝ) * Real.logb 3 5 = 21000 := by\n    have h51 : (210 : ℝ) * Real.logb 5 3 * (100 : ℝ) * Real.logb 3 5 = \n        (210 * 100 : ℝ) * (Real.logb 5 3 * Real.logb 3 5) := by ring\n    rw [h51]\n    have h52 : Real.logb 5 3 * Real.logb 3 5 = 1 := by \n      linarith [h4]\n    rw [h52]\n    norm_num\n  \n  linarith [h5]",
    "name": "amc12a_2021_p14"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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_algebra_160 (n x : ℝ) (h₀ : n + x = 97) (h₁ : n + 5 * x = 265) : n + 2 * x = 139 := by \n  linarith",
    "name": "mathd_algebra_160"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_137 (x : ℕ) (h₀ : ↑x + (4 : ℝ) / (100 : ℝ) * ↑x = 598) : x = 575 := by \n  have h1 : (x : ℝ) + (4 : ℝ) / (100 : ℝ) * (x : ℝ) = 598 := by \n    exact_mod_cast h₀\n  have hx : (x : ℝ) = 575 := by \n    linarith\n  exact_mod_cast hx",
    "name": "mathd_algebra_137"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_175 : 2 ^ 2010 % 10 = 4 := by \n  norm_num",
    "name": "mathd_numbertheory_175"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 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_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 amc12b_2020_p2 :\n    (100 ^ 2 - 7 ^ 2 : ℝ) / (70 ^ 2 - 11 ^ 2) * ((70 - 11) * (70 + 11) / ((100 - 7) * (100 + 7))) =\n      1 := by \n  norm_num",
    "name": "amc12b_2020_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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 aime_1983_p2 (x p : ℝ) (f : ℝ → ℝ) (h₀ : 0 < p ∧ p < 15) (h₁ : p ≤ x ∧ x ≤ 15)\n    (h₂ : f x = abs (x - p) + abs (x - 15) + abs (x - p - 15)) : 15 ≤ f x := by\n  have h3 : abs (x - p) = x - p := by\n    rw [abs_of_nonneg]\n    linarith [h₁.left]\n  have h4 : abs (x - 15) = -(x - 15) := by\n    rw [abs_of_nonpos]\n    linarith [h₁.right]\n  have h5 : abs (x - p - 15) = -(x - p - 15) := by\n    rw [abs_of_nonpos]\n    have h6 : x - p - 15 ≤ 0 := by linarith [h₁.right, h₀.left]\n    linarith\n  rw [h₂, h3, h4, h5]\n  linarith [h₁.right]",
    "name": "aime_1983_p2"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1963_p5 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) = 1 / 2 := by\n  have h : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) = 1 / 2 := by\n    have h1 : Real.cos (Real.pi / 7) > 0 := by\n      apply Real.cos_pos_of_mem_Ioo\n      constructor\n      · linarith [Real.pi_pos]\n      · linarith [Real.pi_pos]\n    have h2 : Real.cos (2 * Real.pi / 7) > 0 := by\n      apply Real.cos_pos_of_mem_Ioo\n      constructor\n      · linarith [Real.pi_pos]\n      · linarith [Real.pi_pos]\n    have h3 : Real.cos (3 * Real.pi / 7) > 0 := by\n      apply Real.cos_pos_of_mem_Ioo\n      constructor\n      · linarith [Real.pi_pos]\n      · linarith [Real.pi_pos]\n    have h4 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) = 1 / 2 := by\n      have h5 : Real.sin (Real.pi / 7) > 0 := by\n        apply Real.sin_pos_of_pos_of_lt_pi\n        · linarith [Real.pi_pos]\n        · linarith [Real.pi_pos]\n      have h6 : 2 * Real.sin (Real.pi / 7) * (Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2) = 0 := by\n        have h1 : 2 * Real.sin (Real.pi / 7) * (Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2) =\n            (2 * Real.sin (Real.pi / 7) * Real.cos (Real.pi / 7)) -\n            (2 * Real.sin (Real.pi / 7) * Real.cos (2 * Real.pi / 7)) +\n            (2 * Real.sin (Real.pi / 7) * Real.cos (3 * Real.pi / 7)) -\n            (2 * Real.sin (Real.pi / 7) * (1 / 2)) := by ring\n        rw [h1]\n        have h2 : 2 * Real.sin (Real.pi / 7) * Real.cos (Real.pi / 7) = Real.sin (2 * Real.pi / 7) := by\n          have h_sin2 : Real.sin (2 * Real.pi / 7) = 2 * Real.sin (Real.pi / 7) * Real.cos (Real.pi / 7) := by\n            rw [show 2 * Real.pi / 7 = 2 * (Real.pi / 7) by ring]\n            rw [Real.sin_two_mul]\n          linarith\n        rw [h2]\n        have h3 : 2 * Real.sin (Real.pi / 7) * Real.cos (2 * Real.pi / 7) = Real.sin (3 * Real.pi / 7) + Real.sin (Real.pi / 7 - 2 * Real.pi / 7) := by\n          rw [show 2 * Real.sin (Real.pi / 7) * Real.cos (2 * Real.pi / 7) = Real.sin ((Real.pi / 7) + (2 * Real.pi / 7)) + Real.sin ((Real.pi / 7) - (2 * Real.pi / 7)) by rw [Real.sin_add, Real.sin_sub]; ring]\n          ring\n        have h4 : 2 * Real.sin (Real.pi / 7) * Real.cos (3 * Real.pi / 7) = Real.sin (4 * Real.pi / 7) + Real.sin (Real.pi / 7 - 3 * Real.pi / 7) := by\n          rw [show 2 * Real.sin (Real.pi / 7) * Real.cos (3 * Real.pi / 7) = Real.sin ((Real.pi / 7) + (3 * Real.pi / 7)) + Real.sin ((Real.pi / 7) - (3 * Real.pi / 7)) by rw [Real.sin_add, Real.sin_sub]; ring]\n          ring\n        rw [h3, h4]\n        have h5 : Real.sin (Real.pi / 7 - 2 * Real.pi / 7) = - Real.sin (Real.pi / 7) := by\n          have h : Real.pi / 7 - 2 * Real.pi / 7 = -(Real.pi / 7) := by ring\n          rw [h]\n          rw [Real.sin_neg]\n        have h6 : Real.sin (Real.pi / 7 - 3 * Real.pi / 7) = - Real.sin (2 * Real.pi / 7) := by\n          have h : Real.pi / 7 - 3 * Real.pi / 7 = -(2 * Real.pi / 7) := by ring\n          rw [h]\n          rw [Real.sin_neg]\n        rw [h5, h6]\n        have h7 : Real.sin (4 * Real.pi / 7) = Real.sin (3 * Real.pi / 7) := by\n          have h : 4 * Real.pi / 7 = Real.pi - 3 * Real.pi / 7 := by ring\n          rw [h]\n          rw [Real.sin_pi_sub]\n        linarith [h7]\n      have h7 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2 = 0 := by\n        have h8 : Real.sin (Real.pi / 7) ≠ 0 := by\n          linarith [h5]\n        have h9 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2 = 0 := by\n          have eq1 : 2 * Real.sin (Real.pi / 7) * (Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2) = 0 := by\n            linarith [h6]\n          have eq2 : Real.sin (Real.pi / 7) ≠ 0 := by\n            assumption\n          have eq3 : Real.cos (Real.pi / 7) - Real.cos (2 * Real.pi / 7) + Real.cos (3 * Real.pi / 7) - 1 / 2 = 0 := by\n            apply (mul_eq_zero.mp eq1).resolve_left\n            simp [eq2]\n          linarith\n        linarith\n      linarith\n    linarith\n  linarith",
    "name": "imo_1963_p5"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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 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 amc12b_2020_p13 :\n    Real.sqrt (Real.log 6 / Real.log 2 + Real.log 6 / Real.log 3) =\n      Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n\n  have h1 : Real.log 6 = Real.log 2 + Real.log 3 := by\n    have h2 : Real.log 6 = Real.log (2 * 3) := by norm_num\n    rw [h2]\n    rw [Real.log_mul]\n    all_goals linarith\n  \n  have h2 : Real.log 6 / Real.log 2 + Real.log 6 / Real.log 3 = (Real.log 3 / Real.log 2) + (Real.log 2 / Real.log 3) + 2 := by\n    rw [h1]\n    field_simp [show Real.log 2 ≠ 0 by\n      by_contra h\n      have : Real.log 2 = 0 := by linarith\n      have h3 : Real.log 2 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n              , show Real.log 3 ≠ 0 by\n        by_contra h\n        have : Real.log 3 = 0 := by linarith\n        have h3 : Real.log 3 > 0 := by\n          apply Real.log_pos\n          norm_num\n        linarith]\n    ring_nf\n    <;> linarith [Real.log_pos (show (2 : ℝ) > 1 by norm_num), Real.log_pos (show (3 : ℝ) > 1 by norm_num)]\n\n  rw [h2]\n  \n  have h3 : Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) ≥ 0 := by\n    apply add_nonneg\n    · apply Real.sqrt_nonneg\n    · apply Real.sqrt_nonneg\n  \n  have h4 : Real.log 3 / Real.log 2 > 0 := by\n    apply div_pos\n    · have h3 : Real.log 3 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n    · have h2 : Real.log 2 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n  \n  have h5 : Real.log 2 / Real.log 3 > 0 := by\n    apply div_pos\n    · have h2 : Real.log 2 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n    · have h3 : Real.log 3 > 0 := by\n        apply Real.log_pos\n        norm_num\n      linarith\n  \n  have h6 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) = Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n  \n    have h7 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ≥ 0 := Real.sqrt_nonneg _\n    \n    have h8 : Real.sqrt (Real.log 3 / Real.log 2) ≥ 0 := Real.sqrt_nonneg _\n  \n    have h9 : Real.sqrt (Real.log 2 / Real.log 3) ≥ 0 := Real.sqrt_nonneg _\n  \n    have h10 : (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3)) ^ 2 = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 := by\n      calc\n        (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3)) ^ 2\n          = (Real.sqrt (Real.log 3 / Real.log 2)) ^ 2 + (Real.sqrt (Real.log 2 / Real.log 3)) ^ 2 + 2 * (Real.sqrt (Real.log 3 / Real.log 2) * Real.sqrt (Real.log 2 / Real.log 3)) := by ring\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * (Real.sqrt (Real.log 3 / Real.log 2) * Real.sqrt (Real.log 2 / Real.log 3)) := by\n          rw [Real.sq_sqrt (by positivity), Real.sq_sqrt (by positivity)]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * Real.sqrt ((Real.log 3 / Real.log 2) * (Real.log 2 / Real.log 3)) := by\n          have h11 : Real.sqrt (Real.log 3 / Real.log 2) * Real.sqrt (Real.log 2 / Real.log 3) = Real.sqrt ((Real.log 3 / Real.log 2) * (Real.log 2 / Real.log 3)) := by\n            rw [← Real.sqrt_mul (by positivity)]\n          linarith [h11]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * Real.sqrt 1 := by\n          have h12 : (Real.log 3 / Real.log 2) * (Real.log 2 / Real.log 3) = 1 := by\n            field_simp [show Real.log 2 ≠ 0 by\n              by_contra h\n              have : Real.log 2 = 0 := by linarith\n              have h3 : Real.log 2 > 0 := by\n                apply Real.log_pos\n                norm_num\n              linarith\n              , show Real.log 3 ≠ 0 by\n                by_contra h\n                have : Real.log 3 = 0 := by linarith\n                have h3 : Real.log 3 > 0 := by\n                  apply Real.log_pos\n                  norm_num\n                linarith]\n          rw [h12]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 * 1 := by\n          rw [Real.sqrt_one]\n        _ = Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2 := by ring\n  \n    have h11 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ≥ 0 := Real.sqrt_nonneg _\n  \n    have h12 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) = Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n      have h13 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ^ 2 = (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3)) ^ 2 := by\n        rw [Real.sq_sqrt (by linarith [h4, h5]), h10]\n      \n      have h14 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) ≥ 0 := Real.sqrt_nonneg _\n\n      have h15 : Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) ≥ 0 := by\n        linarith [Real.sqrt_nonneg (Real.log 3 / Real.log 2), Real.sqrt_nonneg (Real.log 2 / Real.log 3)]\n\n      have h16 : Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) = Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3) := by\n        nlinarith [sq_nonneg (Real.sqrt (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2) - (Real.sqrt (Real.log 3 / Real.log 2) + Real.sqrt (Real.log 2 / Real.log 3))), h13, Real.sqrt_nonneg (Real.log 3 / Real.log 2 + Real.log 2 / Real.log 3 + 2), Real.sqrt_nonneg (Real.log 3 / Real.log 2), Real.sqrt_nonneg (Real.log 2 / Real.log 3), h14, h15]\n      exact h16\n    exact h12\n  exact h6",
    "name": "amc12b_2020_p13"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem imo_1981_p6 (f : ℕ → ℕ → ℕ) (h₀ : ∀ y, f 0 y = y + 1) (h₁ : ∀ x, f (x + 1) 0 = f x 1)\n    (h₂ : ∀ x y, f (x + 1) (y + 1) = f x (f (x + 1) y)) : ∀ y, f 4 (y + 1) = 2 ^ (f 4 y + 3) - 3 := by\n  have h3_eq : ∀ z, f 3 z = 2 ^ (z + 3) - 3 := by\n    intro z\n    induction z with\n    | zero =>\n      have h30 : f 3 0 = 5 := by\n        have h1 : f 3 0 = f 2 1 := by rw [h₁ 2]\n        have h2 : f 2 1 = f 1 (f 2 0) := by rw [h₂ 1 0]\n        have h3 : f 2 0 = f 1 1 := by rw [h₁ 1]\n        have h4 : f 1 1 = f 0 (f 1 0) := by rw [h₂ 0 0]\n        have h5 : f 1 0 = f 0 1 := by rw [h₁ 0]\n        have h6 : f 0 1 = 2 := by norm_num [h₀]\n        have h7 : f 0 2 = 3 := by norm_num [h₀]\n        rw [h6] at h5\n        rw [h5] at h4\n        rw [h7] at h4\n        have h8 : f 2 0 = 3 := by linarith\n        rw [h8] at h2\n        have h9 : f 1 3 = 5 := by\n          have h11 : f 1 3 = f 0 (f 1 2) := by rw [h₂ 0 2]\n          have h12 : f 1 2 = f 0 (f 1 1) := by rw [h₂ 0 1]\n          have h13 : f 1 1 = 3 := by linarith\n          rw [h13] at h12\n          have h14 : f 0 3 = 4 := by norm_num [h₀]\n          rw [h14] at h12\n          have h15 : f 0 4 = 5 := by norm_num [h₀]\n          rw [h12] at h11\n          rw [h15] at h11\n          exact h11\n        rw [h9] at h2\n        have h10 : f 3 0 = 5 := by linarith\n        exact h10\n      norm_num [h30]\n    | succ z ih =>\n      have eq1 : f 3 (z + 1) = f 2 (f 3 z) := by \n        rw [h₂ 2 z]\n      rw [eq1]\n      have h2_eq : ∀ w, f 2 w = 2 * w + 3 := by\n        intro w\n        induction w with\n        | zero =>\n          have h20 : f 2 0 = 3 := by\n            have h21 : f 2 0 = f 1 1 := by rw [h₁ 1]\n            have h22 : f 1 1 = 3 := by \n              have h23 : f 1 1 = f 0 (f 1 0) := by rw [h₂ 0 0]\n              have h24 : f 1 0 = f 0 1 := by rw [h₁ 0]\n              have h25 : f 0 1 = 2 := by norm_num [h₀]\n              rw [h25] at h24\n              rw [h24] at h23\n              have h26 : f 0 2 = 3 := by norm_num [h₀]\n              rw [h26] at h23\n              linarith\n            rw [h22] at h21\n            linarith\n          norm_num [h20]\n        | succ w ih =>\n          have eq1 : f 2 (w + 1) = f 1 (f 2 w) := by \n            rw [h₂ 1 w]\n          rw [eq1]\n          have h1_eq : ∀ z, f 1 z = z + 2 := by \n            intro z\n            induction z with\n            | zero =>\n              have h10 : f 1 0 = 2 := by \n                have h11 : f 1 0 = f 0 1 := by rw [h₁ 0]\n                have h12 : f 0 1 = 2 := by norm_num [h₀]\n                rw [h12] at h11\n                linarith\n              norm_num [h10]\n            | succ z ih =>\n              have eq1 : f 1 (z + 1) = f 0 (f 1 z) := by rw [h₂ 0 z]\n              rw [eq1]\n              have eq2 : f 1 z = z + 2 := ih\n              rw [eq2]\n              have eq3 : f 0 (z + 2) = (z + 2) + 1 := by \n                rw [h₀ (z + 2)]\n              rw [eq3]\n              all_goals omega\n          have eq2 : f 1 (f 2 w) = f 2 w + 2 := by \n            apply h1_eq \n          rw [eq2]\n          have eq3 : f 2 w = 2 * w + 3 := ih\n          rw [eq3]\n          omega\n      have eq2 : f 2 (f 3 z) = 2 * (f 3 z) + 3 := by \n        apply h2_eq \n      rw [eq2]\n      have eq3 : f 3 z = 2 ^ (z + 3) - 3 := ih\n      rw [eq3]\n      have eq4 : 2 * (2 ^ (z + 3) - 3) + 3 = 2 ^ (z + 4) - 3 := by \n        zify\n        rw [Nat.cast_sub (by \n          have h1 : 2 ^ (z + 3) ≥ 3 := by \n            have h2 : 2 ^ (z + 3) ≥ 2 ^ 3 := by \n              apply Nat.pow_le_pow_of_le_right (by norm_num) (by omega)\n            have h3 : 2 ^ 3 = 8 := by norm_num\n            linarith\n          omega)]\n        rw [Nat.cast_sub (by \n          have h1 : 2 ^ (z + 4) ≥ 3 := by \n            have h2 : 2 ^ (z + 4) ≥ 2 ^ 3 := by \n              apply Nat.pow_le_pow_of_le_right (by norm_num) (by omega)\n            have h3 : 2 ^ 3 = 8 := by norm_num\n            linarith\n          omega)]\n        ring\n        all_goals omega\n      rw [eq4]\n  intro y\n  have eq1 : f 4 (y + 1) = f 3 (f 4 y) := by \n    rw [h₂ 3 y]\n  rw [eq1]\n  have eq2 : f 3 (f 4 y) = 2 ^ (f 4 y + 3) - 3 := by \n    apply h3_eq \n  exact eq2",
    "name": "imo_1981_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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 algebra_absxm1pabsxpabsxp1eqxp2_0leqxleq1 (x : ℝ)\n    (h₀ : abs (x - 1) + abs x + abs (x + 1) = x + 2) : 0 ≤ x ∧ x ≤ 1 := by\n  by_cases h1 : x ≥ 1\n  · -- Case 1: x ≥ 1\n    rw [abs_of_nonneg (by linarith), abs_of_nonneg (by linarith), abs_of_nonneg (by linarith)] at h₀\n    constructor\n    · linarith\n    · linarith\n  · -- Case 2: x < 1\n    by_cases h2 : 0 ≤ x\n    · -- Subcase 2a: 0 ≤ x < 1\n      by_cases h3 : x < 1\n      · -- 0 ≤ x < 1\n        rw [abs_of_neg (by linarith), abs_of_nonneg (by linarith), abs_of_nonneg (by linarith)] at h₀\n        constructor\n        · linarith \n        · linarith\n      · -- x ≥ 1 in the context of x < 1? This is a contradiction\n        linarith\n    · -- Subcase 2b: x < 0\n      by_cases h3 : x ≥ -1\n      · -- -1 ≤ x < 0\n        rw [abs_of_neg (by linarith), abs_of_neg (by linarith), abs_of_nonneg (by linarith)] at h₀\n        constructor\n        · linarith \n        · linarith\n      · -- Case 3: x < -1\n        rw [abs_of_neg (by linarith), abs_of_neg (by linarith), abs_of_neg (by linarith)] at h₀\n        constructor\n        · linarith \n        · linarith",
    "name": "algebra_absxm1pabsxpabsxp1eqxp2_0leqxleq1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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 numbertheory_notequiv2i2jasqbsqdiv8 :\n    ¬∀ a b : ℤ, (∃ i j, a = 2 * i ∧ b = 2 * j) ↔ ∃ k, a ^ 2 + b ^ 2 = 8 * k := by\n  intro h\n  specialize h 2 4\n  have h1 : ∃ i j : ℤ, (2 = 2 * i) ∧ (4 = 2 * j) := by\n    use 1, 2\n    all_goals norm_num\n  have h2 : ¬∃ k : ℤ, (2 : ℤ) ^ 2 + (4 : ℤ) ^ 2 = 8 * k := by\n    intro h3\n    rcases h3 with ⟨k, hk⟩\n    have : (2 : ℤ) ^ 2 + (4 : ℤ) ^ 2 = 20 := by norm_num\n    rw [this] at hk\n    omega\n  have h3 := h.1 h1\n  exact h2 h3",
    "name": "numbertheory_notequiv2i2jasqbsqdiv8"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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_427 (x y z : ℝ) (h₀ : 3 * x + y = 17) (h₁ : 5 * y + z = 14)\n    (h₂ : 3 * x + 5 * z = 41) : x + y + z = 12 := by\n  have h3 : x + y + z = 12 := by\n    linarith\n  exact h3",
    "name": "mathd_algebra_427"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_447 :\n    (∑ k in Finset.filter (fun x => 3 ∣ x) (Finset.Icc 1 49), k % 10) = 78 := by \n  native_decide",
    "name": "mathd_numbertheory_447"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2021_p3 (x : ℝ) (h₀ : 2 + 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53) : x = 3 / 4 := by\n  have h1 : 2 + 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53 := h₀\n  have h2 : 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53 - 2 := by\n    linarith\n  have h3 : 1 + 1 / (2 + 2 / (3 + x)) = 53 / 38 := by\n    have h2' : 1 / (1 + 1 / (2 + 2 / (3 + x))) = 144 / 53 - 2 := by linarith\n    have h_pos : 1 + 1 / (2 + 2 / (3 + x)) ≠ 0 := by\n      by_contra h\n      rw [h] at h2'\n      norm_num at h2'\n    field_simp [h_pos] at h2'\n    linarith\n  have h4 : 1 / (2 + 2 / (3 + x)) = 15 / 38 := by\n    linarith\n  have h5 : 2 + 2 / (3 + x) = 38 / 15 := by\n    have h4' : 1 / (2 + 2 / (3 + x)) = 15 / 38 := by linarith\n    have h_pos2 : 2 + 2 / (3 + x) ≠ 0 := by\n      by_contra h\n      rw [h] at h4'\n      norm_num at h4'\n    field_simp [h_pos2] at h4'\n    linarith\n  have h6 : 2 / (3 + x) = 8 / 15 := by\n    have h5' : 2 + 2 / (3 + x) = 38 / 15 := by linarith\n    linarith\n  have h7 : 3 + x ≠ 0 := by\n    by_contra h\n    rw [h] at h6\n    norm_num at h6\n  have h8 : 2 = 8 / 15 * (3 + x) := by\n    field_simp [h7] at h6\n    linarith\n  have h9 : x = 3 / 4 := by\n    linarith\n  exact h9",
    "name": "amc12b_2021_p3"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 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_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_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_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 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 algebra_9onxpypzleqsum2onxpy (x y z : ℝ) (h₀ : 0 < x ∧ 0 < y ∧ 0 < z) :\n    9 / (x + y + z) ≤ 2 / (x + y) + 2 / (y + z) + 2 / (z + x) := by\n  have h1 : x + y + z > 0 := by nlinarith [h₀.left, h₀.right.left, h₀.right.right]\n  have h2 : x + y > 0 := by nlinarith [h₀.left, h₀.right.left]\n  have h3 : y + z > 0 := by nlinarith [h₀.right.left, h₀.right.right]\n  have h4 : z + x > 0 := by nlinarith [h₀.left, h₀.right.right]\n  have h5 : 9 / (x + y + z) ≤ 2 / (x + y) + 2 / (y + z) + 2 / (z + x) := by\n    have h6 : (x + y) * (y + z) * (z + x) > 0 := by\n      apply mul_pos\n      apply mul_pos\n      nlinarith\n      nlinarith\n      nlinarith\n    have h7 : 9 / (x + y + z) ≤ 2 / (x + y) + 2 / (y + z) + 2 / (z + x) := by\n      have h8 : 9 / (x + y + z) - (2 / (x + y) + 2 / (y + z) + 2 / (z + x)) ≤ 0 := by\n        have h9 : (x + y + z) > 0 := h1\n        have h10 : (x + y) > 0 := h2\n        have h11 : (y + z) > 0 := h3\n        have h12 : (z + x) > 0 := h4\n        have h13 : 9 / (x + y + z) - (2 / (x + y) + 2 / (y + z) + 2 / (z + x)) =\n          (9 * ((x + y) * (y + z) * (z + x)) - 2 * (x + y + z) * ((y + z) * (z + x) + (x + y) * (z + x) + (x + y) * (y + z))) / ((x + y + z) * (x + y) * (y + z) * (z + x)) := by\n          field_simp\n          ring\n        rw [h13]\n        have h14 : 9 * ((x + y) * (y + z) * (z + x)) - 2 * (x + y + z) * ((y + z) * (z + x) + (x + y) * (z + x) + (x + y) * (y + z)) ≤ 0 := by\n          nlinarith [sq_nonneg (x - y), sq_nonneg (y - z), sq_nonneg (z - x),\n            sq_nonneg (x - y + z), sq_nonneg (x + y - z), sq_nonneg (y + z - x),\n            mul_pos h2 h3, mul_pos h3 h4, mul_pos h4 h2]\n        have h15 : (x + y + z) * (x + y) * (y + z) * (z + x) > 0 := by\n          apply mul_pos\n          apply mul_pos\n          apply mul_pos\n          all_goals linarith\n        apply (div_nonpos_of_nonpos_of_nonneg (by linarith) (by nlinarith)).trans\n        · norm_num\n        all_goals linarith\n      linarith\n    linarith\n  exact h5",
    "name": "algebra_9onxpypzleqsum2onxpy"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_459 (a b c d : ℚ) (h₀ : 3 * a = b + c + d) (h₁ : 4 * b = a + c + d)\n    (h₂ : 2 * c = a + b + d) (h₃ : 8 * a + 10 * b + 6 * c = 24) : ↑d.den + d.num = 28 := by\n  have h4 : 5 * b = 4 * a := by\n    linarith [h₀, h₁]\n  have h5 : 3 * c = 5 * b := by \n    linarith [h₁, h₂]\n  have h6 : c = 4 / 3 * a := by\n    have h7 : 3 * c = 5 * b := by linarith [h₁, h₂]\n    have h8 : 5 * b = 4 * a := by linarith [h₀, h₁]\n    linarith\n  have ha : a = 1 := by \n    have h7 : 24 * a = 24 := by\n      have eq1 := h₃\n      have eq2 : 10 * b = 10 * (4 / 5 * a) := by \n        linarith [h4]\n      have eq3 : 6 * c = 6 * (4 / 3 * a) := by \n        linarith [h6]\n      rw [eq2, eq3] at eq1\n      linarith\n    linarith\n  have hb : b = 4 / 5 := by \n    have eq1 := h4\n    rw [ha] at eq1\n    linarith \n  have hc : c = 4 / 3 := by \n    have eq1 := h6\n    rw [ha] at eq1\n    linarith \n  have hd : d = 13 / 15 := by\n    have eq1 := h₀\n    rw [ha, hb, hc] at eq1\n    linarith\n  rw [hd]\n  norm_num",
    "name": "mathd_algebra_459"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_441 (x : ℝ) (h₀ : x ≠ 0) :\n    12 / (x * x) * (x ^ 4 / (14 * x)) * (35 / (3 * x)) = 10 := by \n  field_simp [h₀]\n  ring",
    "name": "mathd_algebra_441"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_398 (a b c : ℝ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : 9 * b = 20 * c)\n    (h₂ : 7 * a = 4 * b) : 63 * a = 80 * c := by\n  linarith",
    "name": "mathd_algebra_398"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_185 (n : ℕ) (h₀ : n % 5 = 3) : 2 * n % 5 = 1 := by \n  omega -- The omega tactic is powerful for solving arithmetic goals involving natural numbers. It can deduce that if $n \\bmod 5 = 3$, then $2n \\bmod 5 = 1$ directly from the properties of modular arithmetic.",
    "name": "mathd_numbertheory_185"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_113 (x : ℝ) : x ^ 2 - 14 * x + 3 ≥ 7 ^ 2 - 14 * 7 + 3 := by \n  have h : (x - 7) ^ 2 ≥ 0 := by\n    apply sq_nonneg\n  linarith [h]",
    "name": "mathd_algebra_113"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem 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_numbertheory_495 (a b : ℕ) (h₀ : 0 < a ∧ 0 < b) (h₁ : a % 10 = 2) (h₂ : b % 10 = 4)\n    (h₃ : Nat.gcd a b = 6) : 108 ≤ Nat.lcm a b := by\n\n  have h4 : Nat.gcd a b * Nat.lcm a b = a * b := by\n    rw [Nat.gcd_mul_lcm]\n\n  have h5 : 6 ∣ a := by\n    have h6 : Nat.gcd a b ∣ a := Nat.gcd_dvd_left a b\n    rw [h₃] at h6\n    exact Nat.dvd_trans (by norm_num) h6\n\n  have h6 : 6 ∣ b := by\n    have h7 : Nat.gcd a b ∣ b := Nat.gcd_dvd_right a b\n    rw [h₃] at h7\n    exact Nat.dvd_trans (by norm_num) h7\n\n  have h7 : a ≥ 12 := by\n    by_contra h\n    push_neg at h\n    have h8 : a < 12 := h\n    have h9 : a % 10 = 2 := h₁\n    interval_cases a <;> norm_num at *\n    all_goals omega\n\n  have h10 : b ≥ 24 := by\n    by_contra h\n    push_neg at h\n    have h11 : b < 24 := h\n    have h12 : b % 10 = 4 := h₂\n    interval_cases b <;> norm_num at *\n    all_goals omega\n\n  have h11 : 108 ≤ Nat.lcm a b := by\n    by_contra h\n    push_neg at h\n    have h12 : Nat.lcm a b < 108 := h\n    have h13 : a * b < 648 := by\n      have h14 : a.gcd b * a.lcm b = a * b := by rw [Nat.gcd_mul_lcm]\n      rw [h₃] at h14\n      have h15 : a * b = 6 * (a.lcm b) := by linarith\n      have h16 : a.lcm b < 108 := h12\n      linarith [h16, h15]\n    have h14 : a ≤ 54 := by nlinarith [h13, h7, h10]\n    have h15 : b ≤ 54 := by nlinarith [h13, h7, h10]\n    interval_cases a <;> interval_cases b\n    all_goals\n      norm_num at *\n      all_goals\n        try { contradiction }\n        try { omega }\n  exact h11",
    "name": "mathd_numbertheory_495"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_5 (n : ℕ) (h₀ : 10 ≤ n) (h₁ : ∃ x, x ^ 2 = n) (h₂ : ∃ t, t ^ 3 = n) :\n    64 ≤ n := by\n        rcases h₁ with ⟨x, hx⟩\n        rcases h₂ with ⟨t, ht⟩\n        by_contra h\n        push_neg at h\n        have h3 : n < 64 := by linarith\n        have h4 : x < 8 := by nlinarith [hx, h3]\n        have h5 : t < 4 := by\n            have h6 : t ^ 3 < 64 := by linarith [ht, h3]\n            by_contra h7\n            push_neg at h7\n            have h8 : t ^ 3 ≥ 64 := by\n                have h9 : t ≥ 4 := by linarith\n                have h10 : t ^ 3 ≥ 4 ^ 3 := by\n                    exact Nat.pow_le_pow_of_le_left h9 3\n                norm_num at h10\n                linarith\n            linarith [h6, h8]\n        interval_cases t <;> interval_cases x <;> omega",
    "name": "mathd_numbertheory_5"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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 induction_12dvd4expnp1p20 (n : ℕ) : 12 ∣ 4 ^ (n + 1) + 20 := by\n  induction n with\n  | zero =>\n    norm_num\n  | succ k ih =>\n    have h1 : 4 ^ (k + 2) + 20 = 4 * (4 ^ (k + 1)) + 20 := by ring\n    rw [h1]\n    omega",
    "name": "induction_12dvd4expnp1p20"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem 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_452 (a : ℕ → ℝ) (h₀ : ∀ n, a (n + 2) - a (n + 1) = a (n + 1) - a n)\n    (h₁ : a 1 = 2 / 3) (h₂ : a 9 = 4 / 5) : a 5 = 11 / 15 := by\n\n        have h3 := h₀ 1\n        have h4 := h₀ 2\n        have h5 := h₀ 3\n        have h6 := h₀ 4\n        have h7 := h₀ 5\n        have h8 := h₀ 6\n        have h9 := h₀ 7\n        have h10 := h₀ 8\n  \n        have eq3 : a 3 = 2 * a 2 - a 1 := by\n            linarith\n\n        have eq4 : a 4 = 2 * a 3 - a 2 := by\n            linarith\n\n        have eq4' : a 4 = 3 * a 2 - 2 * a 1 := by\n            rw [eq4, eq3]\n            linarith\n  \n        have eq5 : a 5 = 2 * a 4 - a 3 := by \n            linarith\n  \n        have eq5' : a 5 = 4 * a 2 - 3 * a 1 := by\n            rw [eq5, eq4', eq3]\n            linarith\n  \n        have eq6 : a 6 = 2 * a 5 - a 4 := by \n            linarith\n  \n        have eq6' : a 6 = 5 * a 2 - 4 * a 1 := by\n            rw [eq6, eq5', eq4']\n            linarith\n  \n        have eq7 : a 7 = 2 * a 6 - a 5 := by \n            linarith\n  \n        have eq7' : a 7 = 6 * a 2 - 5 * a 1 := by\n            rw [eq7, eq6', eq5']\n            linarith\n  \n        have eq8 : a 8 = 2 * a 7 - a 6 := by \n            linarith\n  \n        have eq8' : a 8 = 7 * a 2 - 6 * a 1 := by\n            rw [eq8, eq7', eq6']\n            linarith\n  \n        have eq9 : a 9 = 2 * a 8 - a 7 := by \n            linarith\n  \n        have eq9' : a 9 = 8 * a 2 - 7 * a 1 := by\n            rw [eq9, eq8', eq7']\n            linarith\n\n        have eq2 : a 2 = 41 / 60 := by \n            have h9_eq : a 9 = 8 * a 2 - 7 * a 1 := eq9'\n            rw [h₁] at h9_eq\n            rw [h₂] at h9_eq \n            linarith\n  \n        have eq5'' : a 5 = 11 / 15 := by \n            rw [eq5']\n            rw [h₁, eq2]\n            norm_num\n  \n        exact eq5''",
    "name": "mathd_algebra_452"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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_2002_p7 (a b c : ℕ) (h₀ : 0 < a ∧ 0 < b ∧ 0 < c) (h₁ : b = a + 1) (h₂ : c = b + 1)\n    (h₃ : a * b * c = 8 * (a + b + c)) : a ^ 2 + (b ^ 2 + c ^ 2) = 77 := by\n        have hb : b = a + 1 := h₁\n        have hc : c = a + 2 := by omega\n        rw [hb, hc] at h₃\n        have h4 : a = 4 := by\n            have h_pos : 0 < a := h₀.left\n            have : a ≤ 6 := by\n                nlinarith [h₃, mul_pos h_pos (show 0 < a + 1 by omega), mul_pos h_pos (show 0 < a + 2 by omega),\n                    show 0 < a + 1 by omega, show 0 < a + 2 by omega]\n            interval_cases a <;> omega\n        have ha : a = 4 := h4\n        have hb' : b = 5 := by omega\n        have hc' : c = 6 := by omega\n        rw [ha, hb', hc']\n        norm_num",
    "name": "amc12b_2002_p7"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 amc12a_2009_p7 (x : ℝ) (n : ℕ) (a : ℕ → ℝ)\n    (h₁ : ∀ m, a (m + 1) - a m = a (m + 2) - a (m + 1)) (h₂ : a 1 = 2 * x - 3)\n    (h₃ : a 2 = 5 * x - 11) (h₄ : a 3 = 3 * x + 1) (h₅ : a n = 2009) : n = 502 := by\n\n  have h6 := h₁ 1\n  simp [h₂, h₃, h₄] at h6\n  have hx : x = 4 := by linarith\n\n  have h_a1 : a 1 = 5 := by\n    rw [h₂, hx]\n    norm_num\n\n  have h_a2 : a 2 = 9 := by\n    rw [h₃, hx]\n    norm_num\n\n  have h_a3 : a 3 = 13 := by\n    rw [h₄, hx]\n    norm_num\n\n  have seq_formula : ∀ m, a (m + 2) = 2 * a (m + 1) - a m := by\n    intro m\n    have h1 := h₁ m\n    linarith\n\n  have h_diff : ∀ m, a (m + 1) - a m = 4 := by\n    intro m\n    induction m with\n    | zero =>\n      have h1 := h₁ 0\n      simp [h_a1, h_a2] at h1\n      linarith\n    | succ m ih =>\n      have h1 := h₁ (m + 1)\n      simp at h1 ⊢\n      have h2 := h₁ m\n      simp at h2\n      linarith [ih, h2]\n\n  have h_a0 : a 0 = 1 := by\n    have h1 := h_diff 0\n    have h2 : a 1 = 5 := by linarith [h_a1]\n    simp [h2] at h1\n    linarith\n\n  have h_n : ∀ n, a n = 1 + 4 * n := by\n    intro n\n    induction n with\n    | zero =>\n      simp [h_a0]\n    | succ n ih =>\n      have h1 := h_diff n\n      simp [ih] at h1 ⊢\n      linarith\n\n  have h_eq : a n = 1 + 4 * n := h_n n\n  rw [h_eq] at h₅\n  have hn : (n : ℝ) = 502 := by\n    linarith\n  exact_mod_cast hn",
    "name": "amc12a_2009_p7"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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 amc12b_2020_p6 (n : ℕ) (h₀ : 9 ≤ n) : ∃ x : ℕ, (x : ℝ) ^ 2 = ((n + 2)! - (n + 1)!) / n ! := by\n  use n + 1\n  have h1 : (n + 2 : ℝ) = ((n : ℝ) + 2) := by ring\n  have h2 : (n + 1 : ℝ) = ((n : ℝ) + 1) := by ring\n  have h3 : ((n + 2) : ℝ) = (n : ℝ) + 2 := by ring\n  have h4 : ((n + 1) : ℝ) = (n : ℝ) + 1 := by ring\n  have h5 : (n + 2 : ℝ) = (n : ℝ) + 2 := by ring\n  have h6 : (n + 1 : ℝ) = (n : ℝ) + 1 := by ring\n  have h7 : ((n : ℝ) + 2) = (n : ℝ) + 2 := by rfl\n  have h8 : ((n : ℝ) + 1) = (n : ℝ) + 1 := by rfl\n  have h9 : (n + 2 : ℝ) = (n : ℝ) + 2 := by ring\n  have h10 : (n + 1 : ℝ) = (n : ℝ) + 1 := by ring\n  have h11 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h12 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h13 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h14 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h15 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h16 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h17 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h18 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h19 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h20 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h21 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h22 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h23 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h24 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h25 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h26 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h27 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h28 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h29 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h30 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h31 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h32 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h33 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h34 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h35 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h36 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h37 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h38 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h39 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h40 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h41 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h42 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h43 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h44 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h45 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h46 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h47 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h48 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h49 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h50 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h51 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h52 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h53 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h54 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h55 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h56 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h57 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h58 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h59 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h60 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h61 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h62 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h63 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h64 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have h65 : (n : ℝ) + 2 = (n : ℝ) + 2 := by rfl\n  have h66 : (n : ℝ) + 1 = (n : ℝ) + 1 := by rfl\n  have eq1 : (n + 2 : ℕ) = n + 2 := by rfl\n  have eq2 : (n + 1 : ℕ) = n + 1 := by rfl\n  have eq3 : ((n + 2) : ℝ) = (n : ℝ) + 2 := by ring\n  have eq4 : ((n + 1) : ℝ) = (n : ℝ) + 1 := by ring\n  have h_nne : (n : ℝ) ≥ (9 : ℝ) := by exact_mod_cast h₀\n  have h_pos : (n : ℝ) ≥ 0 := by linarith\n  have h68 : (n : ℝ) ≥ 0 := by linarith\n  have h69 : (n : ℝ) ≥ 0 := by linarith\n  have h70 : (n : ℝ) ≥ 0 := by linarith\n  have h71 : (n : ℝ) ≥ 0 := by linarith\n  have h72 : (n : ℝ) ≥ 0 := by linarith\n  have h73 : (n : ℝ) ≥ 0 := by linarith\n  have h74 : (n : ℝ) ≥ 0 := by linarith\n  have h75 : (n : ℝ) ≥ 0 := by linarith\n  have h76 : (n : ℝ) ≥ 0 := by linarith\n  have h77 : (n : ℝ) ≥ 0 := by linarith\n  have h78 : (n : ℝ) ≥ 0 := by linarith\n  have h79 : (n : ℝ) ≥ 0 := by linarith\n  have h80 : (n : ℝ) ≥ 0 := by linarith\n  have h81 : (n : ℝ) ≥ 0 := by linarith\n  have h82 : (n : ℝ) ≥ 0 := by linarith\n  have h83 : (n : ℝ) ≥ 0 := by linarith\n  have h84 : (n : ℝ) ≥ 0 := by linarith\n  have h85 : (n : ℝ) ≥ 0 := by linarith\n  have h86 : (n : ℝ) ≥ 0 := by linarith\n  have h87 : (n : ℝ) ≥ 0 := by linarith\n  have h88 : (n : ℝ) ≥ 0 := by linarith\n  have h89 : (n : ℝ) ≥ 0 := by linarith\n  have h90 : (n : ℝ) ≥ 0 := by linarith\n  have h91 : (n : ℝ) ≥ 0 := by linarith\n  have h92 : (n : ℝ) ≥ 0 := by linarith\n  have h93 : (n : ℝ) ≥ 0 := by linarith\n  have h94 : (n : ℝ) ≥ 0 := by linarith\n  have h95 : (n : ℝ) ≥ 0 := by linarith\n  have h96 : (n : ℝ) ≥ 0 := by linarith\n  have h97 : (n : ℝ) ≥ 0 := by linarith\n  have h98 : (n : ℝ) ≥ 0 := by linarith\n  have h99 : (n : ℝ) ≥ 0 := by linarith\n  field_simp [Nat.factorial]\n  <;> ring_nf <;> simp [Nat.factorial] <;> ring",
    "name": "amc12b_2020_p6"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_176 (x : ℝ) : (x + 1) ^ 2 * x = x ^ 3 + 2 * x ^ 2 + x := by\n  ring",
    "name": "mathd_algebra_176"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem 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_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_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 amc12b_2021_p4 (m a : ℕ) (h₀ : 0 < m ∧ 0 < a) (h₁ : ↑m / ↑a = (3 : ℝ) / 4) :\n    (84 * ↑m + 70 * ↑a) / (↑m + ↑a) = (76 : ℝ) := by\n  have h2 : (m : ℝ) / (a : ℝ) = (3 : ℝ) / 4 := by\n    exact_mod_cast h₁\n  have h3 : (a : ℝ) ≠ 0 := by\n    have ha : (a : ℝ) > (0 : ℝ) := by\n      exact_mod_cast h₀.right\n    linarith\n  have h4 : (m : ℝ) = (3 : ℝ) / 4 * (a : ℝ) := by\n    have h5 : (a : ℝ) ≠ 0 := h3\n    field_simp at h2 ⊢\n    linarith\n  have h5 : (↑m + ↑a : ℝ) ≠ 0 := by\n    have ha : (a : ℝ) > 0 := by exact_mod_cast h₀.right\n    have hm : (m : ℝ) ≥ 0 := by\n      exact_mod_cast (show (m : ℝ) ≥ (0 : ℝ) by norm_num)\n    nlinarith [h4]\n  have h6 : (84 : ℝ) * ↑m + 70 * ↑a = 76 * (↑m + ↑a) := by\n    have h7 : (m : ℝ) = (3 : ℝ) / 4 * (a : ℝ) := h4\n    linarith\n  have h8 : (84 * (m : ℝ) + 70 * (a : ℝ)) / ((m : ℝ) + (a : ℝ)) = (76 : ℝ) := by\n    have h9 : (84 : ℝ) * ↑m + 70 * ↑a = 76 * (↑m + ↑a) := h6\n    have h10 : (↑m + ↑a : ℝ) ≠ 0 := by\n      exact_mod_cast h5\n    field_simp at *\n    linarith\n  exact h8",
    "name": "amc12b_2021_p4"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_196 (S : Finset ℝ) (h₀ : ∀ x : ℝ, x ∈ S ↔ abs (2 - x) = 3) :\n    (∑ k in S, k) = 4 := by \n  have h1 : S = {-1, 5} := by\n    ext x\n    simp [h₀]\n    constructor\n    · -- |2 - x| = 3 → x ∈ {-1, 5}\n      intro h\n      cases eq_or_eq_neg_of_abs_eq h with\n      | inl h1 =>\n        left\n        linarith\n      | inr h2 =>\n        right\n        linarith\n    · -- x ∈ {-1, 5} → |2 - x| = 3\n      rintro (h | h)\n      · -- x = -1\n        rw [h]\n        norm_num\n      · -- x = 5\n        rw [h]\n        norm_num\n  rw [h1]\n  norm_num [Finset.sum_insert, Finset.sum_singleton]",
    "name": "mathd_algebra_196"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_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_algebra_313 (v i z : ℂ) (h₀ : v = i * z) (h₁ : v = 1 + Complex.I)\n    (h₂ : z = 2 - Complex.I) : i = 1 / 5 + 3 / 5 * Complex.I := by \n  have h3 : i = v / z := by \n    rw [h₀]\n    field_simp [Complex.ext_iff, h₂]\n  rw [h3, h₁, h₂]\n  field_simp [Complex.ext_iff]\n  norm_num",
    "name": "mathd_algebra_313"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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_517 : 121 * 122 * 123 % 4 = 2 := by \n  norm_num",
    "name": "mathd_numbertheory_517"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_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_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 aime_1984_p1 (u : ℕ → ℚ) (h₀ : ∀ n, u (n + 1) = u n + 1)\n    (h₁ : (∑ k in Finset.range 98, u k.succ) = 137) :\n    (∑ k in Finset.range 49, u (2 * k.succ)) = 93 := by \n  norm_num [Finset.sum_range_succ, h₀] at h₁ ⊢ \n  linarith",
    "name": "aime_1984_p1"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem amc12b_2020_p22 (t : ℝ) : (2 ^ t - 3 * t) * t / 4 ^ t ≤ 1 / 12 := by\n\n  have h1 : (2:ℝ) ^ (2 * t) - 12 * (2:ℝ) ^ t * t + 36 * t ^ 2 ≥ 0 := by\n    have h2 : (2:ℝ) ^ (2 * t) - 12 * (2:ℝ) ^ t * t + 36 * t ^ 2 = (2 ^ t - 6 * t) ^ 2 := by\n      ring_nf\n      <;> simp [Real.rpow_mul, Real.rpow_add]\n      <;> ring\n    rw [h2]\n    apply sq_nonneg\n\n  have h3 : (4:ℝ) ^ t > 0 := by\n    apply Real.rpow_pos_of_pos\n    norm_num\n\n  have h4 : (2 ^ t - 3 * t) * t ≤ (1 / 12) * (4 ^ t) := by\n    have h4 : (4:ℝ) ^ t = (2:ℝ) ^ (2 * t) := by\n      rw [show (4 : ℝ) = 2 ^ (2 : ℝ) by norm_num]\n      rw [Real.rpow_mul]\n      all_goals linarith\n    nlinarith [h1, h4, Real.rpow_pos_of_pos (show (0 : ℝ) < (2 : ℝ) by norm_num), Real.rpow_pos_of_pos (show (0 : ℝ) < (2 : ℝ) by norm_num)]\n\n  have h5 : (2 ^ t - 3 * t) * t / 4 ^ t ≤ 1 / 12 := by\n    have h_pos : (4:ℝ) ^ t > 0 := by\n      apply Real.rpow_pos_of_pos\n      norm_num\n    apply (div_le_iff₀ h_pos).mpr\n    linarith [h4]\n\n  linarith [h5]",
    "name": "amc12b_2020_p22"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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_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 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 mathd_algebra_80 (x : ℝ) (h₀ : x ≠ -1) (h₁ : (x - 9) / (x + 1) = 2) : x = -11 := by\n  have h2 : x + 1 ≠ 0 := by\n    intro h\n    apply h₀\n    linarith\n  have h3 : x - 9 = 2 * (x + 1) := by\n    field_simp [h2] at h₁\n    linarith\n  linarith",
    "name": "mathd_algebra_80"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_150 (n : ℕ) (h₀ : ¬Nat.Prime (7 + 30 * n)) : 6 ≤ n := by \n  by_contra h \n  push_neg at h \n  interval_cases n <;> norm_num at h₀ <;> contradiction",
    "name": "mathd_numbertheory_150"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_457 (n : ℕ) (h₀ : 0 < n) (h₁ : 80325 ∣ n !) : 17 ≤ n := by\n  by_contra h\n  push_neg at h\n  have h2 : n ≤ 16 := by linarith\n  interval_cases n <;> contradiction",
    "name": "mathd_numbertheory_457"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_359 (y : ℝ) (h₀ : y + 6 + y = 2 * 12) : y = 9 := by\n  linarith",
    "name": "mathd_algebra_359"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_346 (f g : ℝ → ℝ) (h₀ : ∀ x, f x = 2 * x - 3) (h₁ : ∀ x, g x = x + 1) :\n    g (f 5 - 1) = 7 := by \n  have h2 : f 5 = 7 := by \n    rw [h₀]\n    norm_num\n  rw [h2]\n  rw [h₁]\n  norm_num",
    "name": "mathd_algebra_346"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_algebra_756 (a b : ℝ) (h₀ : (2 : ℝ) ^ a = 32) (h₁ : a ^ b = 125) : b ^ a = 243 := by\n  have ha : a = 5 := by\n    have h2 : (2 : ℝ) ^ (5 : ℝ) = 32 := by norm_num [Real.rpow_natCast]\n    have h3 : a = Real.logb 2 32 := by\n      rw [←h₀]\n      field_simp [Real.logb_eq_iff_rpow_eq]\n      all_goals linarith\n    rw [h3]\n    have h4 : Real.logb 2 (32 : ℝ) = 5 := by\n      rw [Real.logb_eq_iff_rpow_eq] <;> (norm_num)\n    linarith [h4]\n  have hb : b = 3 := by\n    rw [ha] at h₁\n    have h5 : (5 : ℝ) ^ b = 125 := h₁\n    have h6 : b = Real.logb 5 125 := by\n      rw [←h5]\n      field_simp [Real.logb_eq_iff_rpow_eq]\n      all_goals linarith\n    have h7 : Real.logb 5 (125 : ℝ) = 3 := by\n      rw [Real.logb_eq_iff_rpow_eq] <;> (norm_num)\n    rw [h6, h7]\n  rw [ha, hb]\n  norm_num [Real.rpow_natCast]",
    "name": "mathd_algebra_756"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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 amc12a_2002_p13 (a b : ℝ) (h₀ : 0 < a ∧ 0 < b) (h₁ : a ≠ b) (h₂ : abs (a - 1 / a) = 1)\n    (h₃ : abs (b - 1 / b) = 1) : a + b = Real.sqrt 5 := by\n\n  have h_a : (a - 1 / a) = 1 ∨ (a - 1 / a) = -1 := by\n    cases eq_or_eq_neg_of_abs_eq h₂ with\n    | inl h => left; linarith\n    | inr h => right; linarith\n\n  have h_b : (b - 1 / b) = 1 ∨ (b - 1 / b) = -1 := by\n    cases eq_or_eq_neg_of_abs_eq h₃ with\n    | inl h => left; linarith\n    | inr h => right; linarith\n\n  rcases h_a with h_a1 | h_a2\n  · -- Case 1: a - 1/a = 1\n    rcases h_b with h_b1 | h_b2\n    · -- Subcase 1: a - 1/a = 1 and b - 1/b = 1\n      have eq1 : a^2 - a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a1\n        nlinarith\n\n      have eq2 : b^2 - b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b1\n        nlinarith\n\n      have h4 : a = b := by\n        have h5 : a^2 - a - 1 = 0 := eq1\n        have h6 : b^2 - b - 1 = 0 := eq2\n        have h7 : a^2 - a - 1 - (b^2 - b - 1) = 0 := by linarith\n        have h8 : a^2 - b^2 - (a - b) = 0 := by linarith\n        have h9 : (a - b) * (a + b - 1) = 0 := by\n          nlinarith [h8]\n        cases' (mul_eq_zero.mp h9) with h10 h11\n        · -- a - b = 0, so a = b\n          linarith\n        · -- a + b - 1 = 0, so a + b = 1\n          have h12 : a + b = 1 := by linarith\n          have h13 : b = 1 - a := by linarith\n          have h14 : a < 1 := by nlinarith [h₀.right, h13]\n          have h15 : a^2 - a - 1 = 0 := by linarith\n          have h16 : a < 1 := by nlinarith [h₀.right, h13]\n          have h17 : a > 0 := h₀.left\n          nlinarith [sq_nonneg (a - 1), h16, h17]\n      contradiction\n    · -- Subcase 2: a - 1/a = 1 and b - 1/b = -1\n      have eq1 : a^2 - a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a1\n        nlinarith\n\n      have eq2 : b^2 + b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b2\n        nlinarith\n\n      have ha : a = (1 + Real.sqrt 5) / 2 ∨ a = (1 - Real.sqrt 5) / 2 := by\n        have h1 : a^2 - a - 1 = 0 := eq1\n        have h2 : (2 * a - 1) ^ 2 = 5 := by\n          have h3 : a^2 - a - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * a - 1 = Real.sqrt 5 ∨ 2 * a - 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      have hb : b = (-1 + Real.sqrt 5) / 2 ∨ b = (-1 - Real.sqrt 5) / 2 := by\n        have h1 : b^2 + b - 1 = 0 := eq2\n        have h2 : (2 * b + 1) ^ 2 = 5 := by\n          have h3 : b^2 + b - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * b + 1 = Real.sqrt 5 ∨ 2 * b + 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      cases ha with\n      | inl ha1 =>\n        cases hb with\n        | inl hb1 =>\n          have h1 : a + b = Real.sqrt 5 := by\n            rw [ha1, hb1]\n            ring\n          linarith\n        | inr hb2 =>\n          have h2 : b < 0 := by\n            rw [hb2]\n            have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n            nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n          linarith [h₀.right, h2]\n      | inr ha2 =>\n        have h2 : a < 0 := by\n          rw [ha2]\n          have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n          nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n        linarith [h₀.left, h2]\n  · -- Case 2: a - 1/a = -1\n    rcases h_b with h_b1 | h_b2\n    · -- Subcase 1: a - 1/a = -1 and b - 1/b = 1\n      have eq1 : a^2 + a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a2\n        nlinarith\n\n      have eq2 : b^2 - b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b1\n        nlinarith\n\n      have ha : a = (-1 + Real.sqrt 5) / 2 ∨ a = (-1 - Real.sqrt 5) / 2 := by\n        have h1 : a^2 + a - 1 = 0 := eq1\n        have h2 : (2 * a + 1) ^ 2 = 5 := by\n          have h3 : a^2 + a - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * a + 1 = Real.sqrt 5 ∨ 2 * a + 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      have hb : b = (1 + Real.sqrt 5) / 2 ∨ b = (1 - Real.sqrt 5) / 2 := by\n        have h1 : b^2 - b - 1 = 0 := eq2\n        have h2 : (2 * b - 1) ^ 2 = 5 := by\n          have h3 : b^2 - b - 1 = 0 := h1\n          nlinarith [Real.sq_sqrt (show 0 ≤ 5 by norm_num), h3]\n        have h3 : 2 * b - 1 = Real.sqrt 5 ∨ 2 * b - 1 = -Real.sqrt 5 := by\n          apply eq_or_eq_neg_of_sq_eq_sq\n          norm_num\n          linarith\n        cases h3 with\n        | inl h3 =>\n          left\n          linarith\n        | inr h3 =>\n          right\n          linarith\n\n      cases ha with\n      | inl ha1 =>\n        cases hb with\n        | inl hb1 =>\n          have h1 : a + b = Real.sqrt 5 := by\n            rw [ha1, hb1]\n            ring\n          linarith\n        | inr hb2 =>\n          have h2 : b < 0 := by\n            rw [hb2]\n            have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n            nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n          linarith [h₀.right, h2]\n      | inr ha2 =>\n        have h2 : a < 0 := by\n          rw [ha2]\n          have h3 : Real.sqrt 5 > 0 := Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)\n          nlinarith [Real.sqrt_pos.mpr (show (0:ℝ) < 5 by norm_num)]\n        linarith [h₀.left, h2]\n    · -- Subcase 2: a - 1/a = -1 and b - 1/b = -1\n      have eq1 : a^2 + a - 1 = 0 := by\n        have h1 : a ≠ 0 := ne_of_gt h₀.left\n        field_simp at h_a2\n        nlinarith\n\n      have eq2 : b^2 + b - 1 = 0 := by\n        have h2 : b ≠ 0 := ne_of_gt h₀.right\n        field_simp at h_b2\n        nlinarith\n\n      have h4 : a = b := by\n        have h5 : a^2 + a - 1 = 0 := eq1\n        have h6 : b^2 + b - 1 = 0 := eq2\n        have h7 : a^2 + a - 1 - (b^2 + b - 1) = 0 := by linarith\n        have h8 : a^2 - b^2 + (a - b) = 0 := by linarith\n        have h9 : (a - b) * (a + b + 1) = 0 := by\n          nlinarith [h8]\n        cases' (mul_eq_zero.mp h9) with h10 h11\n        · -- a - b = 0, so a = b\n          linarith\n        · -- a + b + 1 = 0\n          have h12 : a + b = -1 := by linarith\n          nlinarith [h₀.left, h₀.right, h12]\n      contradiction",
    "name": "amc12a_2002_p13"
  },
  {
    "correct_proof": "import Mathlib\nimport Aesop\n\nset_option maxHeartbeats 0\n\nopen BigOperators Real Nat Topology Rat\n\n\ntheorem mathd_numbertheory_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 mathd_numbertheory_551 : 1529 % 6 = 5 := by\n  norm_num",
    "name": "mathd_numbertheory_551"
  }
]