{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 0,
 "number-keyword-sentences": 0,
 "include-fixed": true,
 "failures":
 ["The number of partitions with odd parts is equal to the number of partitions with distinct parts.",
  "Every non-empty poset in which every chain has an upper bound contains a maximal element.",
  "A topological space is normal if and only if any two disjoint closed subsets can be separated by a continuous function.",
  "If a function from the unit interval to itself has a point of period three, then it has points of all positive periods.",
  "A terminal object in a category is unique up to unique isomorphism.",
  "The complement of the union of two sets is the intersection of their complements.",
  "Every free group is torsion free.",
  "A finite torsion-free group is trivial",
  "Every matrix satisfies its own characteristic polynomial.",
  "The square root of an irrational number is irrational.",
  "In a finite commutative ring, all prime ideals are maximal.",
  "Every non-identity element of a free group is of infinite order.",
  "An element of a discrete valuation ring is a unit if and only if it has a valuation of zero.",
  "If the direct product of two groups is torsion free then each of the groups is torsion free."],
 "elaborated-prompts":
 [{"theorem":
   "∀ (X : Type ?u.148138) [inst : TopologicalSpace X] (hX : IsCompact (Set.Univ \\ {∅})), IsCompact (?m.148516 X hX)",
   "some-correct": null,
   "prompt":
   "If every proper closed set of a topological space is compact, then the space itself is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact   (   Set.Univ \\  {   ∅ }  ) ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  Z   :  Set  X ,    IsClosed  Z ∧  Z ≠  ∅ →  IsCompact  Z ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  A   :  Set  X ,    IsClosed  A ∧  ¬  IsOpen  A →  IsCompact  A ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  H :  ∀  C   :  Set  X ,    IsClosed  C ∧  C ≠  ∅ →  IsCompact  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  A   :  Set  X ,    IsClosed  A ∧  A ≠  ∅ →  IsCompact  A ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  A   :  Set  X ,   IsClosed  A →   IsCompact  A →  IsCompact  X ) ->  IsCompact  X"]},
  {"theorem":
   "∀ (p : ℕ), Nat.Prime p → ¬p = 2 ∧ ¬p % 4 = 1 → ∃ a b, a ^ 2 + b ^ 2 = p",
   "some-correct": null,
   "prompt":
   "Every prime that is `1` greater than a multiple of `4` can be expressed as the sum of two squares.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  hp1 :   ¬  p =  2 ∧  ¬   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp4 :   p %  4 =  1 ) ->  ∃     a  b  :  ℤ ,    a ^  2 +  b ^  2 =  (  p   :  ℤ )",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  h :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp_mod4 :   p %  4 =  1 ) ->  ∃     n  m  :  ℕ ,    n * n +  m * m = p",
    " (  n :  ℕ ) ->  (  h :  n >  0 ) ->  (  hn :  ∀  k   :  ℕ ,   n %  4 ≠  k %  4 ) ->  (  hp :  Nat.Prime  n ) ->  ∃     x  y  :  ℕ ,    x ^  2 +  y ^  2 = n",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  hp1 :  Nat.Prime   (   p +  1  ) ) ->  (  hmod :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,    a * a +  b * b = p",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  h :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,   (   ∀  c d   :  ℕ ,     a ^  2 +  b ^  2 =   c ^  2 +  d ^  2 →   a = c ∧  b = d  ) ∧    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hpmod4 :   p %  4 =  1 ) ->  ∃     x  y  :  ℤ ,    x ^  2 +  y ^  2 = p",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  h :  (    p %  4 =  1  ) ) ->  ∃     a  b  :  ℕ ,   Nat.Prime  p ∧    a * a +  b * b = p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hu :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,    0 < a ∧    0 < b ∧  p =   a ^  2 +  b ^  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp4 :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,  p =   a ^  2 +  b ^  2"]},
  {"theorem":
   "∀ (a b : ℤ),\n  (∃ a1 a2 a3 a4, a = a1 ^ 2 + a2 ^ 2 + a3 ^ 2 + a4 ^ 2) →\n    (∃ b1 b2 b3 b4, b = b1 ^ 2 + b2 ^ 2 + b3 ^ 2 + b4 ^ 2) → ∃ c1 c2 c3 c4, a * b = c1 ^ 2 + c2 ^ 2 + c3 ^ 2 + c4 ^ 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 :  ℤ ) ->  (  h_a :  ∃    (   a1  a2  a3  a4 :  ℤ ) ,  a =     a1 ^  2 +  a2 ^  2 +  a3 ^  2 +  a4 ^  2 ) ->  (  h_b :  ∃    (   b1  b2  b3  b4 :  ℤ ) ,  b =     b1 ^  2 +  b2 ^  2 +  b3 ^  2 +  b4 ^  2 ) ->  ∃    (   c1  c2  c3  c4 :  ℤ ) ,   a * b =     c1 ^  2 +  c2 ^  2 +  c3 ^  2 +  c4 ^  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 :  ℤ ) ->  (  ha :      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =  1 ) ->  (  hb :      e ^  2 +  f ^  2 +  g ^  2 +  h ^  2 =  1 ) ->       (      a * e +  b * f +  c * g +  d * h  ) ^  2 +   (      a * f -  b * e +  c * h -  d * g  ) ^  2 +   (      a * g -  b * h -  c * e +  d * f  ) ^  2 +   (      a * h +  b * g -  c * f -  d * e  ) ^  2 =  1",
    " (  a b c d e f g h :  ℕ ) ->    (      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2  ) *  (      e ^  2 +  f ^  2 +  g ^  2 +  h ^  2  ) =      (      a * e +  b * f +  c * g +  d * h  ) ^  2 +   (      a * f -  b * e +  c * h -  d * g  ) ^  2 +   (      a * g -  b * h -  c * e +  d * f  ) ^  2 +   (      a * h +  b * g -  c * f -  d * e  ) ^  2"]},
  {"theorem":
   "(R : Type ?u.772869) → [inst : Ring R] → (∀ (x : R), x ^ 2 = x) → CommRing R",
   "some-correct": null,
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h1 :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h1 :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hr :  ∀  x   : R ,   x * x = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hr :  ∀  x   : R ,   x * x = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  x   : R ,   x ^  2 = x ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h1 :  ∀  a   : R ,   a ^  2 = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h1 :  ∀  a   : R ,   a ^  2 = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h1 :  ∀  a   : R ,   a ^  2 = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h1 :  ∀  a   : R ,   a ^  2 = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  H :  ∀  a   : R ,   a * a = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  H :  ∀  a   : R ,   a * a = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  H :  ∀  a   : R ,   a * a = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  H :  ∀  a   : R ,   a * a = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  (  x y : R ) ->   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  (  x y : R ) ->   x * y =  y * x"]},
  {"theorem": "ℕ → ∃ p, Prime p ∧ ∃ p', Prime p' ∧ p' = p + 2",
   "some-correct": null,
   "prompt":
   "There are infinitely many pairs of primes that differ exactly by `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃     n  ,   Prime  n ∧  Prime   (   n +  2  )",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   Prime  p ∧  ∃     p'  :  ℕ ,   Prime  p' ∧  p' =  p +  2",
    " ∃     a  :  ℕ ,  ∃     b  :  ℕ ,   b =  a +  2 ∧   Prime  b ∧  Prime  a",
    " ∃     p'  :  ℕ ,  ∃     p  :  ℕ ,    p' %  2 ≠  0 ∧    p %  2 =  0 ∧   Prime  p' ∧   Prime  p ∧  p =  p' +  2",
    " ∃     L  :  List   (    ℕ ×  ℕ  ) ,  ∀   (  p q  :   ℕ ×  ℕ  )  ,   p ∈ L →   q ∈ L →  p ≠ q",
    " ∃     primes  :   ℕ →  ℕ ,  ∃     k  :  ℕ ,  ∀  n  ,    primes  n +  2 =  primes   (   n + k  )",
    " ∀  n  ,  ∃     p  q  ,  p.prime ∧  q.prime ∧  q =  p +  2",
    " ∃     n  :  ℕ ,  ∃     p  :  ℕ ,   Prime  p ∧  Prime   (    2 + p  )",
    " ∃    (   a  b :  ℕ ) ,   Prime  a ∧   Prime  b ∧  a =  b +  2",
    " (  p q :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hq :  Prime  q ) ->  (  h :  p ≠ q ) ->  (  h2 :   q - p =  2 ) ->  ∃     m  n  :  ℕ ,   Prime  m ∧   Prime  n ∧   m ≠ n ∧   m - n =  2",
    " ∃     p  q  :  ℕ ,   (   ∀  m n   :  ℕ ,   m ≠ n →   m +  2 ≠ n  ) ∧   p ≠ q ∧   Prime  p ∧  Prime  q",
    " (  h :  (   ∀  p   :  ℕ ,   p >  2 →  ∃     p₁  p₂  :  ℕ ,   Prime  p₁ ∧   Prime  p₂ ∧   p₁ =  p +  2 ∧  p₂ = p  ) ) ->  ∃     p₁  p₂  :  ℕ ,   Prime  p₁ ∧   Prime  p₂ ∧  p₁ =  p₂ +  2"]},
  {"theorem":
   "(R : Type ?u.905389) → [inst : DivisionRing R] → Finite R → Field R",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  DivisionRing  R ] ->  (  hR :  Finite  R ) ->  Field  R",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Finite  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Nonempty   (   Finset   (   Units  D  )  ) ) ->  Field  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  Field  R",
    " (  F :  Type* ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  Field  F",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Fintype  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  Fintype  D ] ->  [  DivisionRing  D ] ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Nonempty   (   Fintype  D  ) ) ->  Field  D"]},
  {"theorem":
   "∀ (X : Type ?u.905696) (Y : Type ?u.905699) [inst : Inhabited X] [inst : Inhabited Y] (f : X → Y) (g : Y → X),\n  (∀ (x : X), f (g (f x)) = f x) → (∀ (y : Y), g (f (g y)) = g y) → Function.injective f ∧ Function.injective g",
   "some-correct": null,
   "prompt":
   "If each of two types can be mapped injectively into the other, then there is a bijection between them.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X Y :  Type* ) ->  [  Inhabited  X ] ->  [  Inhabited  Y ] ->  (  f :  X → Y ) ->  (  g :  Y → X ) ->  (  hf :  ∀  x   : X ,   f   (   g   (   f  x  )  ) =  f  x ) ->  (  hg :  ∀  y   : Y ,   g   (   f   (   g  y  )  ) =  g  y ) ->  f.injective ∧ g.injective"]},
  {"theorem":
   "∀ (n : ℕ) (G : Fin n → Fin n), (∀ (i j : Fin n), G i ≠ G j) → ∃ i, ∀ (j : Fin n), j ≠ i → G j = G i",
   "some-correct": null,
   "prompt":
   "A finite graph in which every pair of vertices have precisely one common neighbour contains a vertex that is adjacent to all other vertices.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  G :   Fin  n →  Fin  n ) ->  (  hG :  ∀  i j   :  Fin  n ,   G  i ≠  G  j ) ->  ∃     i  :  Fin  n ,  ∀  j   :  Fin  n ,   j ≠ i →   G  j =  G  i",
    " (  n :  ℕ ) ->  (  G :   Fin  n →  Finₓ  n ) ->  (  hG :  ∀  i j   :  Fin  n ,   G  i ≠  G  j ) ->  ∃     i  :  Fin  n ,  ∀  j   :  Fin  n ,   j ≠ i →   G  j =  G  i",
    " (  n :  ℕ ) ->  (  G :   Finₓ  n →  Fin  n ) ->  (  hG :  ∀  i j   :  Finₓ  n ,   G  i ≠  G  j ) ->  ∃     i  :  Finₓ  n ,  ∀  j   :  Finₓ  n ,   j ≠ i →   G  j =  G  i",
    " (  n :  ℕ ) ->  (  G :   Finₓ  n →  Finₓ  n ) ->  (  hG :  ∀  i j   :  Finₓ  n ,   G  i ≠  G  j ) ->  ∃     i  :  Finₓ  n ,  ∀  j   :  Finₓ  n ,   j ≠ i →   G  j =  G  i",
    " (  V :  Type* ) ->  [  Fintype  V ] ->  (  E :  V →  V →  Prop ) ->  (  h :  ∀  v w  ,  ∃     x  ,   E  x v ∧  E  x w ) ->  (  hsym :  ∀  x y   : V ,   E  x y →  E  y x ) ->  (  h1 :  ∀  x y z  ,   E  x y →   E  x z →   E  y z →  x = z ) ->  ∃     x  ,  ∀  v  ,  E  x v"]},
  {"theorem":
   "∀ (G : Type ?u.5984079) [inst : Groupₓ G],\n  (∀ (α : G → G), IsGroupHom α → IsMonoidHom α → α = 1 → ∃ z, ∀ (g : G), α g = g * z) → ∀ (g1 g2 : G), g1 * g2 = g2 * g1",
   "some-correct": null,
   "prompt": "A group whose automorphism group is cyclic is Abelian.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  ∀  α   :  G → G ,   IsGroupHom  α →   IsMonoidHom  α →   α =  1 →  ∃     z  : G ,  ∀  g  ,   α  g =  g * z ) ->  ∀  g1 g2   : G ,   g1 * g2 =  g2 * g1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∃    (   α :  G → G ) ,   IsGroupHom  α ∧  ∀  x  ,    α  x = x →  x =  1 ) ->  Commutative  G"]},
  {"theorem":
   "∀ (X : Type ?u.6462556) (Y : Type ?u.6462559) (Z : Type ?u.6462562) [inst : UniformSpace X] [inst_1 : UniformSpace Y]\n  [inst_2 : UniformSpace Z] (f : X → Y) (g : Y → Z),\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α β γ :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ x ,  g   (   f  x  )  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  hf :  UniformContinuous  f ) ->  (  g :  Y → Z ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ (X : Type ?u.6933717) (Y : Type ?u.6933720) (Z : Type ?u.6933723) [inst : UniformSpace X] [inst_1 : UniformSpace Y]\n  [inst_2 : UniformSpace Z] (f : X → Y) (g : Y → Z),\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α β γ :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ x ,  g   (   f  x  )  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  hf :  UniformContinuous  f ) ->  (  g :  Y → Z ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem": "∀ (a b : ℕ), 0 < a → 0 < b → ∀ (c : ℕ), ¬a ^ 3 + b ^ 3 = c ^ 3",
   "some-correct": null,
   "prompt":
   "The sum of the cubes of two positive integers is never equal to the cube of a third integer.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  a b :  ℕ ) ->  (  ha :   0 < a ) ->  (  hb :   0 < b ) ->  ∃     c  :  ℕ ,  ∀  d   :  ℕ ,    a ^  3 +  b ^  3 ≠  d ^  3",
    " (  m n p :  ℕ ) ->  (  hm :  m >  0 ) ->  (  hn :  n >  0 ) ->  (  hp :  p >  0 ) ->    m ^  3 +  n ^  3 ≠  p ^  3",
    " (  x y :  ℕ ) ->  (  hx :   0 < x ) ->  (  hy :   0 < y ) ->  ∀  z   :  ℕ ,    x ^  3 +  y ^  3 ≠  z ^  3",
    " (  a b :  ℤ ) ->  (  ha :   (   0   :  ℤ ) < a ) ->  (  hb :   (   0   :  ℤ ) < b ) ->  ∀  z   :  ℤ ,   z ^  3 ≠   a ^  3 +  b ^  3",
    " (  a b :  ℕ ) ->  (  h :   a >  0 ∧  b >  0 ) ->  ∀  c   :  ℕ ,   c ^  3 ≠   (   a + b  ) ^  3",
    " (  a b :  ℕ ) ->  (  ha :   0 < a ) ->  (  hb :   0 < b ) ->  ∀  c   :  ℕ ,  ¬    a ^  3 +  b ^  3 =  c ^  3"]},
  {"theorem":
   "∀ (G : Type ?u.9027123) [inst : Group G], (∀ (x : G), x ≠ 1 → x * x = 1) → ∀ (x y : G), x * y = y * x",
   "some-correct": null,
   "prompt":
   "If every element of a group `G` has order `2`, then every pair of elements of `G` commutes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  x   : G ,   x ≠  1 →   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  x   : G ,   x ≠  1 →   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  ∀  g   : G ,   g ≠  1 →  ∃     n  ,    g ^ n =  1 ∧   2 ≤ n ) ->  ∀  g h   : G ,   g * h =  h * g",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  ∀  g   : G ,   g ≠  1 →  ∃     n  ,    g ^ n =  1 ∧   2 ≤ n ) ->  ∀  g h   : G ,   g * h =  h * g",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h_G :  ∀  x   : G ,  x =  x ⁻¹ ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h_G :  ∀  x   : G ,  x =  x ⁻¹ ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  ∀  x   : G ,   x * x =  1 ) ->  (  x y : G ) ->   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  ∀  x   : G ,   x * x =  1 ) ->  (  x y : G ) ->   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀  g   : G ,   g * g =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  g   : G ,   g * g =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  x  ,   x ≠  1 →   x * x =  1 ) ->  ∀  a b  ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  x  ,   x ≠  1 →   x * x =  1 ) ->  ∀  a b  ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hgh :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hgh :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀   (  x  : G  )  ,   x ≠  1 →   x * x =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀   (  x  : G  )  ,   x ≠  1 →   x * x =  1 ) ->  ∀  a b   : G ,   a * b =  b * a"]},
  {"theorem": "∀ (n : ℕ), ∃ m, m * (m + 1) = 2 * n",
   "some-correct": null,
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  ∃     m  :  ℕ ,   m *  (   m +  1  ) =   2 * n",
    " (  n :  ℕ ) ->   2 ∣  n *  (   n +  1  )",
    " (  m n :  ℕ ) ->    m *  (   m +  1  ) %  2 =  0",
    " (  n :  ℕ ) ->   2 ∣  n *  (   n +  1  )",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,  n =   2 * m",
    " (  n :  ℕ ) ->  ∃     k  :  ℕ ,   k *  (   k +  1  ) =   2 * n",
    " (  n :  ℕ ) ->  Even   (   n *  (   n +  1  )  )",
    " (  n :  ℕ ) ->  Even   (   n *  (   n +  1  )  )",
    " ∀  m n   :  ℕ ,  Even   (   m * n  )",
    " (  n :  ℕ ) ->    n *  (   n +  1  ) %  2 =  0"]},
  {"theorem":
   "∀ (G : Type ?u.10407252) [inst : Groupₓ G] (H : Set G), (∀ (g h : G), g * h ∈ H ↔ h * g ∈ H) → IsNormalSubgroup H",
   "some-correct": null,
   "prompt": "Every index 2 subgroup of a group is normal.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  hH :  ∀   (  g h  : G  )  ,    g * h ∈ H ↔   h * g ∈ H ) ->  IsNormalSubgroup  H",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  Set  G ) ->  (  hH :  ∀  h   : G ,   h * h ∈ H ) ->  (  hH1 :  H ≠  ∅ ) ->  ∀  h   : G ,  ∀  g   : G ,    h * g ∈ H →   g * h ∈ H",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  hH :  ∀  h   : G ,   h * h ∈ H ) ->  (  hH1 :  H ≠  ∅ ) ->  ∀  h   : G ,  ∀  g   : G ,    h * g ∈ H →   g * h ∈ H",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  hH :  ∀  x  ∈ H ,   x ⁻¹ ∈ H ) ->  (  h1 :  ∀  x  ∈ H ,   x ∈ H →  x =  1 ) ->  IsNormalSubgroup  H"]},
  {"theorem": "∀ (n : ℕ), n > 1 → ∃ p, Prime p ∧ p ∣ ↑n",
   "some-correct": null,
   "prompt":
   "Every natural number greater than `1` is divisible by a prime number. ",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃     p  :  ℤ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  {  p :  ℕ } ->  (  hp :  Prime  p ) ->  (  h :  n >  1 ) ->  ∃     d  :  ℕ ,   d ∣ n ∧  Prime  d",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h1 :  n >  1 ) ->  ∃     p  ,  p.prime ∧  p ∣ n"]},
  {"theorem":
   "(R : Type ?u.16056528) → [inst : DivisionRing R] → Finite R → Field R",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  DivisionRing  R ] ->  (  hR :  Finite  R ) ->  Field  R",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Finite  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Nonempty   (   Finset   (   Units  D  )  ) ) ->  Field  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  Field  R",
    " (  F :  Type* ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  Field  F",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Fintype  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  Fintype  D ] ->  [  DivisionRing  D ] ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  Nonempty   (   Fintype  D  ) ) ->  Field  D"]},
  {"theorem":
   "∀ (X : Type ?u.16163086) [inst : TopologicalSpace X],\n  Finite X → ∀ (U : Set X), IsOpen U → ∃ n, ∀ (n : ℕ), ∃ x, x ∈ U ∧ ∀ (m : ℕ), m ≠ n → ¬x ∈ U",
   "some-correct": null,
   "prompt": "Every finite topological space is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  (  U :  Set  X ) ->  (  hU :  IsOpen  U ) ->  ∃     n  :  ℕ ,  ∀  n   :  ℕ ,  ∃  x  ∈ U ,  ∀  m   :  ℕ ,   m ≠ n →  ¬  x ∈ U",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_finite :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  Fintype  X ] ->  [  TopologicalSpace  X ] ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  Fintype  X ] ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  Fintype  X ] ->  (  hX :  ∀  U   :  Set  X ,   IsOpen  U →  ∃  x  ∈ U ,  ∀  V  ,   x ∈ V →  V ∈ U ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_fin :  Finite  X ) ->  CompactSpace  X",
    " (  n :  ℕ ) ->  [  TopologicalSpace   (   Fin  n  ) ] ->  CompactSpace   (   Fin  n  )",
    " (  n :  ℕ ) ->  [  TopologicalSpace   (   Finₓ  n  ) ] ->  CompactSpace   (   Finₓ  n  )"]},
  {"theorem":
   "∀ (G : Type ?u.16786217) [inst : Fintype G] [inst : DecidableEq G] [inst : Group G] (g : G → G),\n  Function.Injective g → Function.Surjective g → Function.Injective g",
   "some-correct": null,
   "prompt":
   "Every surjective homomorphism from a finitely generated free group to itself is injective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Fintype  G ] ->  [  DecidableEq  G ] ->  [  Group  G ] ->  (  g :  G → G ) ->  (  hg :  Function.Injective  g ) ->  (  hg_surj :  Function.Surjective  g ) ->  Function.Injective  g",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  DecidableEq  G ] ->  [  Groupₓ  G ] ->  (  g :  G → G ) ->  (  hg :  Function.Injective  g ) ->  (  hg_surj :  Function.Surjective  g ) ->  Function.Injective  g"]},
  {"theorem":
   "∀ (n : ℕ), 0 < n → (∃ k, n = 2 * k) → ∃ p q, p + q = n ∧ Nat.Prime p ∧ Nat.Prime q",
   "some-correct": null,
   "prompt":
   "Every positive even integer can be written as the sum of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  Pos :   0 < n ) ->  (  Even :  ∃     k  ,  n =   2 * k ) ->  ∃     p  q  :  ℕ ,    p + q = n ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  (  h :  ¬  Even  n ) ->  ∀  k m   :  ℕ ,     2 * n =    2 * k +   2 * m →   ¬  Prime  k ∨  ¬  Prime  m",
    " (  n :  ℕ ) ->  (  h :   Even  n ∧  n >  0 ) ->  ∃     p  q  :  ℕ ,   p >  1 ∧   q >  1 ∧   Prime  p ∧   Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hpos :  n >  0 ) ->  (  heven :   n %  2 =  0 ) ->  ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->  (  h :   0 <   2 * n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p + q =   2 * n",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->  (  hn :  n >  0 ) ->  ∃     m  l  :  ℕ ,   m > l ∧   Prime  m ∧    m %  2 =  1 ∧   Prime  l ∧    l %  2 =  1 ∧  n =  m + l",
    " (  n :  ℕ ) ->  (  h :  n >  0 ) ->  (  hn :  Even  n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧   n %  2 =  0 ) ->  ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧   a + b = n"]},
  {"theorem": "∀ (x : ℤ), x ^ 2 % 2 = 0 → x % 2 = 0",
   "some-correct": null,
   "prompt": "If the square of a number is even, the number itself is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  x :  ℤ ) ->  (  hx :    x ^  2 %  2 =  0 ) ->   x %  2 =  0",
    " (  n :  ℕ ) ->  (  h :  ∃     m  :  ℕ ,   n * n =   2 * m ) ->  ∃     k  :  ℕ ,  n =   2 * k",
    " (  n :  ℤ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  n :  ℕ ) ->  (  h :  ∃     m  :  ℕ ,   n ^  2 =   2 * m ) ->  ∃     m  :  ℕ ,  n =   2 * m",
    " (  n :  ℕ ) ->  (  h :  ∃    (   k :  ℕ ) ,  n =   2 * k ) ->  ∃    (   k :  ℕ ) ,   k *  2 = n",
    " (  x :  ℕ ) ->     x ^  2 %  2 =  0 →   x %  2 =  0",
    " (  n :  ℕ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  x :  ℤ ) ->  (  hx :   (   2   :  ℤ ) ∣  x ^  2 ) ->   (   2   :  ℤ ) ∣ x",
    " (  n :  ℕ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  n :  ℕ ) ->  (  h :    n * n %  2 =  0 ) ->   n %  2 =  0",
    " (  n :  ℕ ) ->  (  hn2 :   2 ∣  n ^  2 ) ->   2 ∣ n",
    " (  x :  ℕ ) ->     x ^  2 %  2 =  0 →   x %  2 =  0",
    " (  a :  ℕ ) ->    2 ∣  a ^  2 →   2 ∣ a"]},
  {"theorem":
   "∀ (X : Type ?u.19415115) [inst : TopologicalSpace X],\n  IsSeparated (?m.19415368 X) ↔ ∀ (x y : X), ∃ U V, IsOpen U ∧ IsOpen V ∧ x ∈ U ∧ y ∈ V ∧ U ∩ V = ∅",
   "some-correct": null,
   "prompt":
   "A topological space $X$ is Hausdorff if and only if the diagonal is a closed set in $X × X$.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->   IsSeparated  X ↔  ∀   (  x y  : X  )  ,  ∃     U  V  :  Set  X ,   IsOpen  U ∧   IsOpen  V ∧   x ∈ U ∧   y ∈ V ∧   U ∩ V =  ∅"]},
  {"theorem":
   "∀ (X : Type ?u.19663272) [inst : TopologicalSpace X] (A : Set X), (∀ (x : X), x ∈ A → ∃ U, IsOpen U ∧ x ∈ U) → IsOpen A",
   "some-correct": null,
   "prompt":
   "If every point of a subset of a topological space is contained in some open set, the subset itself is open.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [ t :  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧   x ∈ U ∧  U ⊆ A ) ->  IsOpen  A",
    " (  X :  Type  u ) ->  (  A :  Set  X ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A"]},
  {"theorem":
   "∀ (a b N : ℕ), (∀ (d : ℕ), d ∣ a → d ∣ b → d = 1) → 2 ≤ N → ∃ x y, N = a * x + b * y",
   "some-correct": null,
   "prompt":
   "For any two relatively prime positive integers $a$ and $b$, every sufficiently large natural number $N$ can be written as a linear combination $ax + by$ of $a$ and $b$, where both $x$ and $y$ are natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  a b N :  ℕ ) ->  (  h :  ∀  d  ,   d ∣ a →   d ∣ b →  d =  1 ) ->  (  hn :   2 ≤ N ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :   gcd  a b =  1 ) ->  (  N :  ℕ ) ->  (  hN :  N >  a * b ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :   gcd  a b =  1 ) ->  (  n :  ℕ ) ->  (  hn :  n ≥ a ) ->  ∃    (   x  y :  ℕ ) ,  n =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  h :  a.coprime  b ) ->  (  hs :   a >  0 ∧  b >  0 ) ->  (  N :  ℕ ) ->  (  hN :  N >  1 ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :   gcd  a b =  1 ) ->  (  N :  ℕ ) ->  (  h :  N ≥   a + b +  2 ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :  IsCoprime  a b ) ->  ∃     x  y  :  ℕ ,  ∀  N   :  ℕ ,   (  N   :  ℤ ) ≥   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :  a.coprime  b ) ->  (  N :  ℕ ) ->  (  hN :  ∃     x  y  :  ℕ ,    a * x +  b * y = N ) ->  ∃     x  y  :  ℕ ,     a * x +  b * y = N ∧   x ≥  0 ∧  y ≥  0",
    " (  a b :  ℕ ) ->  (  h_rel_prime :   gcd  a b =  1 ) ->  (  min_sol :  ∃     x  y  :  ℕ ,    a * x +  b * y =  a * b ) ->  (  N :  ℕ ) ->  (  h_large :   b * N ≥  a * b ) ->  ∃     x  y  :  ℕ ,    a * x +  b * y = N"]},
  {"theorem": "(α : Type ?u.21604630) → [inst : Field α] → Ring α",
   "some-correct": null,
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type* ) ->  [  Field  α ] ->  Ring  α",
    " (  α :  Type* ) ->  [  Field  α ] ->  Ringₓ  α",
    " (  F :  Type* ) ->  [  Ring  F ] ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Ring  F ] ->  [  Field  F ] ->  Ringₓ  F",
    " (  F :  Type* ) ->  [  Ringₓ  F ] ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Ringₓ  F ] ->  [  Field  F ] ->  Ringₓ  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  CommRing  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  CommRingₓ  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ringₓ  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ringₓ  F",
    " (  α :  Type* ) ->  [  Field  α ] ->   @ Ring  α",
    " (  α :  Type* ) ->  [  Field  α ] ->   @ Ringₓ  α"]},
  {"theorem": "(A : Type ?u.22385239) → [inst : Ringₓ A] → Group (Units A)",
   "some-correct": null,
   "prompt": "The set of units in a ring forms a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  A :  Type* ) ->  [  Ringₓ  A ] ->  Group   (   Units  A  )",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  Groupₓ   (   Units  A  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " (  R :  Type* ) ->  [  Semiringₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type* ) ->  [  Semiringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " (  G :  Type* ) ->  [  Group  G ] ->  [  Monoidₓ  G ] ->  Group   (   Units  G  )",
    " (  G :  Type* ) ->  [  Group  G ] ->  [  Monoidₓ  G ] ->  Groupₓ   (   Units  G  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Monoid  G ] ->  Group   (   Units  G  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Monoid  G ] ->  Groupₓ   (   Units  G  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Monoidₓ  G ] ->  Group   (   Units  G  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Monoidₓ  G ] ->  Groupₓ   (   Units  G  )",
    " (  R :  Type* ) ->  [  Ring  R ] ->  Group   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ring  R ] ->  Groupₓ   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Group   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Groupₓ   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  x y :  Units  R ) ->    (   x * y  ) ⁻¹ =   x ⁻¹ *  y ⁻¹"]}],
 "elaborated": 26}