{"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.",
  "Every element in the trivial group has finite order.",
  "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 :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->   p =  2 ∨   p %  2 =  1",
    " {  p :  ℕ } ->   Nat.Prime  p →   p =  2 ∨  Odd  p",
    " {  p :  ℕ } ->   Nat.Prime  p →   p =  2 ∨   p %  2 =  1",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->   p =  2 ∨  ¬  Even  p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->   p =  2 ∨  Odd  p"]},
  {"theorem": "∀ ⦃n : ℕ⦄, ∃ m, n < m ∧ Odd m",
   "some-correct": null,
   "prompt": "There are infinitely many odd natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃    (   m :  ℕ ) ,  ∃    (   n :  ℕ ) ,   m ≠  2 ∧  m =  n ^  2",
    " ∃    (   m :  ℕ ) ,  ∀   (  n  :  ℕ  )  ,  m <   2 * n",
    " ∀   ⦃  n  :  ℕ ⦄  ,  ∃    (   m :  ℕ ) ,   n < m ∧  Odd  m",
    " ∃    (   n :  ℕ ) ,   n %  2 =  1",
    " ∀  n  ,  ∃     m  ,   m > n ∧  (    m %  2 =  1  )",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   n < p ∧  (    p %  2 =  1  )",
    " ∀  n  ,  ∃  m  > n ,   m %  2 =  1",
    " ∀   (  b  :  ℕ  )  ,  ∃    (   n :  ℕ ) ,    n %  2 =  1 ∧  n ≥ b",
    " ∃    (   f :   ℕ →  ℕ ) ,  ∀   (  a b  :  ℕ  )  ,   a < b →   f  a <  f  b",
    " ∀  m   :  ℕ ,  ∃     n  :  ℕ ,   n > m ∧  Odd  n",
    " ∃     m  :  ℕ ,  Odd  m",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,   n < m ∧  Odd  m"]},
  {"theorem": "Fact (Nat.Prime 3)",
   "some-correct": null,
   "prompt": "The smallest odd prime is `3`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" Fact   (   Nat.Prime   3  )",
    " Nat.Prime   3",
    " ∀  n  ,   n ≥  3 →    n %  2 =  1 →    n %  3 ≠  0 →   Nat.Prime  n →  n =  3"]},
  {"theorem": "∀ (n : ℕ), ∃ p, n < p ∧ Nat.Prime p ∧ p % 2 = 1",
   "some-correct": null,
   "prompt": "There are infinitely many odd prime numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   n < p ∧   Nat.Prime  p ∧   p %  2 =  1",
    " ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Odd  p",
    " [  Fact   (    2 ≠  0  ) ] ->  ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Odd  p ∧  p > n",
    " ∃    (   f :   ℕ →  ℕ ) ,   (   ∀   (  n  :  ℕ  )  ,  Nat.Prime   (   f  n  )  ) ∧  ∀   (  p q  :  ℕ  )  ,   Nat.Prime  p →   Nat.Prime  q →   p ≠ q →   f  p ≠  f  q",
    " ∀   {  p  :  ℕ }  ,  ∃     q  :  ℕ ,   Odd  q ∧   p < q ∧  Prime  q",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   a :  ℕ ) ,   n < a ∧   Nat.Prime  a ∧    (  a   :  ℕ ) %  2 =  1",
    " ∃     p  :  ℕ ,   p >  2 ∧  Nat.Prime  p",
    " ∀   {  n  :  ℕ }  ,  ∃    (   p :  ℕ ) ,   n ≤ p ∧   Nat.Prime  p ∧  Odd  p",
    " ∀  k   :  ℕ ,  ∃     p  ,   Nat.Prime  p ∧   p >  2 ∧    p %  2 =  1 ∧  p ≥   2 ^ k"]},
  {"theorem":
   "∀ {K : Type u} {V : Type v} [inst : DivisionRing K] [inst_1 : AddCommGroupₓ V] [inst_2 : Module K V],\n  2 ≤ Module.rank K V → 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 :   2 ≤  Module.rank  K V ) ->  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 ] ->    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",
    " (  K :  Type  u ) ->  [  Field  K ] ->  DivisionRing  K",
    " {  α :  Type  u } ->  [  Field  α ] ->  DivisionRing  α",
    " {  K :  Type  u_1 } ->  [  Field  K ] ->  DivisionRing  K",
    " (  α :  Type  u ) ->  [  Field  α ] ->  DivisionRing  α",
    " {  F :  Type  u } ->  [  Field  F ] ->  DivisionRing  F"]},
  {"theorem":
   "∀ {K : Type u} {V : Type v} [inst : DivisionRing K] [inst_1 : AddCommGroupₓ V] [inst_2 : Module K V],\n  2 ≤ Module.rank K V → 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 :   2 ≤  Module.rank  K V ) ->  FiniteDimensional  K V",
    " (  K :  Type  u ) ->  (  V :  Type  v ) ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  FiniteDimensional  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 ] ->  (  n :   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 ] ->    2 ≤  Module.rank  K V →  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 ] ->    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": "∀ {n : ℕ}, ∃ m, m = n + 1",
   "some-correct": null,
   "prompt": "Every natural number has a successor.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  ∃    (   m :  ℕ ) ,  m =  (   n +  1  )",
    " {  n :  ℕ } ->  ∃    (   x :  ℕ ) ,  n < x",
    " {  n :  ℕ } ->  ∃     s  :  ℕ ,  n < s",
    " (  n :  ℕ ) ->  ∃    (   m :  ℕ ) ,  n < m",
    " ∀  a   :  ℕ ,  ∃     b  :  ℕ ,   b ≥  1 ∧  ∀  c   :  ℕ ,   c ≥  1 →   a < c →  b < c",
    " {  n :  ℕ } ->  ∃    (   m :  ℕ ) ,  n < m",
    " {  n :  ℕ } ->  n <  n +  1",
    " {  n :  ℕ } ->  ∃    (   m :  ℕ ) ,  n =  m +  1",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m :  ℕ ) ,  n < m",
    " ∀   (  x  :  ℕ  )  ,  ∃    (   y :  ℕ ) ,  x < y",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,  m =  n +  1"]},
  {"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 m :  ℕ } ->  (  h :  n ≤ m ) ->  n ≤  m +  1",
    " {  n :  ℕ } ->  n <  n +  1",
    " {  n :  ℕ } ->  n < n.succ",
    " ∀   (  n  :  ℕ  )  ,  n <  n +  1",
    " {  n :  ℕ } ->  (  hn :  n ≠  0 ) ->  n <  Order.succ  n",
    " (  a :  ℕ ) ->  a < a.succ"]},
  {"theorem":
   "∀ {α : Type u_1} {s : Set α} {m : MeasurableSpace α}, MeasurableSet s",
   "some-correct": null,
   "prompt": "Every set is Lebesgue measurable.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  s :  Set  α } ->  {  m :  MeasurableSpace  α } ->  MeasurableSet  s",
    " {  α :  Type  u_1 } ->  {  m :  MeasurableSpace  α } ->  (  s :  Set  α ) ->  MeasurableSet  s",
    " ∀  s  ,  MeasurableSet  s",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->  MeasurableSet  s",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  {  s :  Set  α } ->  MeasurableSet  s"]},
  {"theorem": "∀ {p : ℕ} [inst : Fact (Nat.Prime p)], ¬∃ n, n * n = p",
   "some-correct": null,
   "prompt": "No prime number is a perfect square.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   n :  ℕ ) ,   n * n = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   n :  ℕ ) ,   n * n = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   q :  ℕ ) ,   q * q = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   t :  ℕ ) ,   t * t = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :  p ≠  2 ) ->  ¬  ∃    (   m :  ℕ ) ,   m * m = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   x :  ℕ ) ,  p =  x ^  2",
    " {  p :  ℕ } ->  [ h :  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   t :  ℕ ) ,   t * t = p",
    " {  p :  ℕ } ->  (  hp :  Nat.Prime  p ) ->  ¬  ∃    (   n :  ℕ ) ,   n * n = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  ¬  ∃    (   m :  ℕ ) ,  Nat.Prime   (   m * m  )"]},
  {"theorem": "∀ (p : ℕ) [hpri : Fact (Nat.Prime p)], p % 2 = 1 → 2 < p",
   "some-correct": null,
   "prompt": "Every odd prime number is greater than `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p :  ℕ ) ->  [ hpri :  Fact   (   Nat.Prime  p  ) ] ->  (  h_odd :   p %  2 =  1 ) ->   2 < p",
    " (  p :  ℕ ) ->  [ hpri :  Fact   (   Nat.Prime  p  ) ] ->  p >  2",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->   p ≥  3 ↔   p %  2 =  1",
    " {  p :  ℕ } ->  (  hp :  Nat.Prime  p ) ->  (  hodd :   p %  2 =  1 ) ->  p >  2",
    " {  p :  ℕ } ->  (  h_odd_prime :  Odd  p ) ->  (  h_prime :  Nat.Prime  p ) ->   2 < p",
    " (  p :  ℕ ) ->  [ hp :  Fact   (   Nat.Prime  p  ) ] ->  (  h_odd :  Odd  p ) ->   2 < p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h_odd :   p %  2 =  1 ) ->   2 < p",
    " (  p :  ℕ ) ->  (  h :  Nat.Prime  p ) ->  (  h2 :   2 < p ) ->   p %  2 =  1",
    " (  p :  ℕ ) ->    Nat.Prime  p ∧  p ≠  2 →   1 < p"]},
  {"theorem":
   "∀ {a b : ℤ},\n  a ^ 2 + a ^ 2 + b ^ 2 + b ^ 2 = a * b →\n    ∃ c d e f, a = c ^ 2 + c ^ 2 + d ^ 2 + d ^ 2 ∧ b = e ^ 2 + e ^ 2 + f ^ 2 + f ^ 2",
   "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":
   [" {  a b :  ℤ } ->       a ^  2 +  a ^  2 +  b ^  2 +  b ^  2 =  a * b →  ∃    (   c  d  e  f :  ℤ ) ,   a =     c ^  2 +  c ^  2 +  d ^  2 +  d ^  2 ∧  b =     e ^  2 +  e ^  2 +  f ^  2 +  f ^  2",
    " {  x y :  ℕ } ->  (  hx :  ∃    (   a  α  b  β  c  γ  d  δ :  ℕ ) ,      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 = x ) ->  (  hy :  ∃    (   a  α  b  β  c  γ  d  δ :  ℕ ) ,      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 = y ) ->  ∃    (   f  ϕ  g  γ  h  η  i  ι :  ℕ ) ,      f ^  2 +  g ^  2 +  h ^  2 +  i ^  2 =  x * y",
    " {  a b :  ℕ } ->  ∃    (   u  v  w  x :  ℕ ) ,   a =     u ^  2 +  v ^  2 +  w ^  2 +  x ^  2 ∧  ∃    (   s  t  r  y :  ℕ ) ,   a * b =     s ^  2 +  t ^  2 +  r ^  2 +  y ^  2",
    " {  x y :  ℕ } ->  (  hx :  ∃     a  b  c  d  ,  x =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->  (  hy :  ∃     a  b  c  d  ,  y =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->  ∃     a  b  c  d  ,   x * y =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2"]},
  {"theorem":
   "∀ {X : Type u} [inst : TopologicalSpace X], CompactSpace X → LocallyCompactSpace X",
   "some-correct": null,
   "prompt": "Every compact topological space is locally compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  (  h :  CompactSpace  X ) ->  LocallyCompactSpace  X",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  LocallyCompactSpace  X",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  (  h :  CompactSpace  X ) ->  LocallyCompactSpace  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  LocallyCompactSpace  α",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  LocallyCompactSpace  α",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  (  hX :  CompactSpace  X ) ->  LocallyCompactSpace  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  LocallyCompactSpace  α",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  LocallyCompactSpace  X"]},
  {"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 } ->  {  β :  Type  v } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f"]},
  {"theorem": "∀ {a b : ℕ}, Nat.Prime a → Nat.Prime b → a ≠ b → ¬a + b = 6",
   "some-correct": null,
   "prompt": "`6` is not the sum of two distinct prime numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀   {  a b  :  ℕ }  ,   Nat.Prime  a →   Nat.Prime  b →   a ≠ b →  ¬   a + b =  6",
    "   (   6   :  ℕ ) ≠   1 +  5 ∧   6 ≠   2 +  4",
    " ∀   (  p q  :  ℕ  )  ,   Nat.Prime  p →   Nat.Prime  q →   p ≠  6 →   q ≠  6 →   p + q ≠  6",
    " ¬  ∃    (   a  b :  ℕ ) ,   a < b ∧   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b =  6",
    " (  p q :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  [  Fact   (   Nat.Prime  q  ) ] ->   p + q ≠  6"]},
  {"theorem": "∀ {α : Type u} [inst : Ringₓ α] (a : α), IsUnit a",
   "some-correct": null,
   "prompt": "The identity element in a ring is a unit.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit  a",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  One : α ) ->  (  a : α ) ->  IsUnit   (   One * a  )",
    " {  α :  Type  u } ->  [  Semiringₓ  α ] ->  (  a : α ) ->   IsUnit  a →  a =  1",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  r : α ) ->  (  h :   r *  1 = r ) ->  IsUnit  r",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  x : α ) ->  IsUnit  x",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  One  α ] ->  (  a : α ) ->  IsUnit   (   1   : α )",
    " {  α :  Type* } ->  [  Ringₓ  α ] ->  (  One : α ) ->  (  Eq :   1 = One ) ->  IsUnit  One",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  a : α ) ->  IsUnit   1",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit   1",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  IsUnit   (   1   : α )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  IsUnit   (   1   : α )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  a : α ) ->  (  h :  a =  1 ) ->  IsUnit  a"]},
  {"theorem": "∀ {α : Type} [inst : Groupₓ α] {S : Set α}, IsSubgroup S",
   "some-correct": null,
   "prompt": "Every subgroup of a group is a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  } ->  [  Groupₓ  α ] ->  {  S :  Set  α } ->  IsSubgroup  S"]},
  {"theorem": "∀ {m n : ℕ}, m + n = m + n",
   "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  )",
    " {  m n :  ℕ } ->   m + n >  0",
    " {  m n :  ℕ } ->   (   m + n   :  ℕ ) =  m + n"]},
  {"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 } ->  [  Group  G ] ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  IsOfFinOrder   (   1   : G )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->   IsOfFinOrder  x ↔  (   x =  1  )"]},
  {"theorem": "Nat.Prime 7",
   "some-correct": null,
   "prompt": "`7` is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" Nat.Prime   7",
    " Nat.Prime   7",
    " Prime   7",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->   p >  6 →  p ∈  {   2 ,  3 ,  5 ,  7 ,  11 ,  13 ,  17 ,  19 }"]},
  {"theorem": "∀ (p : ℕ), p < 8 → Nat.Prime p → p = 2 ∨ p = 3 ∨ p = 5 ∨ p = 7",
   "some-correct": null,
   "prompt": "There are `3` prime numbers below `8`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p : Nat ) ->   p <  8 →   Nat.Prime  p →  (     (  p   :  ℕ ) =  2 ∨   p =  3 ∨   p =  5 ∨  p =  7  )",
    "  List.length   (   List.filter   (   λ   ( p :  ℕ ) ,  Prime  p  )  (   List.range   7  )  ) =  3"]},
  {"theorem": "∀ {α : Type u} [inst : Fintype α] (s : Set α), ∅ ⊂ s",
   "some-correct": null,
   "prompt": "The empty set is contained in every finite set.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Fintype  α ] ->  (  s :  Set  α ) ->   ∅ ⊆ s",
    " {  S :  Type* } ->  (  F :  Finset  S ) ->   ∅ ⊆ F",
    " {  α :  Type  u } ->  {  S :  Set  α } ->   ∅ ⊆ S",
    " {  α :  Type  u } ->  (  s :  Set  α ) ->   ∅ ⊆ s",
    " {  α :  Type  u } ->  (  s :  Finset  α ) ->   ∅ ⊆ s"]},
  {"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_1 } ->  [  CommRing  α ] ->  Monoid  α",
    " {  α :  Type  u_1 } ->  [  CommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u_1 } ->  [  CommRingₓ  α ] ->  Monoid  α",
    " {  α :  Type  u_1 } ->  [  CommRingₓ  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  NonUnitalCommRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  NonUnitalCommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u_1 } ->  [  NonUnitalRing  α ] ->  CommMonoid  α",
    " {  α :  Type  u_1 } ->  [  NonUnitalRing  α ] ->  CommMonoidₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  Monoidₓ  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  Monoid  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  Monoidₓ  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : Fintype α], Fintype.card α = 10 → ¬Nonempty (Field α)",
   "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  )  )",
    " Nonempty   (   Field   (   Fin   10  )  )",
    " Nonempty   (   Field   (   Finₓ   10  )  )",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  (  h :   Fintype.card  α =  10 ) ->  ¬  Nonempty   (   Field  α  )"]},
  {"theorem": "∀ {m n : ℕ} (a : Odd m), ∃ a b, a ≠ b ∧ m = a + b",
   "some-correct": null,
   "prompt":
   "Every odd natural number is the sum of two distinct natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  m n :  ℕ } ->   Odd  m →  ∃    (   a  b :  ℕ ) ,   a ≠ b ∧  m =  a + b",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m :  ℕ ) ,  n =  m + m.succ",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m :  ℕ ) ,  n =  m +  (   m +  1  )",
    " {  n :  ℕ } ->  (  h_odd :   n %  2 =  1 ) ->  ∃    (   m :  ℕ ) ,   m ≠  n - m ∧   m +  (   n - m  ) = n",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m  k :  ℕ ) ,   k ≠ m ∧  n =  m + k",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  1 ) ->  ∃    (   m  k :  ℕ ) ,    m + k = n ∧  m ≠ k",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  1 ) ->  ∃    (   a  b :  ℕ ) ,   a ≠ b ∧  n =  a + b",
    " {  n :  ℕ } ->  (  hn :   (   1   :  ℕ ) ≤ n ) ->  (  h :   n %  2 =  1 ) ->  ∃     m  k  :  ℕ ,   m ≠ k ∧   m + k = n",
    " {  n :  ℕ } ->    n %  2 =  1 →  ∃    (   m  k :  ℕ ) ,   k < m ∧  n =  m + k",
    " {  n :  ℕ } ->  (  h :   n %  2 =  1 ) ->  ∃    (   a  b :  ℕ ) ,   a ≠ b ∧  n =  a + b",
    " {  n :  ℕ } ->  (  h :   n %  2 =  1 ) ->  ∃    (   m  k :  ℕ ) ,   m ≠ k ∧  n =  m + k",
    " (  n :  ℕ ) ->  (  hn :   n %  2 =  1 ) ->  ∃    (   a  b :  ℕ ) ,   a ≠ b ∧  n =  a + b"]},
  {"theorem":
   "∀ {α : Type u} [inst : LinearOrderedRing α] {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 } ->  [  LinearOrderedRing  α ] ->  {  x : α } ->  (  hx :  Even  x ) ->  Even   (   x * x  )",
    " {  n :  ℕ } ->  Even   (   n * n  )",
    " {  n :  ℕ } ->   Even  n →  Even   (   n * n  )",
    " {  n :  ℕ } ->   Even  n →  Even   (   n ^  2  )",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a : α } ->  (  ha :  Even  a ) ->  Even   (   a * a  )",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a : α } ->  (  ha :  Even  a ) ->  Even   (   a * a  )",
    " {  n :  ℕ } ->   Even   (   n ^  2  ) ↔  Even  n",
    " {  x :  ℕ } ->  (  h :  Even  x ) ->  Even   (   x * x  )",
    " {  n :  ℕ } ->   Even   (   n * n  ) ↔  Even  n",
    " {  m :  ℕ } ->  (  m_even :  Even  m ) ->  Even   (   m * m  )",
    " {  n :  ℕ } ->   Even   (    2 * n  ) →  Even   (   n * n  )",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  n :  ℕ } ->  (  hn :  Even  n ) ->  Even   (   n * n  )",
    " {  n :  ℕ } ->   Even   (    2 * n  ) →   Even   (    2 * n  ) ^  2",
    " {  m n :  ℕ } ->   Even   (    m * m +  n * n  ) →  Even  m"]},
  {"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",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  [  DivisionRing  α ] ->  IsField  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  [  DivisionRing  α ] ->  IsField  α",
    " {  K :  Type  u } ->  [  Field  K ] ->  (  h :  CommRing  K ) ->  IsField  K",
    " {  K :  Type  u } ->  [  Field  K ] ->  (  h :  CommRingₓ  K ) ->  IsField  K"]},
  {"theorem": "∀ {α : Type u} [inst : Monoid α], id 1 = 1",
   "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 } ->  [  Monoid  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  One  α ] ->  (  x : α ) ->   x *  1 = x",
    " {  α :  Type  u } ->  [  Group  α ] ->  (  a : α ) ->   (   id   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  (  a : α ) ->   (   id   1   : α ) =  1",
    " {  α :  Type  u_1 } ->  [  One  α ] ->   id   1 =  1",
    " {  α :  Type  u } ->  [  Zero  α ] ->   (   0   : α ) =  0",
    " {  α :  Type  u } ->  [  One  α ] ->   id   1 =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->   id   (   1   : α ) =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->   (   id   1   :  α → α ) =  1",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->   (   id   1   :  α → α ) =  1",
    " {  α :  Type  u } ->  [  Group  α ] ->  (  x : α ) ->   id   (   x *  1  ) = x",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  (  x : α ) ->   id   (   x *  1  ) = x"]},
  {"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 } ->  {  x : α } ->  Function.IsFixedPt  id x",
    " {  α :  Type  u } ->  (  x : α ) ->  Function.IsFixedPt   (  id   :  α → α ) x",
    " {  α :  Type  u } ->  {  a : α } ->  Function.IsFixedPt  id a",
    " {  α :  Type  u_1 } ->  {  x : α } ->  Function.IsFixedPt   (    @ id  α  ) x"]},
  {"theorem":
   "∀ {α : Type u} [inst : PseudoEmetricSpace α] (a : α), Emetric.diam { b | b = a } = 0",
   "some-correct": null,
   "prompt": "The diameter of a singleton space is `0`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  PseudoMetricSpace  α ] ->  (  a : α ) ->   Metric.diam   (    {  aa }  {    aa    }   :  Set  α ) =  0",
    " {  α :  Type  u } ->  [  PseudoEmetricSpace  α ] ->  {  x : α } ->   Emetric.diam   (    {  xx }  {    xx    }   :  Set  α ) =  0",
    " {  α :  Type  u } ->  [  PseudoEmetricSpace  α ] ->  (  a : α ) ->   Emetric.diam   (    {  aa }  {    aa    }   :  Set  α ) =  0",
    " {  α :  Type  u } ->  [  PseudoEmetricSpace  α ] ->  (  a : α ) ->   Emetric.diam   {   b  |  b = a } =  0"]},
  {"theorem": "∀ {α : Type u_1} [inst : Group α], Nonempty α",
   "some-correct": null,
   "prompt": "Every group is non-empty.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  Group  α ] ->  Nonempty  α",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  Nonempty  α",
    " {  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  u } ->  (  g : G ) ->  [  Group  G ] ->  Nonempty  G",
    " {  G :  Type  u } ->  (  g : G ) ->  [  Groupₓ  G ] ->  Nonempty  G",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  Nonempty  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  Nonempty  G",
    " {  α :  Type* } ->  [  Group  α ] ->  Nonempty  α",
    " {  α :  Type* } ->  [  Groupₓ  α ] ->  Nonempty  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {C : Set α}, { x // Membership.Mem x (ConnectedComponent C) } → IsConnected C",
   "some-correct": null,
   "prompt": "All connected components of a topological space are connected.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  C :  Set  α } ->  (  H :  ConnectedComponent  C ) ->  IsConnected  C",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  ∀   (  x  : α  )  ,  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  x : α ) ->  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  x  : α  )  ,  ConnectedComponent  x ) ->  ∀   (  x  : α  )  ,  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  ∀   (  x  :  ConnectedComponents  α  )  ,  IsConnected  x",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  TotallyDisconnectedSpace  α ) ->  ∀   {  x  : α }  ,  IsConnected   (   ConnectedComponent  x  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  x : α } ->  IsConnected   (   ConnectedComponent  x  )"]},
  {"theorem": "∀ {x y : ℤ}, x ^ 2 + y ^ 2 = 25 → 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",
    " ∃    (   m  n :  ℕ ) ,   3 =   m ^  2 +  n ^  2",
    " {  x y :  ℤ } ->  (  h :    x ^  2 +  y ^  2 =  25 ) ->  PythagoreanTriple   3  4  5"]}],
 "elaborated": 34}