{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["Every set of Borel measure zero is Lebesgue measurable.",
  "No integer is irrational.",
  "Every infinite set contains a finite set.",
  "The diameter of a singleton space is `0`.",
  "The ring of integers has a maximal ideal.",
  "A vector space with the empty set as basis is trivial. "],
 "elaborated-prompts":
 [{"theorem": "∀ {p : ℕ} [inst : Fact (Nat.Prime p)], p = 2 ∨ p % 2 = 1",
   "some-correct": null,
   "prompt": "Every prime number is `2` or odd.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->   p =  2 ∨   p %  2 =  1",
    " {  p :  ℕ } ->  [ hp :  Fact   (   Nat.Prime  p  ) ] ->   p =  2 ∨   p %  2 =  1",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->   p =  2 ∨  Odd  p"]},
  {"theorem": "∀ (n : ℕ), ∃ m, m > n ∧ Odd m",
   "some-correct": null,
   "prompt": "There are infinitely many odd natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃    (   m :  ℕ ) ,   m %  2 =  1",
    " ∀   (  n  :  ℕ  )  ,  ∃     m  ,   m > n ∧  Odd  m",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,   n < m ∧  Odd  m",
    " ∀  m  ,  ∃     n  ,  ∀  p  ,   m ≤ p →   Odd  n →  n < p",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   o :  ℕ ) ,   n < o ∧  Odd  o",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,    m %  2 =  1 ∧  n ≤ m",
    " ∀  n  ,  ∃     m  ,   n < m ∧  ∀  k  ,   n < k →  ¬  (    k %  2 =  0  )",
    " ∀   {  n  :  ℕ }  ,  ∃    (   k :  ℕ ) ,  n <    2 * k +  1",
    " ∃    (   n :  ℕ ) ,  Odd  n",
    " ∃    (   a :  ℕ ) ,  ∀   (  b  :  ℕ  )  ,   a < b →  ¬  Even  b"]},
  {"theorem": "∀ {p : ℕ}, Fact (Nat.Prime p) → p > 2 → p = 3",
   "some-correct": null,
   "prompt": "The smallest odd prime is `3`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" Nat.Prime   (   3   :  ℕ )",
    " ∀   {  p  :  ℕ }  ,   Fact   (   Nat.Prime  p  ) →   p >  2 →  p =  3",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  2 =  1 ) ->  p =  3"]},
  {"theorem": "Fact (∀ (n : ℕ), ∃ p, n < p ∧ Nat.Prime p)",
   "some-correct": null,
   "prompt": "There are infinitely many odd prime numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" Fact   (   ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   n < p ∧  Nat.Prime  p  )",
    " Infinite   { p  :  ℕ //   (   p >  2  ) ∧  (   Prime  p  ) }",
    " ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  ∀   (  q  :  ℕ  )  ,   Nat.Prime  q →   q ≠ p →  q > p",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   n < p ∧   Odd  p ∧  Nat.Prime  p",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   n < p ∧   Nat.Prime  p ∧   p %  2 =  1"]},
  {"theorem":
   "∀ {K : Type u} {V : Type v} [inst : DivisionRing K] [inst_1 : AddCommGroupₓ V] [inst_2 : Module K V],\n  Module.rank K V = 2 → FiniteDimensional K V",
   "some-correct": null,
   "prompt":
   "If a vector space has dimension `2` then it is finite dimensional.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V =  2 ) ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->    Module.rank  K V =  2 →   FiniteDimensional.finrank  K V =  2",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->    Module.rank  K V =  2 →  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V ≤  2 ) ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V ≤  2 ) ->  FiniteDimensional  K V"]},
  {"theorem": "(K : Type u) → [inst : Field K] → DivisionRing K",
   "some-correct": null,
   "prompt": "Every field is a division ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  Field  K ] ->  DivisionRing  K",
    " {  α :  Type  u_1 } ->  [  Field  α ] ->  DivisionRing  α",
    " (  K :  Type  u ) ->  [  Field  K ] ->  [  CharZero  K ] ->  DivisionRing  K",
    " {  α :  Type  u } ->  [  Field  α ] ->  DivisionRing  α",
    " {  K :  Type  u } ->  [  Field  K ] ->  DivisionRing  K",
    " {  K :  Type  u } ->  [  Field  K ] ->  DivisionRing  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  DivisionRing  K"]},
  {"theorem":
   "∀ {K : Type u} {V : Type v} [inst : DivisionRing K] [inst_1 : AddCommGroupₓ V] [inst_2 : Module K V]\n  {h : Module.rank K V = 2}, FiniteDimensional K V",
   "some-correct": null,
   "prompt": "If a space has dimension `2` then it is finite dimensional.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  {  h :   Module.rank  K V =  2 } ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V =  2 ) ->  FiniteDimensional  K V",
    " (  K :  Type  u ) ->  (  V :  Type  v ) ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V =  2 ) ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V =  2 ) ->   FiniteDimensional.finrank  K V ≠  0",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->    Module.rank  K V =  2 →  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :   Module.rank  K V ≤  2 ) ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  (  V :  Type  v ) ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->    Module.rank  K V =  2 →  FiniteDimensional  K V"]},
  {"theorem": "∀ (n : ℕ), ∃ m, n < m",
   "some-correct": null,
   "prompt": "Every natural number has a successor.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,  n < m",
    " {  m :  ℕ } ->  ∃    (   n :  ℕ ) ,  m < n",
    " {  n :  ℕ } ->  ∃    (   m :  ℕ ) ,  m =  n +  1",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,   n +  1 = m",
    " {  n :  ℕ } ->  ∃    (   ns :  ℕ ) ,  n < ns",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,  m =  n +  1",
    " (  n :  ℕ ) ->  ∃    (   m :  ℕ ) ,  n < m",
    " (  n :  ℕ ) ->  ∃    (   m :  ℕ ) ,  m > n",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,  m > n"]},
  {"theorem": "∀ {n : ℕ}, n < n + 1",
   "some-correct": null,
   "prompt": "Every natural number is less than its successor.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  n <  n +  1",
    " (  n :  ℕ ) ->  n ≤ n.succ",
    " {  n :  ℕ } ->  n < n.succ",
    " (  n :  ℕ ) ->   (  n   :  ℕ ) <  n +  1",
    " ∀   (  n  :  ℕ  )  ,  n < n.succ",
    " {  m :  ℕ } ->  m <  m +  1"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : MeasurableSpace α] (s : Set α), MeasurableSet s",
   "some-correct": null,
   "prompt": "Every set is Lebesgue measurable.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->  MeasurableSet  s",
    " {  α :  Type  u_1 } ->  {  s :  Set  α } ->  {  m :  MeasurableSpace  α } ->  MeasurableSet  s",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  {  s :  Set  α } ->  ∃    (   t :  Set  α ) ,   s = t ∧  MeasurableSet  t"]},
  {"theorem": "∀ {p : ℕ} [inst : Fact (Nat.Prime p)], ¬∃ q, q ^ 2 = p",
   "some-correct": null,
   "prompt": "No prime number is a perfect square.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   q :  ℕ ) ,   q ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   m :  ℕ ) ,   m ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   k :  ℕ ) ,   k * k = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  (   ∃    (   m :  ℕ ) ,   m * m = p  )",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   m :  ℕ ) ,   m * m = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   n :  ℕ ) ,  p =  n ^  2",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   t :  ℕ ) ,   t * t = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ∀   (  k  :  ℕ  )  ,   k ^  2 ≠ p"]},
  {"theorem": "∀ (p : ℕ) [inst : Fact (Nat.Prime p)], Odd p → 2 < p",
   "some-correct": null,
   "prompt": "Every odd prime number is greater than `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h_odd :  Odd  p ) ->   2 < p",
    " (  p :  ℕ ) ->    Nat.Prime  p ∧  p ≠  2 →   p %  2 =  1",
    " {  p :  ℕ } ->  (  h :  Nat.Prime  p ) ->   p >  2 ↔  Odd  p",
    " {  p :  ℕ } ->  (  h :   p %  2 =  1 ) ->  (  h2 :  Nat.Prime  p ) ->   2 < p",
    " (  p :  ℕ ) ->   Nat.Prime  p →    p %  2 =  1 →  p >  2",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h_odd :   p %  2 =  1 ) ->   2 < p",
    " {  p :  ℕ } ->  (  h :  Nat.Prime  p ) ->  (  h_odd :   p %  2 =  1 ) ->   2 < p",
    " (  p :  ℕ ) ->  (  h_prime :  Nat.Prime  p ) ->  (  h_odd :   p %  2 =  1 ) ->   2 < p",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  ho :   p %  2 =  1 ) ->  p >  2",
    " (  n :  ℕ ) ->  (  h :  Nat.Prime  n ) ->  (  h_odd :   n %  2 =  1 ) ->  n >  2",
    " {  p :  ℕ } ->  (  h :  Nat.Prime  p ) ->  (  ho :   p %  2 =  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  2 =  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  (  h1 :  Nat.Prime  p ) ->  (  hp :   p %  2 =  1 ) ->   2 < p"]},
  {"theorem":
   "∀ {x y : ℤ},\n  PythagoreanTriple x y 1 → ∀ (z w : ℤ), PythagoreanTriple z w 1 → PythagoreanTriple (x * z) (x * w + y * z) (y * w)",
   "some-correct": null,
   "prompt":
   "The product of two numbers, each of which is the sum of four squares, is itself a sum of four squares.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  x y :  ℤ } ->   PythagoreanTriple  x y  1 →  ∀   (  z w  :  ℤ  )  ,   (   PythagoreanTriple  z w  1  ) →  PythagoreanTriple   (   x * z  )  (    x * w +  y * z  )  (   y * w  )",
    " {  x₁ x₂ y₁ y₂ z₁ z₂ :  ℕ } ->    PythagoreanTriple  x₁ y₁ z₁ ∧  PythagoreanTriple  x₂ y₂ z₂ →  PythagoreanTriple   (    x₁ * x₂ +  y₁ * y₂  )  (    x₁ * y₂ +  y₁ * x₂  )  (   z₁ * z₂  )",
    " {  a b :  ℕ } ->  (  ha :  ∃     x  y  z  w  :  ℕ ,      x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 = a ) ->  (  hb :  ∃     x  y  z  w  :  ℕ ,      x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 = b ) ->  ∃     x  y  z  w  :  ℕ ,      x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 =  a * b",
    " {  a b :  ℤ } ->  ∃    (   n  m  p  q :  ℤ ) ,    a =     n * n +  m * m +  p * p +  q * q ∧  b =     n * n +  m * m +  p * p +  q * q →  ∃    (   s  t  u  v :  ℤ ) ,   a * b =     s * s +  t * t +  u * u +  v * v",
    " {  x y :  ℤ } ->  (  hx :  ∃     a  b  c  d  :  ℤ ,  x =     a * a +  b * b +  c * c +  d * d ) ->  (  hy :  ∃     e  f  g  h  :  ℤ ,  y =     e * e +  f * f +  g * g +  h * h ) ->  ∃     a  b  c  d  :  ℤ ,   x * y =     a * a +  b * b +  c * c +  d * d"]},
  {"theorem":
   "∀ {X : Type u_1} [inst : TopologicalSpace X] [inst_1 : CompactSpace X], LocallyCompactSpace X",
   "some-correct": null,
   "prompt": "Every compact topological space is locally compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  LocallyCompactSpace  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  LocallyCompactSpace  α",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  LocallyCompactSpace  X",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  (  hX :  CompactSpace  X ) ->  LocallyCompactSpace  X",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  LocallyCompactSpace  α"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} [inst : UniformSpace α] [inst_1 : UniformSpace β] {f : α → β},\n  Continuous f → UniformContinuous f",
   "some-correct": null,
   "prompt": "Every continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  SeparatedSpace  α ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  s :  Set  α } ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  s :  Set  α } ->  {  f :  α → β } ->  (  hf :  ContinuousOn  f s ) ->  UniformContinuousOn  f s"]},
  {"theorem": "∀ (p q : ℕ), Nat.Prime p → Nat.Prime q → ¬(p + q = 6 ∧ p ≠ q)",
   "some-correct": null,
   "prompt": "`6` is not the sum of two distinct prime numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p q :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  hq :  Nat.Prime  q ) ->  ¬  (     p + q =  6 ∧  p ≠ q  )",
    " ¬  Nat.Prime   6",
    " ¬  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p ≠ q ∧   p + q =  6",
    " ¬  ∃    (   p  q :  ℕ ) ,    p + q =  6 ∧   Prime  p ∧  Prime  q",
    " ¬  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧    2 < p ∧    2 < q ∧   p + q =  6",
    " ¬  ∃    (   x  y :  ℕ ) ,    3 ≤ x ∧    3 ≤ y ∧   ¬  (   x = y  ) ∧   ¬  (   x =  2  ) ∧   ¬  (   y =  2  ) ∧   x + y =  6"]},
  {"theorem": "∀ {α : Type u} [inst : Semiringₓ α], IsUnit 1",
   "some-correct": null,
   "prompt": "The identity element in a ring is a unit.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Semiringₓ  α ] ->  IsUnit   (   1   : α )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  One  α ] ->  (  a : α ) ->  IsUnit  a",
    " {  α :  Type  u } ->  [  Semiring  α ] ->  (  a : α ) ->  IsUnit   1",
    " {  α :  Type  u } ->  [  Semiringₓ  α ] ->  (  a : α ) ->  IsUnit   1",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit  a",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  a : α ) ->  IsUnit   1",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit   1",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  e : α ) ->  (  he :   e * e = e ) ->  IsUnit  e",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit   (   1   : α )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit   (   1   : α )",
    " {  α :  Type  u } ->  [  Semiringₓ  α ] ->  [  One  α ] ->  IsUnit   (   1   : α )"]},
  {"theorem":
   "∀ {α : Type u} [inst : Groupₓ α] {s : Set α}, IsSubmonoid s → IsSubgroup s",
   "some-correct": null,
   "prompt": "Every subgroup of a group is a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Groupₓ  α ] ->  {  s :  Set  α } ->  (  hs :  IsSubmonoid  s ) ->  IsSubgroup  s"]},
  {"theorem": "∀ {m n : ℕ} (m n : ℕ), m + n = n + m",
   "some-correct": null,
   "prompt": "The sum of two natural numbers is a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  m n :  ℕ } ->  ∀   (  m n  :  ℕ  )  ,   m + n =  n + m",
    " {  m n :  ℕ } ->  ∃    (   a :  ℕ ) ,   m + n = a",
    " {  m n :  ℕ } ->   (   m + n   :  ℕ ) =  m + n",
    " {  m n :  ℕ } ->  ∃    (   k :  ℕ ) ,   m + n = k"]},
  {"theorem": "∀ {G : Type u} [inst : Groupₓ G], IsOfFinOrder 1",
   "some-correct": null,
   "prompt": "The identity element of a group has finite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  AddGroup  G ] ->  {  x : G } ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  AddGroupₓ  G ] ->  {  x : G } ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  IsOfFinOrder   (   1   : G )",
    " {  G :  Type  u } ->  [  Group  G ] ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  IsOfFinOrder   (   1   : G )",
    " {  G :  Type  u } ->  [  Group  G ] ->  (  g : G ) ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  g : G ) ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Group  G ] ->  (  a : G ) ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  a : G ) ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Group  G ] ->  (  x : G ) ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  IsOfFinOrder   1"]},
  {"theorem": "Nat.Prime 7",
   "some-correct": null,
   "prompt": "`7` is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs": [" Nat.Prime   7"]},
  {"theorem": "3 = 2 → 2 = 3",
   "some-correct": null,
   "prompt": "There are `3` prime numbers below `8`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  h :   3 =  2 ) ->   2 =  3",
    "  List.length   (   List.filter  Nat.Prime  (   List.range   (   8   :  ℕ )  )  ) =  3",
    "  List.length   (   List.filter  Nat.Prime  (   List.range   8  )  ) =  3"]},
  {"theorem": "∀ {α : Type u} (s : Finset α), ∅ ⊂ s",
   "some-correct": null,
   "prompt": "The empty set is contained in every finite set.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  (  s :  Finset  α ) ->   ∅ ⊆ s",
    " {  α :  Type* } ->  (  s :  Finset  α ) ->   ∅ ⊆ s",
    " {  α :  Type  u } ->  {  s :  Finset  α } ->   ∅ ⊆ s",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  (  s :  Finset  α ) ->   ∅ ⊆ s",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  (  s :  Set  α ) ->   ∅ ⊆ s",
    " (  n :  ℕ ) ->   ∅ ⊆  Finset.range  n"]},
  {"theorem": "{α : Type u} → [inst : CommRing α] → Monoid α",
   "some-correct": null,
   "prompt": "Every commutative ring is a monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  CommRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  Monoidₓ  α",
    " {  R :  Type  u } ->  [  CommRing  R ] ->  Monoid  R",
    " {  R :  Type  u } ->  [  CommRing  R ] ->  Monoidₓ  R",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  Monoid  R",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  Monoidₓ  R",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  NonUnitalCommRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  NonUnitalCommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u_1 } ->  [  NonUnitalRing  α ] ->  AddMonoid  α",
    " {  α :  Type  u_1 } ->  [  NonUnitalRing  α ] ->  AddMonoidₓ  α",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  AddMonoid  α",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  AddMonoidₓ  α",
    " {  α :  Type* } ->  [  CommRing  α ] ->  Monoid  α",
    " {  α :  Type* } ->  [  CommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type* } ->  [  CommRingₓ  α ] ->  Monoid  α",
    " {  α :  Type* } ->  [  CommRingₓ  α ] ->  Monoidₓ  α",
    " {  α :  Type  u_1 } ->  [  NonUnitalRing  α ] ->  Monoid  α",
    " {  α :  Type  u_1 } ->  [  NonUnitalRing  α ] ->  Monoidₓ  α"]},
  {"theorem": "¬IsPrimePow 10",
   "some-correct": null,
   "prompt": "There is no field of order `10`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ¬  IsPrimePow   10",
    " ¬  Nonempty   (   Field   (   Fin   10  )  )",
    " ¬  Nonempty   (   Field   (   Finₓ   10  )  )",
    " ¬   IsField   ℤ /  10"]},
  {"theorem": "∀ {m : ℕ}, m % 2 = 1 → ∃ n k, m = n + k ∧ n ≠ k",
   "some-correct": null,
   "prompt":
   "Every odd natural number is the sum of two distinct natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  m :  ℕ } ->  (  h :   m %  2 =  1 ) ->  ∃    (   n  k :  ℕ ) ,   m =  n + k ∧  n ≠ k",
    " {  n :  ℕ } ->    n %  2 =  1 →  ∃    (   m :  ℕ ) ,  (   ∃    (   l :  ℕ ) ,    m + l = n ∧  m ≠ l  )",
    " {  n :  ℕ } ->  (  h :   n %  2 =  1 ) ->  ∃     m  :  ℕ ,  n =  m +  (   m +  1  )",
    " {  n :  ℕ } ->  (  h1 :   n %  2 =  1 ) ->  ∃    (   i  j :  ℕ ) ,   i ≠ j ∧  n =   (     2 * i +  1  ) +  (     2 * j +  1  )",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m  k :  ℕ ) ,   n =  m + k ∧  m ≠ k",
    " (  n :  ℕ ) ->    n %  2 =  1 →  ∃    (   m  p :  ℕ ) ,    m + p = n ∧  m ≠ p",
    " {  m :  ℕ } ->  (  h1 :   m %  2 =  1 ) ->  ∃    (   n :  ℕ ) ,   n ≠ n.succ ∧  m =  n + n.succ",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m  k :  ℕ ) ,   m ≠ k ∧  n =  m + k",
    " {  n :  ℕ } ->  (  h₂ :   n %  2 =  1 ) ->  ∃    (   i :  ℕ ) ,   i ≠  n - i ∧   i +  (   n - i  ) = n",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃     i  j  :  ℕ ,   i ≠ j ∧   i + j = n",
    " {  n :  ℕ } ->  (  h :  Odd  n ) ->  ∃    (   a  b :  ℕ ) ,   n =  a + b ∧  a ≠ b",
    " {  n :  ℕ } ->  (  h_odd :   n %  2 =  1 ) ->  ∃    (   p  q :  ℕ ) ,   p ≠ q ∧  n =  p + q",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m  k :  ℕ ) ,    m + k = n ∧  m ≠ k",
    " {  n :  ℕ } ->  (  h :   n %  2 =  1 ) ->  ∃    (   k  hk :  ℕ ) ,   k ≠ hk ∧   k + hk = n"]},
  {"theorem":
   "∀ {G : Type u_1} {x : G} [inst : Groupₓ G], x = 1 → IsOfFinOrder x",
   "some-correct": null,
   "prompt": "Every element in the trivial group has finite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  {  x : G } ->  [  Groupₓ  G ] ->  (  hx1 :  x =  1 ) ->  IsOfFinOrder  x",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  H :  Subgroup  G ) ->  (  x : G ) ->  (  hx :  x ∈ H ) ->  IsOfFinOrder  x"]},
  {"theorem":
   "∀ {α : Type u} [inst : LinearOrderedSemiring α] {x : α}, Even x → Even (x * x)",
   "some-correct": null,
   "prompt": "The square of an even number is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  LinearOrderedSemiring  α ] ->  {  x : α } ->   Even  x →  Even   (   x * x  )",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  Even   (   n * n  )",
    " {  m :  ℕ } ->   Even  m →  Even   (   m ^  2  )",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  Even   (   n * n  )",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->    (   n ^  2  ) %  2 =  0",
    " {  n :  ℕ } ->   Even   (   n * n  ) ↔  Even  n",
    " {  n :  ℕ } ->   Even  n →  Even   (   n * n  )",
    " {  n :  ℕ } ->  Even   (   n ^  2  )",
    " {  x :  ℤ } ->   Even  x →  Even   (   x * x  )"]},
  {"theorem":
   "∀ (R : Type u) [inst : CommRing R] [inst : DivisionRing R], IsField R",
   "some-correct": null,
   "prompt": "Every commutative division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type  u ) ->  [  CommRing  R ] ->  [  DivisionRing  R ] ->  IsField  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->  [  DivisionRing  R ] ->  IsField  R",
    " {  K :  Type  u } ->  [  CommRing  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  CommRingₓ  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  CommRing  K ] ->  [  Nonempty  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  CommRingₓ  K ] ->  [  Nonempty  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  [  DivisionRing  α ] ->  IsField  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  [  DivisionRing  α ] ->  IsField  α"]},
  {"theorem": "∀ {α : Type u} [inst : Group α] {a : α}, id a⁻¹ = a⁻¹",
   "some-correct": null,
   "prompt":
   "The image of the identity element under the identity map is the identity element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Group  α ] ->  ∀   {  a  : α }  ,   id   ↑  (   a ⁻¹  ) =  a ⁻¹",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  ∀   {  a  : α }  ,   id   ↑  (   a ⁻¹  ) =  a ⁻¹",
    " {  α :  Type  u } ->  {  x : α } ->  [  Monoid  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  {  x : α } ->  [  Monoidₓ  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  One  α ] ->   id   1 =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->   id   1 =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->   id   1 =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->  (  x : α ) ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  (  x : α ) ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->  (  x : α ) ->   id  x = x",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  (  x : α ) ->   id  x = x",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Inv  α ] ->    (  id   :  α → α )   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Inv  α ] ->    (  id   :  α → α )   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->  (  a : α ) ->   id   (   id  a  ) = a",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  (  a : α ) ->   id   (   id  a  ) = a"]},
  {"theorem": "∀ {α : Type u} (x : α), Function.IsFixedPt id x",
   "some-correct": null,
   "prompt":
   "Every point is a fixed point of the identity function on a space.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  (  x : α ) ->  Function.IsFixedPt   (  id   :  α → α ) x",
    " {  α :  Type  u_1 } ->  (  x : α ) ->  Function.IsFixedPt  id x",
    " {  α :  Type  u } ->  (  x : α ) ->  Function.IsFixedPt  id x",
    " {  α :  Type* } ->  (  x : α ) ->  Function.IsFixedPt  id x",
    " {  α :  Type  u_1 } ->  {  x : α } ->  Function.IsFixedPt  id x",
    " {  α :  Type  u } ->  (  x : α ) ->  Function.IsFixedPt   (    @ id  α  ) x",
    " {  α :  Type  u } ->  {  x : α } ->  Function.IsFixedPt  id x"]},
  {"theorem": "∀ {G : Type u} [inst : Group G], Nonempty G",
   "some-correct": null,
   "prompt": "Every group is non-empty.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  Group  G ] ->  Nonempty  G",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  Nonempty  G",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  Nonempty  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  Nonempty  G",
    " {  G :  Type* } ->  [  Group  G ] ->  Nonempty  G",
    " {  G :  Type* } ->  [  Groupₓ  G ] ->  Nonempty  G",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  Nonempty  α",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  Nonempty  α",
    " {  α :  Type  u } ->  [  Group  α ] ->  Nonempty  α",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  Nonempty  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] (x : α), IsConnected (ConnectedComponent x)",
   "some-correct": null,
   "prompt": "All connected components of a topological space are connected.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  x : α ) ->  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  ∀   (  x  : α  )  ,  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  Z :  Set  α } ->  (  h :  ConnectedComponent  Z ) ->  IsConnected  Z",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  ∀   {  x  : α }  ,  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  x : α } ->  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  t : α ) ->  IsConnected   (   ConnectedComponent  t  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  X :  ConnectedComponents  α } ->  IsConnected  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  U :  Set  α } ->  (  hU :  ∃    (   x : α ) ,  U =  ConnectedComponent  x ) ->  IsConnected  U",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  x : α } ->  IsConnected   (   ConnectedComponent  x  )"]},
  {"theorem": "PythagoreanTriple 3 4 5",
   "some-correct": null,
   "prompt": "The numbers `3`, `4` and `5` form a Pythagorean triple.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" PythagoreanTriple   3  4  5", " PythagoreanTriple   3  4  5"]}],
 "elaborated": 34}