{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 0,
 "number-keyword-sentences": 0,
 "include-fixed": true,
 "failures":
 ["If a vector space has dimension `2` then it is finite dimensional.",
  "If a space has dimension `2` then it is finite dimensional.",
  "Every set is Lebesgue measurable.",
  "Every set of Borel measure zero is Lebesgue measurable.",
  "No integer is irrational.",
  "Every infinite set contains a finite set.",
  "There is no field of order `10`.",
  "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 : ℕ), Prime p → p = 2 ∨ ∃ q, p = 2 * q + 1",
   "some-correct": null,
   "prompt": "Every prime number is `2` or odd.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p :  ℕ ) ->  (  hp :  Prime  p ) ->   p =  2 ∨  ∃     q  :  ℕ ,  p =    2 * q +  1",
    " (  n :  ℕ ) ->  (  hn :  Prime  n ) ->   ¬  (   n =  2  ) →  ∃     m  :  ℕ ,     2 * m +  1 = n",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->   p =  2 ∨   p %  2 =  1",
    " (  n :  ℕ ) ->  (  hnprime :  Prime  n ) ->   n =  2 ∨  (    n ≠  2 ∧   n %  2 =  1  )",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->   p =  2 ∨  Odd  p",
    " (  n :  ℕ ) ->  (  h :  Prime  n ) ->   n =  2 ∨   n %  2 =  1",
    " (  n :  ℕ ) ->  (  h :  Prime  n ) ->   n =  2 ∨  (   ∃     m  :  ℕ ,  n =    2 * m +  1  )",
    " (  n :  ℕ ) ->  (  h :  Prime  n ) ->   (   n =  2  ) ∨  (   ∃     k  ,  n =    2 * k +  1  )",
    " (  n :  ℕ ) ->  (  hp :  Prime  n ) ->   n =  2 ∨  ¬  Even  n",
    " (  p :  ℕ ) ->  (  h1 :  Prime  p ) ->   p =  2 ∨   p %  2 =  1",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->   p =  2 ∨   p %  2 =  1",
    " (  p :  ℕ ) ->  (  h :  Prime  p ) ->  (  h1 :  p ≠  2 ) ->  ∃     q  ,  p =    2 * q +  1"]},
  {"theorem": "∀ (n : ℕ), ∃ m, m > n ∧ m % 2 = 1",
   "some-correct": null,
   "prompt": "There are infinitely many odd natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀  n m   :  ℕ ,   n ≠ m →     2 * n +  1 ≠    2 * m +  1",
    " ∃     n  :  ℕ ,  ¬  ∃     m  :  ℕ ,  n =   2 * m",
    " ∃     n  :  ℕ ,   n %  2 =  1",
    " ∀  n   :  ℕ ,  ∃     m  :  ℕ ,   m > n ∧   m %  2 =  1",
    " Nonempty   (   ∃     n  :  ℕ ,    n %  2 =  1 ∧  ∀  m  ,   m < n →   m %  2 =  0  )",
    " ∃     n  :  ℕ ,  ∃  m  > n ,   m %  2 =  1",
    " ∀  n   :  ℕ ,  ∃     m  ,   m > n ∧   m %  2 =  1",
    " ∃     m  :  ℕ ,  ∀  n   :  ℕ ,   n ≠ m →   m %  2 =  1",
    " Nonempty   ℕ",
    " ∀  n   :  ℕ ,  ∃     k  :  ℕ ,   n <    2 * k +  1 ∧   k %  2 =  1",
    " ∀  N   :  ℕ ,   (     2 * N +  1  ) <   2 *  (   N +  1  )",
    " ∃    (   f :   ℕ →  ℕ ) ,  ∀  x   :  ℕ ,   x <  f  x ∧    (   f  x  ) %  2 =  1"]},
  {"theorem": "∀ (p : ℕ), Prime p → p = 3 ∨ p ≥ 5",
   "some-correct": null,
   "prompt": "The smallest odd prime is `3`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀  p   :  ℕ ,   Prime  p →   p =  3 ∨  p ≥  5",
    " ∀  a   :  ℕ ,   a <  3 ∨  a =  3",
    " Prime   3",
    " (  n :  ℕ ) ->  (  hp :  Prime  n ) ->  (  h3 :  n >  3 ) ->  n =  3",
    " ∃     x  ,   Prime  x ∧   ¬  (   ∃  y  < x ,  Prime  y  ) ∧   x %  2 =  1",
    " Nat.Prime   3",
    " Prime   3",
    " ∃     p  :  ℕ ,   Prime  p ∧  ∀  q   :  ℕ ,   Prime  q →    3 ≤ q →  q =  3",
    " Prime   3",
    " (  x :  ℕ ) ->  (  hx :  Prime  x ) ->  x =  3"]},
  {"theorem":
   "∀ (p : ℕ), Prime p → p % 2 = 1 → ∃ q, q > p ∧ Prime q ∧ q % 2 = 1",
   "some-correct": null,
   "prompt": "There are infinitely many odd prime numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃     n  :  ℕ ,  ∃     p  :  ℕ ,   Prime  p ∧  p ≥ n",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   p > n ∧   Prime  p ∧   (   p %  2  ) ≠  0",
    " ∃    (   p :  ℕ )  (   hp :  Prime  p ) ,  ∀  q   :  ℕ ,   Prime  q →  q < p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp_odd :   p %  2 =  1 ) ->  ∃     q  :  ℕ ,   q > p ∧   Prime  q ∧   q %  2 =  1",
    " ∃    (   p :  ℕ )  (   h :   Prime  p ∧   p %  2 =  1 ) ,  ∀   (  q  :  ℕ  )  (  h'  :   Prime  q ∧   q %  2 =  1  )  ,  p ≠ q",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   Prime  p ∧  p > n",
    " ∀  m   :  ℕ ,  ∃     p  :  ℕ ,   Prime  p ∧   p >  2 ∧  p > m",
    " ∀  n   :  ℕ ,  ∃     m  :  ℕ ,   m > n ∧   Prime  m ∧   m %  2 =  1"]},
  {"theorem": "(F : Type ?u.20554) → [inst : Field F] → DivisionRing F",
   "some-correct": null,
   "prompt": "Every field is a division ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  F :  Type* ) ->  [  Field  F ] ->  DivisionRing  F",
    " (  R :  Type* ) ->  [  Field  R ] ->  DivisionRing  R",
    " (  R :  Type* ) ->  [  Field  R ] ->  (  x : R ) ->  (  hx :  x ≠  0 ) ->  ∃     y  : R ,   y * x =  1",
    " (  k :  Type* ) ->  [  Field  k ] ->  DivisionRing  k",
    " (  K :  Type* ) ->  [  Field  K ] ->  DivisionRing  K",
    " (  α :  Type* ) ->  [  DivisionRing  α ] ->  Field  α"]},
  {"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 :  ℕ ) ->  ∃     m  :  ℕ ,  m > n",
    " (  n :  ℕ ) ->  ∃     m  ,  n =  m +  1",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,  n = m.succ",
    " (  x :  ℕ ) ->  ∃     a  ,  a =  x +  1",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,  n =  m +  1",
    " (  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   :  ℕ ,  n <  n +  1",
    " (  n :  ℕ ) ->  n <  n +  1",
    " (  n :  ℕ ) ->  n ≤  n +  1"]},
  {"theorem": "∀ (p : ℕ), Prime p → ∀ (n : ℕ), p ≠ n * n",
   "some-correct": null,
   "prompt": "No prime number is a perfect square.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  ∀  n  ,  p ≠  n * n",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  ∀  n   :  ℕ ,   n ^  2 ≠ p",
    " (  p :  ℕ ) ->  (  h1 :  Prime  p ) ->  (  hp :  ∃     m  ,  p =  m ^  2 ) ->  p =  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  ¬  ∃     n  ,   n ^  2 = p"]},
  {"theorem": "∀ (p : ℕ), Prime p → p % 2 = 1 → p > 2",
   "some-correct": null,
   "prompt": "Every odd prime number is greater than `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp_odd :   p %  2 =  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hodd :   p %  2 =  1 ) ->  p >  2",
    " {  p :  ℕ } ->  (  h2 :  Prime  p ) ->  (  h3 :   2 ∣ p ) ->  p >  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h :   p %  2 =  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp_odd :   p %  2 =  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  (  h :  Prime  p ) ->  (  odd_p :   2 ∣  p -  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hop :   p %  2 =  1 ) ->   2 < p",
    " ∀  p   :  ℕ ,   Prime  p →   Odd  p →  p >  2",
    " ∀  p   :  ℕ ,    Prime  p ∧   p %  2 =  1 →  p >  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hpodd :   p %  2 =  1 ) ->  p >  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp_odd :  ¬  (   ∃     n  :  ℕ ,   n >  2 ∧  p =    2 * n +  1  ) ) ->   2 < p",
    " (  p :  ℕ ) ->  (  h1 :  Prime  p ) ->  (  h2 :  ¬  (    (  p   :  ℕ ) =  2  ) ) ->   2 < p",
    " (  p :  ℕ ) ->  (  hp1 :   2 ∣  p -  1 ) ->  (  hp2 :  ¬  p ∣  p -  1 ) ->  p >  2"]},
  {"theorem":
   "∀ (a b : ℕ),\n  (∃ a1 a2 a3 a4 b1 b2 b3 b4, a = a1 ^ 2 + a2 ^ 2 + a3 ^ 3 + a4 ^ 4 ∧ b = b1 ^ 2 + b2 ^ 2 + b3 ^ 3 + b4 ^ 4) →\n    ∃ a1 a2 a3 a4 b1 b2 b3 b4, a * b = a1 ^ 2 + a2 ^ 2 + a3 ^ 3 + a4 ^ 4 + b1 ^ 2 + b2 ^ 2 + b3 ^ 3 + b4 ^ 4",
   "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 :  ℕ ) ->  (  h :  ∃     a1  a2  a3  a4  b1  b2  b3  b4  :  ℕ ,   a =     a1 ^  2 +  a2 ^  2 +  a3 ^  3 +  a4 ^  4 ∧  b =     b1 ^  2 +  b2 ^  2 +  b3 ^  3 +  b4 ^  4 ) ->  ∃     a1  a2  a3  a4  b1  b2  b3  b4  :  ℕ ,   a * b =         a1 ^  2 +  a2 ^  2 +  a3 ^  3 +  a4 ^  4 +  b1 ^  2 +  b2 ^  2 +  b3 ^  3 +  b4 ^  4",
    " (  a b :  ℤ ) ->  (  ha :  ∃     n1  n2  n3  n4  :  ℕ ,  a =      ↑ n1 ^  2 +   ↑ n2 ^  2 +   ↑ n3 ^  2 +   ↑ n4 ^  2 ) ->  (  hb :  ∃     n1  n2  n3  n4  :  ℕ ,  b =      ↑ n1 ^  2 +   ↑ n2 ^  2 +   ↑ n3 ^  2 +   ↑ n4 ^  2 ) ->  ∃     n1  n2  n3  n4  :  ℕ ,    ↑  a *  b =      ↑ n1 ^  2 +   ↑ n2 ^  2 +   ↑ n3 ^  2 +   ↑ n4 ^  2",
    " (  a b :  ℕ ) ->  (  ha :  ∃     x  y  z  w  ,  a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  (  hb :  ∃     x  y  z  w  ,  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  ∃     x  y  z  w  ,   a * b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2",
    " (  a b :  ℤ ) ->  (  ha :  ∃    (   x  y  z  w :  ℕ ) ,  a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  (  hb :  ∃    (   x  y  z  w :  ℕ ) ,  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  ∃    (   x  y  z  w :  ℕ ) ,   a * b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2",
    " (  a b c d e f g h k l m n :  ℤ ) ->  (  h :      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =     e ^  2 +  f ^  2 +  g ^  2 +  h ^  2 ) ->  (  h₂ :      k ^  2 +  l ^  2 +  m ^  2 +  n ^  2 =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->  ∃     x  y  z  j  :  ℤ ,      k ^  2 +  l ^  2 +  m ^  2 +  n ^  2 =     x ^  2 +  y ^  2 +  z ^  2 +  j ^  2"]},
  {"theorem":
   "∀ (X : Type ?u.97124) [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* ) ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  LocallyCompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX1 :  CompactSpace  X ) ->  LocallyCompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_c :  IsCompact  X ) ->  ∀  x   : X ,  ∃     U  :  Set  X ,   IsOpen  U ∧   IsCompact  U ∧  x ∈ U",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  CompactSpace  X ) ->  LocallyCompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  LocallyCompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  LocallyCompactSpace  X"]},
  {"theorem":
   "∀ (X : Type ?u.102027) (Y : Type ?u.102031) [inst : TopologicalSpace X] [inst_1 : TopologicalSpace Y] (f : X → Y),\n  Continuous f → Continuous f",
   "some-correct": null,
   "prompt": "Every continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  (  Y :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  (  f :  X → Y ) ->  (  hf :  Continuous  f ) ->  Continuous  f"]},
  {"theorem": "∀ (x y : ℕ), Prime x → Prime y → x ≠ y → x + y ≠ 6",
   "some-correct": null,
   "prompt": "`6` is not the sum of two distinct prime numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ¬  ∃     p  q  :  ℕ ,   p ≠ q ∧   (    Prime  p ∨  Prime  q  ) ∧   p + q =  6",
    " ¬  (   ∃     p  q  :  ℕ ,   p ≠ q ∧   Prime  p ∧   Prime  q ∧   p + q =  6  )",
    " (  P :   ℕ →  Prop ) ->  [  DecidablePred  P ] ->  (  p q :  ℕ ) ->  (  hp :  P  p ) ->  (  hq :  P  q ) ->  (  h :  p ≠ q ) ->  (  H :  ∀  n  ,   Prime  n →  P  n ) ->   6 ≠  p + q",
    " (  h₁ :  Prime   3 ) ->  (  h₂ :  Prime   5 ) ->  ¬  ∃    (   p  q :  ℕ )  (   hp :  Prime  p )  (   hq :  Prime  q ) ,   p ≠ q ∧   6 =  p + q",
    " (  x y : Nat ) ->  (  hx :  Prime  x ) ->  (  hy :  Prime  y ) ->  (  hd :  x ≠ y ) ->   x + y ≠  6",
    " ¬  ∃     p₁  p₂  :  ℕ ,   Prime  p₁ ∧   Prime  p₂ ∧   p₁ ≠ p₂ ∧   p₁ + p₂ =  6",
    " ¬  ∃     x  y  :  ℕ ,   Prime  x ∧   Prime  y ∧   x ≠ y ∧   6 =  x + y",
    " ¬  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p ≠ q ∧   6 =  p + q",
    " ¬  ∃     m  n  ,   m ≠ n ∧   Prime  m ∧   Prime  n ∧   m + n =  6",
    " (  p q :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  hq :  Nat.Prime  q ) ->  (  hpq :  p ≠ q ) ->   p + q ≠  6"]},
  {"theorem": "∀ (X : Type ?u.170864) [inst : Ringₓ X], IsUnit 1",
   "some-correct": null,
   "prompt": "The identity element in a ring is a unit.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  Ringₓ  X ] ->  IsUnit   (   1   : X )",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  x : R ) ->  (  hx :  x ≠  0 ) ->  (   ∃     y  : R ,   x * y =  1  )",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x : R ) ->  (  hx :  x ≠  0 ) ->  (   ∃     y  : R ,   x * y =  1  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  e : R ) ->  (  he :  e =  1 ) ->  IsUnit  e",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h1 :   (   1   : R ) ≠  0 ) ->  IsUnit   1",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h1 :   (   1   : R ) ≠  0 ) ->  IsUnit   1",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  IsUnit   (   1   : R )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  IsUnit   (   1   : R )",
    " (  G :  Type* ) ->  [  Ring  G ] ->  (  h :  ∀  x   : G ,   x *  1 = x ) ->  ∀  x   : G ,   x ≠  0 →  ∃     y  ,   y * x =  1",
    " (  G :  Type* ) ->  [  Ringₓ  G ] ->  (  h :  ∀  x   : G ,   x *  1 = x ) ->  ∀  x   : G ,   x ≠  0 →  ∃     y  ,   y * x =  1",
    " (  G :  Type* ) ->  [  Ring  G ] ->  (  a : G ) ->   a *  1 = a",
    " (  G :  Type* ) ->  [  Ringₓ  G ] ->  (  a : G ) ->   a *  1 = a"]},
  {"theorem":
   "(G : Type ?u.1047468) → (K : Type ?u.1047471) → [inst : Group G] → IsSubgroup (?m.1047605 G K) → Group K",
   "some-correct": null,
   "prompt": "Every subgroup of a group is a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G K :  Type* ) ->  [  Group  G ] ->  (  HK :  IsSubgroup  K ) ->  Group  K",
    " (  G K :  Type* ) ->  [  Group  G ] ->  (  HK :  IsSubgroup  K ) ->  Groupₓ  K",
    " (  G K :  Type* ) ->  [  Groupₓ  G ] ->  (  HK :  IsSubgroup  K ) ->  Group  K",
    " (  G K :  Type* ) ->  [  Groupₓ  G ] ->  (  HK :  IsSubgroup  K ) ->  Groupₓ  K"]},
  {"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"]},
  {"theorem":
   "∀ (G : Type ?u.3796178) [inst : Group G] (a : G), a * 1 = a ∧ 1 * a = a",
   "some-correct": null,
   "prompt": "The identity element of a group has finite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  IsUnit  x ) ->   x =  1 ∨  x =  -  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a : G ) ->    a *  1 = a ∧    1 * a = a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a : G ) ->    a *  1 = a ∧    1 * a = a"]},
  {"theorem": "∀ (n : ℕ), n = 2 ∨ n = 3 ∨ n = 5 ∨ n = 7",
   "some-correct": null,
   "prompt": "`7` is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" Prime   7",
    " ∀  n   :  ℕ ,   n =  2 ∨   n =  3 ∨   n =  5 ∨  n =  7",
    " Prime   7",
    " Prime   7",
    " Prime   7",
    " Nat.Prime   7",
    "   (   7   :  ℕ ) >  1 ∧  Prime   (   7   :  ℕ )"]},
  {"theorem": "∃ l, List.length l = 3 ∧ ∀ (p : ℕ), p ∈ l → Prime p ∧ p < 8",
   "some-correct": null,
   "prompt": "There are `3` prime numbers below `8`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃    (   l :  List   ℕ ) ,   l.length =  3 ∧  ∀  p  ∈ l ,   Prime  p ∧  p <  8",
    " ∃    (   p₁  p₂  p₃ :  ℕ ) ,   Prime  p₁ ∧   Prime  p₂ ∧   Prime  p₃ ∧   p₁ ≤  8 ∧   p₂ ≤  8 ∧  p₃ ≤  8",
    " (   ∃     a  b  c  ,   Prime  a ∧   Prime  b ∧   Prime  c ∧   a <  8 ∧   a < b ∧  b < c  )",
    " ∃    (   x  y  z :  ℕ ) ,   Prime  x ∧   Prime  y ∧   Prime  z ∧   x <  8 ∧   y <  8 ∧  z <  8",
    " ∃     ps  :  Finset   ℕ ,   ps.card =  3 ∧  ∀  x  ∈ ps ,   Prime  x ∧  x ≤  8"]},
  {"theorem": "∀ (n : ℕ) (f : Finset (Fin n)), ∅ ⊂ f",
   "some-correct": null,
   "prompt": "The empty set is contained in every finite set.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  f :  Finset   (   Fin  n  ) ) ->   ∅ ⊆ f",
    " (  n :  ℕ ) ->  (  f :  Finset   (   Finₓ  n  ) ) ->   ∅ ⊆ f",
    " {  α :  Type* } ->  (  s :  Finset  α ) ->   ∅ ⊆ s",
    " (  s :  Finset   ℕ ) ->   ∅ ⊆ s",
    " (  f :  Finset   ℕ ) ->  (  hf :  f.card =  0 ) ->   ∅ ⊆ f",
    " (  f :  Finset   ℕ ) ->   ∅ ⊆ f"]},
  {"theorem": "(R : Type ?u.4514329) → [inst : CommRing R] → Monoid R",
   "some-correct": null,
   "prompt": "Every commutative ring is a monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  CommRing  R ] ->  Monoid  R",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  Monoidₓ  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Monoid  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Monoidₓ  R",
    " (  α :  Type* ) ->  [  CommRing  α ] ->  Monoid  α",
    " (  α :  Type* ) ->  [  CommRing  α ] ->  Monoidₓ  α",
    " (  α :  Type* ) ->  [  CommRingₓ  α ] ->  Monoid  α",
    " (  α :  Type* ) ->  [  CommRingₓ  α ] ->  Monoidₓ  α",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  Monoid  R",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  Monoidₓ  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Monoid  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Monoidₓ  R"]},
  {"theorem": "∀ {a : ℕ}, a % 2 = 1 → ∃ m n, m ≠ n ∧ a = m + n",
   "some-correct": null,
   "prompt":
   "Every odd natural number is the sum of two distinct natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  a :  ℕ } ->  (  h :   a %  2 =  1 ) ->  ∃     m  n  ,   m ≠ n ∧  a =  m + n",
    " (  n :  ℕ ) ->  (  hn_odd :  Odd  n ) ->  ∃     m  k  ,   m ≠ k ∧  n =  m + k",
    " (  a :  ℕ ) ->  (  h :   a %  2 =  1 ) ->  ∃     b  c  ,    b + c = a ∧  b ≠ c",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  1 ) ->  ∃     a  b  :  ℕ ,   a ≠ b ∧  n =  a + b",
    " (  n :  ℕ ) ->  (  h :   0 <    2 * n +  1 ) ->  ∃     i  j  ,      2 * i +  1 =    2 * j +  1 ∧     2 * i +  1 =    2 * n +  1",
    " (  n :  ℕ ) ->  (  hn :   n %  2 =  1 ) ->  ∃     m  k  :  ℕ ,   m ≠ k ∧  n =  m + k",
    " (  n :  ℕ ) ->  (  hn :   n %  2 =  1 ) ->  ∃     m  k  :  ℕ ,   k ≠ m ∧     2 * m +   2 * k = n",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->  ∃     k  l  :  ℕ ,   k ≠ l ∧  n =  k + l",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  1 ) ->  ∃     i  j  :  ℕ ,   i ≠ j ∧  n =  i + j"]},
  {"theorem":
   "∀ (G : Type ?u.7398386) [inst : Group G] (H : Type ?u.7398394) [inst_1 : Group H] (f : G → H),\n  f 1 = 1 → ∀ (x : G), f x = 1 ↔ x = 1",
   "some-correct": null,
   "prompt": "Every element in the trivial group has finite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  X :  Type* } ->  [  Group  X ] ->  (  x : X ) ->  (  h :  ∃     x'  ,  x =  1 ) ->  ∃     n  :  ℕ ,  x =  1",
    " {  X :  Type* } ->  [  Groupₓ  X ] ->  (  x : X ) ->  (  h :  ∃     x'  ,  x =  1 ) ->  ∃     n  :  ℕ ,  x =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  Type* ) ->  [  Group  H ] ->  (  f :  G → H ) ->  (  h :   f   1 =  1 ) ->  (  x : G ) ->    f  x =  1 ↔  x =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  Type* ) ->  [  Groupₓ  H ] ->  (  f :  G → H ) ->  (  h :   f   1 =  1 ) ->  (  x : G ) ->    f  x =  1 ↔  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Type* ) ->  [  Group  H ] ->  (  f :  G → H ) ->  (  h :   f   1 =  1 ) ->  (  x : G ) ->    f  x =  1 ↔  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Type* ) ->  [  Groupₓ  H ] ->  (  f :  G → H ) ->  (  h :   f   1 =  1 ) ->  (  x : G ) ->    f  x =  1 ↔  x =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  Type* ) ->  [  Group  H ] ->  (  hG_triv :  Nontrivial  G ) ->  (  hH_triv :  Nontrivial  H ) ->  Nontrivial   (   G × H  )",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  Type* ) ->  [  Groupₓ  H ] ->  (  hG_triv :  Nontrivial  G ) ->  (  hH_triv :  Nontrivial  H ) ->  Nontrivial   (   G × H  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Type* ) ->  [  Group  H ] ->  (  hG_triv :  Nontrivial  G ) ->  (  hH_triv :  Nontrivial  H ) ->  Nontrivial   (   G × H  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Type* ) ->  [  Groupₓ  H ] ->  (  hG_triv :  Nontrivial  G ) ->  (  hH_triv :  Nontrivial  H ) ->  Nontrivial   (   G × H  )"]},
  {"theorem": "∀ (n : ℕ), n % 2 = 0 → n * n % 2 = 0",
   "some-correct": null,
   "prompt": "The square of an even number is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h2n :   2 ∣ n ) ->   2 ∣  n ^  2",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->    (   n * n  ) %  2 =  0",
    " (  n :  ℤ ) ->  (  h :  ∃     k  ,  n =   2 * k ) ->  ∃     k  ,   n ^  2 =   2 * k",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->    (   n ^  2  ) %  2 =  0",
    " (  n :  ℤ ) ->  (  h :  ∃     m  :  ℤ ,  n =   2 * m ) ->  ∃     m  :  ℤ ,   n ^  2 =   2 * m",
    " (  n :  ℕ ) ->  (  h :  ∃     k  :  ℕ ,  n =   2 * k ) ->  ∃     k  :  ℕ ,   n ^  2 =   2 * k",
    " {  n :  ℕ } ->  (  h :  ∃     k  :  ℕ ,  n =   2 * k ) ->  ∃     k  :  ℕ ,   n ^  2 =   2 * k",
    " (  n :  ℕ ) ->  (  h :  ∃     m  :  ℕ ,  n =   2 * m ) ->  ∃     k  :  ℕ ,   n ^  2 =   2 * k",
    " (  n :  ℤ ) ->  (  h :  ∃     m  :  ℕ ,  n =   2 * m ) ->  ∃     m  :  ℕ ,   n ^  2 =   2 * m",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->    (   n * n  ) %  2 =  0",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->  ∀  m  ,   n =   2 * m →   2 ∣  n ^  2",
    " (  n :  ℕ ) ->   Even  n →  Even   (   n ^  2  )",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->   2 ∣  n ^  2",
    " (  n :  ℕ ) ->  (  hn :   n %  2 =  0 ) ->    (   n * n  ) %  2 =  0",
    " (  n :  ℕ ) ->  (  hn :  Even  n ) ->  Even   (   n * n  )"]},
  {"theorem":
   "∀ (R : Type ?u.7535525) [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* ) ->  [  CommRing  R ] ->  [  DivisionRing  R ] ->  IsField  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  [  DivisionRing  R ] ->  IsField  R",
    " (  F :  Type* ) ->  [  DivisionRing  F ] ->  [  CommRing  F ] ->  IsField  F",
    " (  F :  Type* ) ->  [  DivisionRing  F ] ->  [  CommRingₓ  F ] ->  IsField  F",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  CommRing  D ] ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  CommRingₓ  D ] ->  Field  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  CommRing  R ] ->  IsField  R",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  CommRingₓ  R ] ->  IsField  R",
    " (  α :  Type* ) ->  [  DivisionRing  α ] ->  (  h :  ∀  x y   : α ,   x * y =  y * x ) ->  IsField  α",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  CommRing  D ] ->  Commutative  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  CommRingₓ  D ] ->  Commutative  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  CommRing  D ] ->  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  CommRingₓ  D ] ->  IsField  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  CommRing  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  CommRingₓ  R ] ->  Field  R",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  CommRing  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  CommRingₓ  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  Field  D ] ->  [  CommRing  D ] ->  ∀  x   : D ,   x ≠  0 →  ∃     y  : D ,   x * y =  1",
    " (  D :  Type* ) ->  [  Field  D ] ->  [  CommRingₓ  D ] ->  ∀  x   : D ,   x ≠  0 →  ∃     y  : D ,   x * y =  1"]},
  {"theorem":
   "∀ (X : Type ?u.7765035) [inst : Group X], X → OfNat.ofNat 1 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":
   [" (  X :  Type* ) ->  [  Group  X ] ->  ∀  x   : X ,    (   1   :  X → X )   (   1   : X ) =  1",
    " (  X :  Type* ) ->  [  Groupₓ  X ] ->  ∀  x   : X ,    (   1   :  X → X )   (   1   : X ) =  1",
    " (  X :  Type* ) ->  [  Group  X ] ->  (  x : X ) ->    (   1   :  X → X )  x =  1",
    " (  X :  Type* ) ->  [  Groupₓ  X ] ->  (  x : X ) ->    (   1   :  X → X )  x =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->    (  id   :  G → G )   1 =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->    (  id   :  G → G )   1 =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  g : G ) ->    (   1   :  G → G )  g =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  g : G ) ->    (   1   :  G → G )  g =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  ∀  x   : G ,   x =  1 →    (   λ x , x  )  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  ∀  x   : G ,   x =  1 →    (   λ x , x  )  x =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  x : G ) ->    (   1   :  G → G )  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  x : G ) ->    (   1   :  G → G )  x =  1"]},
  {"theorem": "∀ (X : Type ?u.7765981) (x : X), id x = x",
   "some-correct": null,
   "prompt":
   "Every point is a fixed point of the identity function on a space.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  ∀  x   : X ,   id  x = x",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  x : X ) ->  x =  id  x",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  ∀  x   : X ,  x =   (  id   :  X → X )  x"]},
  {"theorem": "∀ (G : Type ?u.7800154) [inst : Group G], ∃ a, a ≠ 1",
   "some-correct": null,
   "prompt": "Every group is non-empty.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  ∃    (   a : G ) ,  a ≠  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  ∃    (   a : G ) ,  a ≠  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  Nonempty  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  Nonempty  G"]},
  {"theorem":
   "∀ (X : Type ?u.8098392) [inst : TopologicalSpace X] (Y : X → Set X),\n  { x // Membership.Mem x (ConnectedComponent Y) } → ∀ (x y : X), x ∈ Y y → ∃ x, Y x ∩ Y y ≠ ∅",
   "some-correct": null,
   "prompt": "All connected components of a topological space are connected.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsConnected  X ) ->  ∀   (  c  :  Set  X  )  ,   ConnectedComponent  c →  IsConnected  c",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  Y :  X →  Set  X ) ->  (  hY :  ConnectedComponent  Y ) ->  (  x y : X ) ->  (  hx :  x ∈  Y  y ) ->  (   ∃     x  ,    Y  x ∩  Y  y ≠  ∅  )",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  ∀  c   :  Set  X ,   IsConnected  c →  ConnectedComponent  c c"]},
  {"theorem": "ℤ → ∃ i j k, i ^ 2 + j ^ 2 = k ^ 2",
   "some-correct": null,
   "prompt": "The numbers `3`, `4` and `5` form a Pythagorean triple.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃     a  b  c  :  ℕ ,    a ^  2 +  b ^  2 =  c ^  2",
    " ∃     x  y  z  :  ℕ ,  ∀  a b c   :  ℕ ,     a ^  2 +  b ^  2 =  c ^  2 →    a * x +  b * y =  c * z",
    " (  n :  ℤ ) ->  ∃     i  j  k  :  ℤ ,    i ^  2 +  j ^  2 =  k ^  2",
    " (  h :  ∀   (  x y z  :  ℕ  )  ,   x ≤ y →   y ≤ z →     x ^  2 +  y ^  2 =  z ^  2 →   (    x =  3 ∧   y =  4 ∧  z =  5  ) ∨  (    x =  5 ∧   y =  4 ∧  z =  3  ) ) ->  ∀  m n  ,    3 ≤ m →   m ≤ n →   n ≤  5 →     m ^  2 +  n ^  2 =   5 ^  2 →   (    m =  3 ∧  n =  4  ) ∨  (    m =  4 ∧  n =  3  )",
    " ∃    (   a  b  c :  ℕ ) ,     a ^  2 +  b ^  2 =  c ^  2 ∧    a + b + c =  10",
    " ∃     x  y  z  :  ℤ ,     x ^  2 +  y ^  2 =  z ^  2 ∧   x >  0 ∧   y >  0 ∧   x < y ∧  y < z",
    " ∃     a  b  c  :  ℕ ,     a ^  2 +  b ^  2 =  c ^  2 ∧   a >  0 ∧   b >  0 ∧  c >  0",
    " ∃     m  n  :  ℕ ,     3 *  3 +   4 *  4 =   m * m +  n * n",
    " PythagoreanTriple   3  4  5",
    " ∃     x  y  z  :  ℕ ,     x * x +  y * y =  z * z ∧   x < y ∧   z < y ∧  x ≠  0",
    " ∃    (   a  b  c :  ℤ ) ,     a ^  2 +  b ^  2 =  c ^  2 ∧   a =  3 ∧   b =  4 ∧  c =  5",
    " (  three :  ℕ ) ->  (  four :  ℕ ) ->  (  five :  ℕ ) ->     three ^  2 +  four ^  2 =  five ^  2 →   three =  3 ∧   four =  4 ∧  five =  5"]}],
 "elaborated": 30}