{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 20,
 "number-similar-sentences": 0,
 "number-keyword-sentences": 0,
 "include-fixed": true,
 "failures":
 ["Every vector space is finite dimensional.",
  "Every set has Lebesgue measure zero.",
  "Every set that is Lebesgue measurable but not Borel measurable has Lebesgue measure zero.",
  "A finitely-presented group containing a torsion element is finite.",
  "A topological space $X$ is Hausdorff if and only if the diagonal map is an open map from $X$ to $X × X$.",
  "Every normal subgroup of a group has finite index.",
  "The characteristic polynomial of every matrix has real roots.",
  "In a commutative ring, every prime ideal is contained in a unique maximal ideal.",
  "Every continuous function is uniformly continuous.",
  "Every uniformly continuous function is bounded above.",
  "The number of partitions of a finite set is a prime number.",
  "If a function from the unit interval to itself has a fixed point, then it has points of all positive periods.",
  "The complement of the union of two sets contains the union of their complements.",
  "The square root of an rational number is rational.",
  "The initial object of a category is isomorphic to its terminal object.",
  "If an element maps to zero under a ring homomorphism, then it is zero."],
 "elaborated-prompts":
 [{"theorem": "(R : Type ?u.5915) → [inst : Ring R] → Field R",
   "some-correct": null,
   "prompt": "Every ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  Ring  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Field  R",
    " (  R :  Type  u ) ->  [  Ring  R ] ->  Field  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  IsField  R",
    " (  X :  Type* ) ->  [  Ring  X ] ->  Field  X",
    " (  X :  Type* ) ->  [  Ringₓ  X ] ->  Field  X",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  [  NoZeroDivisors  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  NoZeroDivisors  R ] ->  Field  R",
    " (  A :  Type* ) ->  [  Ring  A ] ->  Field  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  Field  A"]},
  {"theorem":
   "∀ (G : Type ?u.301653) [inst : Groupₓ G], IsMonoidHom fun x => x",
   "some-correct": null,
   "prompt": "Every group is a torsion monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  IsMonoidHom   (   λ x : G , x  )"]},
  {"theorem":
   "∀ (G : Type ?u.465692) [inst : Fintype G] [inst_1 : Group G],\n  (∀ (a : G), a ≠ 1 → ∃ b, a * b = b * a) →\n    ∀ (a : G), a ≠ 1 → ∀ (n : ℕ), n > 1 → n ∣ Fintype.card G → n = Fintype.card G",
   "some-correct": null,
   "prompt": "Every finite simple group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Fintype  G ] ->  [  Group  G ] ->  (  hG :  ∀  a   : G ,   a ≠  1 →  ∃     b  : G ,   a * b =  b * a ) ->  ∀  a   : G ,   a ≠  1 →  ∀  n   :  ℕ ,   n >  1 →   n ∣  Fintype.card  G →  n =  Fintype.card  G",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  hG :  ∀  a   : G ,   a ≠  1 →  ∃     b  : G ,   a * b =  b * a ) ->  ∀  a   : G ,   a ≠  1 →  ∀  n   :  ℕ ,   n >  1 →   n ∣  Fintype.card  G →  n =  Fintype.card  G"]},
  {"theorem":
   "∀ (G : Type ?u.699982) [inst : Groupₓ G], Fintype G → IsSimpleGroup G",
   "some-correct": null,
   "prompt": "Every finite group is simple.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hf :  Fintype  G ) ->  IsSimpleGroup  G",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  IsSimpleGroup  G",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Group  G ] ->  (  hG :  ¬  ∀  x   : G ,  x ∈  {   1 } ) ->  ∀   (  n  :  ℕ  )  (  f  :  G → G  )  ,    f   1 =  1 →  ∃     x  ,   f  x ≠ x",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  hG :  ¬  ∀  x   : G ,  x ∈  {   1 } ) ->  ∀   (  n  :  ℕ  )  (  f  :  G → G  )  ,    f   1 =  1 →  ∃     x  ,   f  x ≠ x"]},
  {"theorem":
   "∀ (G : Type ?u.1255332) [inst : Group G], Fintype G → ∃ p, Prime p ∧ p ∣ Fintype.card G",
   "some-correct": null,
   "prompt": "Every finite group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  Fintype  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣  Fintype.card  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Fintype  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣  Fintype.card  G",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Group  G ] ->  (  hG_not_triv :   1 ≠  (   1   : G ) ) ->  ∃     p  :  ℕ ,   Prime  p ∧   Fintype.card  G = p",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  hG_not_triv :   1 ≠  (   1   : G ) ) ->  ∃     p  :  ℕ ,   Prime  p ∧   Fintype.card  G = p",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  Fintype  G ) ->  ∃     p  ,   Prime  p ∧  p ∣  Fintype.card  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Fintype  G ) ->  ∃     p  ,   Prime  p ∧  p ∣  Fintype.card  G"]},
  {"theorem":
   "∀ (X : Type ?u.1431788) [inst : TopologicalSpace X] [inst_1 : CompactSpace X] (A : Set X), IsCompact A → IsCompact A",
   "some-correct": null,
   "prompt": "If a topological space is compact, then every subset is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  IsCompact  A ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  (  A :  Set  X ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hXc :  IsCompact  X ) ->  (  A :  Set  X ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  (  A :  Set  X ) ->  (  hA :  IsOpen  A ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_compact :  IsCompact  X ) ->  (  A :  Set  X ) ->  (  hA_closed :  IsClosed  A ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  (  C :  Set  X ) ->  IsCompact  C",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  (  S :  Set  X ) ->  IsCompact  S",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  (  A :  Set  X ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  (  A :  Set  X ) ->  IsCompact  A"]},
  {"theorem":
   "∀ (X : Type ?u.5630805) [inst : TopologicalSpace X] (A : Set X),\n  (∀ (x : X), x ∈ A → ∃ C, IsClosed C ∧ x ∈ C) → IsClosed A",
   "some-correct": null,
   "prompt":
   "If every point of a subset of a topological space is contained in some closed set, the subset itself is closed.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  h :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧   x ∈ U ∧  U ⊆ A ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  h :  ∀  x  ∈ A ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   x ∈ U ∧  IsClosed  U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     F  :  Set  X ,   IsClosed  F ∧  x ∈ F ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     C  :  Set  X ,   IsClosed  C ∧   x ∈ C ∧  C ⊆ A ) ->  IsClosed  A"]},
  {"theorem":
   "∀ (G : Type ?u.10297708) [inst : Group G] (x : G), (∃ n, x ^ n = 1) → x = 1",
   "some-correct": null,
   "prompt": "Any finite order element in a group is equal to the identity.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  x : G ) ->  (  hx :  ∃     n  ,   x ^ n =  1 ) ->  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  ∃     n  ,   x ^ n =  1 ) ->  x =  1"]},
  {"theorem":
   "∀ (G : Type ?u.11018199) [inst : Groupₓ G] (H : Subgroup G), (∀ (x : G), x ∈ H → x = 1) → ∀ (x : G), x ≠ 1",
   "some-correct": null,
   "prompt":
   "If a subgroup of a group is torsion-free, then the group itself is torsion free.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Subgroup  G ) ->  (  H_torsion :  ∀  x   : G ,   x ∈ H →  x =  1 ) ->  ∀  x   : G ,  x ≠  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  hH :  IsSubgroup  H ) ->  (  hH_tfree :  ∀  x  ∈ H ,  x =  1 ) ->  ∀  x   : G ,  x =  1"]},
  {"theorem":
   "∀ (G : Type ?u.12040878) [inst : Group G] (f : G → G),\n  Function.Injective f → Fintype G → (∀ (x : G), ∃ h, f h = x) → Function.Surjective f",
   "some-correct": null,
   "prompt":
   "Every injective homomorphism from a finitely generated free group to itself is surjective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  f :  G → G ) ->  (  hf :  Function.Injective  f ) ->  (  fg :  Fintype  G ) ->  (  gfr :  ∀  x   : G ,  ∃     h  : G ,   f  h = x ) ->  Function.Surjective  f",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  f :  G → G ) ->  (  hf :  Function.Injective  f ) ->  (  fg :  Fintype  G ) ->  (  gfr :  ∀  x   : G ,  ∃     h  : G ,   f  h = x ) ->  Function.Surjective  f"]},
  {"theorem":
   "(D : Type ?u.12304461) → [inst : DivisionRing D] → ¬IsField D → Fintype D",
   "some-correct": null,
   "prompt": "Every division ring is either a field or finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->  ∃     n  :  ℕ ,   (   ∀  x   : D ,    1 + x ≠  0  ) ∧  ∀  x  ,   x ≠  0 →   x =  1 ∨  x =  -  1",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  h :  ¬  IsField  D ) ->  Fintype  D"]},
  {"theorem": "∀ (n : ℕ), ∃ p q, p * q = n ∧ Prime p ∧ Prime q",
   "some-correct": null,
   "prompt": "Every natural number is the product of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,    p * q = n ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  (  h_n_pos :   0 < n ) ->  ∃    (   p  q :  ℕ )  (   hp :  Prime  p )  (   hq :  Prime  q ) ,  n =  q * p",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   p ≠ q ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃     m  p  :  ℕ ,   m ≠ p ∧   m * p = n",
    " (  n :  ℕ ) ->  (  h :  n ≠  1 ) ->  ∃     a  b  :  ℕ ,   a ≠  1 ∧   b ≠  1 ∧  n =  a * b",
    " (  a :  ℕ ) ->  (  ha :   1 < a ) ->  ∃     b  c  ,   b >  1 ∧   c >  1 ∧   b * c = a",
    " (  n :  ℕ ) ->  (  hn :   0 < n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  h :  n ≠  0 ) ->  ∃     p  q  :  ℕ ,   p >  1 ∧   q >  1 ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   p ≠  1 ∧   q ≠  1 ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  primes :  List   (    ℕ ×  ℕ  ) ) ->  (  hprimes :  ∀  p q   :  ℕ ,    (  p   ,  q ) ∈ primes ↔   Nat.Prime  p ∧  Nat.Prime  q ) ->  ∃    (   p  q :  ℕ ) ,    (  p   ,  q ) ∈ primes ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   p ≠ q ∧   p >  1 ∧   q >  1 ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  hn :  n >  4 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  (  h1 :  n >  1 ) ->  (  h2 :   n %  2 ≠  0 ) ->  ∃     p  q  :  ℕ ,   p ≠ q ∧   Prime  p ∧   Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  hn1 :   1 < n ) ->  ∃     m  p  :  ℕ ,   m ≠  1 ∧   p ≠  1 ∧   m * p = n",
    " (  n :  ℕ ) ->  (  hprime :  ∀  p   :  ℕ ,   Prime  p →    n % p =  0 →   p =  1 ∨  p = n ) ->  ∃     p₁  p₂  :  ℕ ,   p₁ * p₂ = n",
    " (  n :  ℕ ) ->  (  h1 :  Prime  n ) ->   (   n =  2  ) ∨  (   ∃     m  p  ,   Prime  m ∧   Prime  p ∧  n =  m * p  )"]},
  {"theorem": "∀ (m : ℕ), Even m → ∃ n, m = n ^ 2",
   "some-correct": null,
   "prompt": "Every even number is the square of a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀   (  n  :  ℤ  )  ,    n %  2 =  0 →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " (  m :  ℕ ) ->   Even  m →  ∃     n  ,  m =  n ^  2",
    " (  n :  ℕ ) ->  (  h :  Even  n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  m :  ℕ ) ->    2 ∣ m →  ∃     n  :  ℕ ,  m =  n ^  2",
    " (  n :  ℕ ) ->  (  h2 :  ∃     m  :  ℕ ,  n =   2 * m ) ->  ∃     m  :  ℕ ,  n =  m * m",
    " ∀  n   :  ℕ ,   (    n %  2 =  0  ) →  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->  ∃     m  :  ℕ ,   m ^  2 = n",
    " (  n :  ℕ ) ->  (  h :  ∃     m  :  ℕ ,  n =   2 * m ) ->  ∃     k  :  ℕ ,  n =  k ^  2",
    " (  n :  ℕ ) ->  (  h :  ∃     m  :  ℕ ,  n =  m ^  2 ) ->  ∃     k  :  ℕ ,  n =  k ^  2",
    " (  n :  ℕ ) ->  (  h2 :   2 ∣ n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℤ ) ->  (  hpos :   n %  2 =  0 ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->   Even  n ↔  ∃     m  :  ℕ ,  n =  m * m",
    " (  n :  ℕ ) ->  (  hn :   2 ∣ n ) ->  (  h :  n ≠  0 ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  h2n :    2 * n =  0 ) ->  ∃     m  ,   m ^  2 = n",
    " (  n :  ℤ ) ->  (  h :  ∃     m  ,  n =   2 * m ) ->  ∃     p  ,  n =  p ^  2",
    " (  n :  ℕ ) ->  {  o :  Prop } ->  [  DecidableEq  o ] ->  (  h :   n =  0 ∨  (   ∃     m  :  ℕ ,  n =   2 * m  ) ) ->  (   ∀  m   :  ℕ ,    m * m = n →   m =  0 ∨  (   ∃     k  :  ℕ ,  m =   2 * k  )  )",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->  ∃     m  ,   m ^  2 = n",
    " (  m :  ℕ ) ->  (  h :  Even  m ) ->  ∃     n  ,  m =  n ^  2",
    " (  n :  ℤ ) ->    n %  2 =  0 →  ∃     m  :  ℕ ,  n =  m * m",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,  n =  m ^  2"]},
  {"theorem":
   "∀ (X : Type ?u.13926416) [inst : TopologicalSpace X] (h : ∀ (K : Set X), IsCompact K → IsClosed K),\n  IsCompact (?m.13926618 X h)",
   "some-correct": null,
   "prompt":
   "If every compact subset of a topological space is closed, then the space is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hcompact :  ∀   (  K  :  Set  X  )  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  C   :  Set  X ,   IsCompact  C →  IsClosed  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  S  ,   IsCompact  S →  IsClosed  S ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  K  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  H :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀   (  C  :  Set  X  )  ,   IsCompact  C →  IsClosed  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hc :  ∀  C  ,   IsCompact  C →  IsClosed  C ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hC :  ∀  K  ,   IsCompact  K →  IsClosed  K ) ->  CompactSpace  X"]},
  {"theorem":
   "∀ (A : Type ?u.19079617) [inst : CommRing A] {a b : A}, a * a = a → b * b = b → a + b ≠ 0 → (a + b) * (a + b) = a + b",
   "some-correct": null,
   "prompt":
   "In a commutative ring, the sum of idempotent elements is idempotent.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  A :  Type* ) ->  [  CommRing  A ] ->  {  a b : A } ->    a * a = a →    b * b = b →    a + b ≠  0 →    (   a + b  ) *  (   a + b  ) =  a + b",
    " (  A :  Type* ) ->  [  CommRingₓ  A ] ->  {  a b : A } ->    a * a = a →    b * b = b →    a + b ≠  0 →    (   a + b  ) *  (   a + b  ) =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  x y : R ) ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x y : R ) ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  {  a b : R } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  {  a b : R } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  x y : R ) ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x y : R ) ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  (   a + b  )",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  (   a + b  )",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  f g : R ) ->  (  hf :   f ^  2 = f ) ->  (  hg :   g ^  2 = g ) ->    (   f + g  ) ^  2 =  f + g",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  f g : R ) ->  (  hf :   f ^  2 = f ) ->  (  hg :   g ^  2 = g ) ->    (   f + g  ) ^  2 =  f + g",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  {  a b : R } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  {  a b : R } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  x y : R ) ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x y : R ) ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  {  x y : R } ->    x ^  2 = x →    y ^  2 = y →    (   x + y  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  {  x y : R } ->    x ^  2 = x →    y ^  2 = y →    (   x + y  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  f g : R ) ->  (  hf :   f * f = f ) ->  (  hg :   g * g = g ) ->    (   f + g  ) *  (   f + g  ) =  f + g",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  f g : R ) ->  (  hf :   f * f = f ) ->  (  hg :   g * g = g ) ->    (   f + g  ) *  (   f + g  ) =  f + g",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  x y : R ) ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x y : R ) ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b"]},
  {"theorem":
   "∀ (L : Type ?u.32134056) [inst : PartialOrder L],\n  (∃ l, ∀ (l' : L), l' ≤ l → l' = l) → ExistsUnique fun l => ∀ (l' : L), l ≤ l'",
   "some-correct": null,
   "prompt":
   "If a poset has a maximal element, then it has a unique minimal element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  L :  Type* ) ->  [  PartialOrder  L ] ->  (  L_max :  ∃    (   l : L ) ,  ∀   (  l'  : L  )  ,   l' ≤ l →  l' = l ) ->  ∃!    (   l : L ) ,  ∀   (  l'  : L  )  ,  l ≤ l'",
    " (  L :  Type* ) ->  [  PartialOrderₓ  L ] ->  (  L_max :  ∃    (   l : L ) ,  ∀   (  l'  : L  )  ,   l' ≤ l →  l' = l ) ->  ∃!    (   l : L ) ,  ∀   (  l'  : L  )  ,  l ≤ l'",
    " (  X :  Type* ) ->  [  LE  X ] ->  [  PartialOrder  X ] ->  (  maximal_element : X ) ->  (  minimal_element : X ) ->  (  hmaximal_element :  ∀  x   : X ,  maximal_element ≤ x ) ->  (  hminimal_element :  ∀  x   : X ,  x ≤ minimal_element ) ->  minimal_element = maximal_element",
    " (  X :  Type* ) ->  [  LE  X ] ->  [  PartialOrderₓ  X ] ->  (  maximal_element : X ) ->  (  minimal_element : X ) ->  (  hmaximal_element :  ∀  x   : X ,  maximal_element ≤ x ) ->  (  hminimal_element :  ∀  x   : X ,  x ≤ minimal_element ) ->  minimal_element = maximal_element",
    " (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  m : X ) ->  (  h :  ∀  x   : X ,  m ≤ x ) ->  ∃!     x  : X ,  ∀  y   : X ,  x ≤ y",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  m : X ) ->  (  h :  ∀  x   : X ,  m ≤ x ) ->  ∃!     x  : X ,  ∀  y   : X ,  x ≤ y",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  maximal_elem :  ∃     x  : P ,  ∀  y  ,  x ≤ y ) ->  ∃!     minimal_elem  ,  ∀  y  ,  minimal_elem ≤ y",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  maximal_elem :  ∃     x  : P ,  ∀  y  ,  x ≤ y ) ->  ∃!     minimal_elem  ,  ∀  y  ,  minimal_elem ≤ y",
    " (  P :  Type  u ) ->  [  PartialOrder  P ] ->  (  hmax :  ∃    (   m : P ) ,  ∀   (  p  : P  )  ,  p ≤ m ) ->  ∃!    (   l : P ) ,  ∀   (  p  : P  )  ,  l ≤ p",
    " (  P :  Type  u ) ->  [  PartialOrderₓ  P ] ->  (  hmax :  ∃    (   m : P ) ,  ∀   (  p  : P  )  ,  p ≤ m ) ->  ∃!    (   l : P ) ,  ∀   (  p  : P  )  ,  l ≤ p",
    " (  α :  Type  u ) ->  [  PartialOrder  α ] ->  (  m : α ) ->  (  h :  ∀  x   : α ,  ¬  x > m ) ->  ∀  x   : α ,   ¬  ¬  x ≤ m →  x = m",
    " (  α :  Type  u ) ->  [  PartialOrderₓ  α ] ->  (  m : α ) ->  (  h :  ∀  x   : α ,  ¬  x > m ) ->  ∀  x   : α ,   ¬  ¬  x ≤ m →  x = m",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hmax :  ∃     x  : P ,  ∀  y   : P ,  x ≤ y ) ->  ∃!     x  : P ,  ∀  y   : P ,  y ≤ x",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hmax :  ∃     x  : P ,  ∀  y   : P ,  x ≤ y ) ->  ∃!     x  : P ,  ∀  y   : P ,  y ≤ x",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hmax :  ∃     x  : P ,  ∀  y   : P ,  y ≤ x ) ->  (  hmin :  ∃     z  : P ,  ∀  w   : P ,  z ≤ w ) ->  ∃!     min  : P ,  ∀  x   : P ,  min ≤ x",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hmax :  ∃     x  : P ,  ∀  y   : P ,  y ≤ x ) ->  (  hmin :  ∃     z  : P ,  ∀  w   : P ,  z ≤ w ) ->  ∃!     min  : P ,  ∀  x   : P ,  min ≤ x",
    " (  α :  Type  ) ->  [  LinearOrder  α ] ->  (  hα :  ∃     a  : α ,  ∀  b   : α ,  b ≤ a ) ->  ∃     a  : α ,  ∀  b   : α ,  a ≤ b",
    " (  α :  Type  ) ->  [  LinearOrderₓ  α ] ->  (  hα :  ∃     a  : α ,  ∀  b   : α ,  b ≤ a ) ->  ∃     a  : α ,  ∀  b   : α ,  a ≤ b"]},
  {"theorem":
   "∀ (G : Type ?u.35478073) [inst : Group G], CommGroup G → ∃ c, ∀ (x : G), c * x = x * c",
   "some-correct": null,
   "prompt": "The automorphism group of an Abelian group is cyclic.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  CommGroup  G ) ->  (   ∃     c  : G ,  ∀  x  ,   c * x =  x * c  )",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  CommGroupₓ  G ) ->  (   ∃     c  : G ,  ∀  x  ,   c * x =  x * c  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  CommGroup  G ) ->  (   ∃     c  : G ,  ∀  x  ,   c * x =  x * c  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  CommGroupₓ  G ) ->  (   ∃     c  : G ,  ∀  x  ,   c * x =  x * c  )"]},
  {"theorem":
   "∀ (R : Type ?u.51555319) [inst : CommRingₓ R] (M : Type ?u.51555327) [inst_1 : AddCommGroupₓ M] [inst_2 : Module R M]\n  (hM : ∀ (S : Set M), (∀ (x : M), x ∈ S → x = 0) → (∀ (x : M), x ∈ S → x = 0) → ∀ (x : M), x = 0),\n  Commutative (?m.51559019 R M hM)",
   "some-correct": null,
   "prompt": "If a module over a ring is free, then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  M :  Type* ) ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  hM :  ∀  S   :  Set  M ,   (   ∀  x  ∈ S ,  x =  0  ) →   (   ∀  x   : M ,   x ∈ S →  x =  0  ) →  ∀   (  x  : M  )  ,  x =  0 ) ->  Commutative  R"]},
  {"theorem":
   "(R : Type ?u.71730645) → [inst : Ringₓ R] → [inst_1 : Group (Units R)] → CommGroup (Units R) → CommRing R",
   "some-correct": null,
   "prompt":
   "If the set of units of a ring forms a group then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  (  h :  CommGroup   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  (  h :  CommGroup   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  (  h :  CommGroupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  (  h :  CommGroupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  (  h :  CommGroup   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  (  h :  CommGroup   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  (  h :  CommGroupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  (  h :  CommGroupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  CommMonoid   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  CommMonoid   (   Units  R  ) ] ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  CommMonoidₓ   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  CommMonoidₓ   (   Units  R  ) ] ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_r :  ∀  x   : R ,    x * x =  1 →   x =  1 ∨  x =  -  1 ) ->  (  h_unit :  Units  R ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_r :  ∀  x   : R ,    x * x =  1 →   x =  1 ∨  x =  -  1 ) ->  (  h_unit :  Units  R ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Group   (   Units  R  ) ) ->  (  x y : R ) ->   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Groupₓ   (   Units  R  ) ) ->  (  x y : R ) ->   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  hR :  IsSubgroup   (   Units  R  ) ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hU :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hU :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hU :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hU :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Group   (   Units  R  ) ) ->  CommGroup   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Group   (   Units  R  ) ) ->  CommGroupₓ   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Groupₓ   (   Units  R  ) ) ->  CommGroup   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Groupₓ   (   Units  R  ) ) ->  CommGroupₓ   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRingₓ  R"]},
  {"theorem": "∀ (n : ℕ), n > 10 → ∃ p q, n = p * p + q ∧ Prime q",
   "some-correct": null,
   "prompt":
   "Every natural number larger than `10` is the sum of a square and a prime.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀  n   :  ℕ ,   n >  10 →  ∃     p  q  :  ℕ ,   n =   p * p + q ∧  Prime  q",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     a  b  :  ℕ ,   Prime  b ∧    a ^  2 + b = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  ∃     q  :  ℕ ,    q * q + p = n",
    " ∀  n   :  ℕ ,   n >  10 →  ∃    (   a :  ℕ )  (   b :  ℕ ) ,   n =   a ^  2 + b ∧  Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  m  ,  p.prime ∧    m ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     x  p  :  ℕ ,     x ^  2 + p = n ∧  Prime  p",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃     m  p  :  ℕ ,     m ^  2 + p = n ∧  Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  ∃     k  :  ℕ ,    k ^  2 + p = n",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃     p  m  :  ℕ ,   Prime  p ∧   m * m =  n - p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧    q ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  :  ℕ ,  ∃     k  :  ℕ ,   Prime  p ∧  n =   k ^  2 + p",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  ∃     a  :  ℕ ,  n =   a ^  2 + p"]},
  {"theorem":
   "∀ (X : Type ?u.71905127) (Y : Type ?u.71905130) (Z : Type ?u.71905133) [inst : TopologicalSpace X]\n  [inst_1 : TopologicalSpace Y] [inst_2 : TopologicalSpace Z] (f : X → Y) (g : Y → Z),\n  Continuous (g ∘ f) → Continuous f ∧ Continuous g",
   "some-correct": null,
   "prompt":
   "If the composition of two functions is continuous, then each of them is continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  Y X Z :  Type* ) ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Z ] ->  (  f :  Y → X ) ->  (  g :  X → Z ) ->  (  hfg :  Continuous   (   f ∘ g  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  h_comp :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  Continuous   (   g ∘ f  )",
    " (  α β γ :  Type* ) ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  (  f :  X → Y ) ->  (  g :  Y → X ) ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  (  hfg :  Continuous   (   λ x ,  g   (   f  x  )  ) ) ->  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->  Continuous  g",
    " (  M N P :  Type* ) ->  [  TopologicalSpace  M ] ->  [  TopologicalSpace  N ] ->  [  TopologicalSpace  P ] ->  (  f :  M → N ) ->  (  g :  N → P ) ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  ∀  x  ,  Continuous   (   λ x' ,  g   (   f  x'  )  )",
    " (  A B C :  Type* ) ->  [  TopologicalSpace  A ] ->  [  TopologicalSpace  B ] ->  [  TopologicalSpace  C ] ->  (  f :  A → B ) ->  (  g :  B → C ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hgf :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " (  Y Z :  Type* ) ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  Y → Z ) ->  (  g :  Y → Y ) ->  (  h :  Continuous   (   f ∘ g  ) ) ->   Continuous  f ∧  Continuous  g"]},
  {"theorem":
   "∀ (G : Type ?u.78163114) [inst : Group G] (a b c : G), a * b = b * a → b * c = c * b → a * c = c * a",
   "some-correct": null,
   "prompt":
   "If `a` commutes with `b` and `b` commutes with `c` then `a` commutes with `c`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  h₁ :   a * b =  b * a ) ->  (  h₂ :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h₁ :   a * b =  b * a ) ->  (  h₂ :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  ha :   a * b =  b * a ) ->  (  hb :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  ha :   a * b =  b * a ) ->  (  hb :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  CommGroup  G ] ->  (  a b c : G ) ->    a * b =  b * a →    b * c =  c * b →   a * c =  c * a",
    " (  G :  Type* ) ->  [  CommGroupₓ  G ] ->  (  a b c : G ) ->    a * b =  b * a →    b * c =  c * b →   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  h' :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  h' :   b * c =  c * b ) ->   a * c =  c * a",
    " (  a b c :  Type* ) ->  [  CommGroup  a ] ->  [  CommGroup  b ] ->  [  CommGroup  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroup  a ] ->  [  CommGroup  b ] ->  [  CommGroupₓ  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroup  a ] ->  [  CommGroupₓ  b ] ->  [  CommGroup  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroup  a ] ->  [  CommGroupₓ  b ] ->  [  CommGroupₓ  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroupₓ  a ] ->  [  CommGroup  b ] ->  [  CommGroup  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroupₓ  a ] ->  [  CommGroup  b ] ->  [  CommGroupₓ  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroupₓ  a ] ->  [  CommGroupₓ  b ] ->  [  CommGroup  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  a b c :  Type* ) ->  [  CommGroupₓ  a ] ->  [  CommGroupₓ  b ] ->  [  CommGroupₓ  c ] ->  (  hb :  ∀  x y   : b ,   x * y =  y * x ) ->  (  hc :  ∀  x y   : c ,   x * y =  y * x ) ->  ∀  x y   :  a × c ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  ha :   a * b =  b * a ) ->  (  hb :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  ha :   a * b =  b * a ) ->  (  hb :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hba :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hba :   b * c =  c * b ) ->   a * c =  c * a",
    " (  a b c :  ℕ ) ->    a * b =  b * a →    b * c =  c * b →   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  h' :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  h' :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  h_commab :   a * b =  b * a ) ->  (  h_commbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h_commab :   a * b =  b * a ) ->  (  h_commbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  M :  Type* ) ->  [  AddCommGroup  M ] ->  [  Ring  M ] ->  (  a b c : M ) ->  (  h1 :   a * b =  b * a ) ->  (  h2 :   b * c =  c * b ) ->   a * c =  c * a",
    " (  M :  Type* ) ->  [  AddCommGroup  M ] ->  [  Ringₓ  M ] ->  (  a b c : M ) ->  (  h1 :   a * b =  b * a ) ->  (  h2 :   b * c =  c * b ) ->   a * c =  c * a",
    " (  M :  Type* ) ->  [  AddCommGroupₓ  M ] ->  [  Ring  M ] ->  (  a b c : M ) ->  (  h1 :   a * b =  b * a ) ->  (  h2 :   b * c =  c * b ) ->   a * c =  c * a",
    " (  M :  Type* ) ->  [  AddCommGroupₓ  M ] ->  [  Ringₓ  M ] ->  (  a b c : M ) ->  (  h1 :   a * b =  b * a ) ->  (  h2 :   b * c =  c * b ) ->   a * c =  c * a"]},
  {"theorem": "∀ (P Q : Prop), P → Q ↔ Q → P",
   "some-correct": null,
   "prompt": "Implication `→` is symmetric. If `P → Q` then `Q → P`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  P Q :  Prop ) ->   (   P → Q  ) ↔  (   Q → P  )",
    " (  P Q :  Prop ) ->  (  h :  P → Q ) ->  Q → P",
    " (  P Q :  Prop ) ->   (   P → Q  ) →  (   Q → P  )",
    " (  P Q :  Prop ) ->  P →  Q → P",
    " (  p q :  Prop ) ->   (   p → q  ) →  (   q → p  )"]},
  {"theorem": "∀ (m n : ℕ), m = n ↔ ∃ p, m % p.val = 0 ∧ n % p.val = 0",
   "some-correct": null,
   "prompt":
   "Two natural numbers are equal if and only if they are both divisible by some prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n₁ n₂ :  ℕ ) ->   n₁ = n₂ ↔  ∃     p  ,   Prime  p ∧   p ∣ n₁ ∧  p ∣ n₂",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  {   p   :  ℕ |  Prime  p } ,    m % p =  0 ∧   n % p =  0",
    " (  m n :  ℕ ) ->  (  h :  ∃     p  ,   Prime  p ∧   p ∣ m ∧  p ∣ n ) ->  m = n",
    " (  a b :  ℕ ) ->   a = b ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ a ∧  p ∣ b",
    " (  x y :  ℕ ) ->   x = y ↔  ∃     p  ,   Prime  p ∧   p ∣ x ∧  p ∣ y",
    " (  n m :  ℕ ) ->   n = m ↔  ∃     p  :  ℕ ,   Prime  p ∧    n % p =  0 ∧   m % p =  0",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧    m % p =  0 ∧   n % p =  0",
    " (  n m :  ℕ ) ->   n = m ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ n ∧  p ∣ m",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  ,   Prime  p ∧   p ∣ m ∧  p ∣ n",
    " (  a b :  ℕ ) ->  (  hp :  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ a ∧  p ∣ b ) ->  a = b",
    " (  m n :  ℕ ) ->  (  hmn :  ∃     p  :  ℕ ,   Prime  p ∧    m % p =  0 ∧   n % p =  0 ) ->  m = n"]}],
 "elaborated": 24}