{"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.",
  "Any finite order element in a group is equal to the identity.",
  "If a subgroup of a group is torsion-free, then the group itself is torsion free.",
  "Every injective homomorphism from a finitely generated free group to itself is surjective.",
  "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 automorphism group of an Abelian group is cyclic.",
  "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."],
 "elaborated-prompts":
 [{"theorem": "(R : Type ?u.6271) → [inst : Ring R] → Field R",
   "some-correct": null,
   "round-trip":
   "A ring is a field if and only if it is a domain and every nonzero element is invertible. ",
   "prompt": "Every ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  Ring  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Field  R",
    " (  A :  Type* ) ->  [  Ring  A ] ->  Field  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  Field  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  IsField  A",
    " (  A :  Type* ) ->  [  Ring  A ] ->  (  a : A ) ->  (  ha :  a ≠  0 ) ->  ∃     b  : A ,   a * b =  1",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  (  a : A ) ->  (  ha :  a ≠  0 ) ->  ∃     b  : A ,   a * b =  1"]},
  {"theorem": "∀ (G : Type ?u.304106) [inst : Groupₓ G], Monoidₓ.IsTorsion G",
   "some-correct": null,
   "round-trip": "Groups are torsion. ",
   "prompt": "Every group is a torsion monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G"]},
  {"theorem":
   "∀ (G : Type ?u.1209759) [inst : Groupₓ G], Fintype G → IsSimpleGroup G → ∃ p, Prime p ∧ p ≥ 2 ∧ Fintype.card G = p",
   "some-correct": null,
   "round-trip":
   "A finite simple group is isomorphic to `ℤ/pℤ` for some prime `p`. ",
   "prompt": "Every finite simple group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Fintype  G ) ->  (  simple :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧   p ≥  2 ∧   Fintype.card  G = p",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  IsSimpleGroup  G ) ->  (  hG_fin :  Fintype  G ) ->  ∀  p  ,  p.prime →   p ∣  Fintype.card  G →   p =  2 ∨  p =  3",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  IsSimpleGroup  G ) ->  (  hG_finite :  sorry ) ->  ∃     p  :  ℕ ,  sorry"]},
  {"theorem":
   "∀ (G : Type ?u.1321067) [inst : Fintype G] [inst : Groupₓ G], IsSimpleGroup G",
   "some-correct": null,
   "round-trip": " Finite groups are simple. ",
   "prompt": "Every finite group is simple.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  IsSimpleGroup  G"]},
  {"theorem":
   "∀ (G : Type ?u.1534903) [inst : Group G], Fintype G → Nontrivial G → ∃ p, ∀ (a : G), a = 1 → p = 1",
   "some-correct": null,
   "round-trip":
   "If a group is nontrivial and finite, then it has an element of order greater than 1. ",
   "prompt": "Every finite group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  hG_fint :  Fintype  G ) ->  (  hG_nontrivial :  Nontrivial  G ) ->  ∃     p  :  ℕ ,  ∀   (  a  : G  )  ,   a =  1 →  p =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG_fint :  Fintype  G ) ->  (  hG_nontrivial :  Nontrivial  G ) ->  ∃     p  :  ℕ ,  ∀   (  a  : G  )  ,   a =  1 →  p =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG_fin :  Fintype  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧   Fintype.card  G = p",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG_fin :  Fintype  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧   Fintype.card  G = p",
    " (  G :  Type* ) ->  [  Group  G ] ->  [  Fintype  G ] ->  Nat.Prime   (   Fintype.card  G  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  Nat.Prime   (   Fintype.card  G  )",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Group  G ] ->  (  h :  ¬  (   ∃     n  :  ℕ ,   n >  1 ∧  ∀  x  ,   x ^ n =  1  ) ) ->  ∀  x   : G ,  x ≠  1",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  h :  ¬  (   ∃     n  :  ℕ ,   n >  1 ∧  ∀  x  ,   x ^ n =  1  ) ) ->  ∀  x   : G ,  x ≠  1",
    " (  n :  ℕ ) ->  (  h :  n ≠  0 ) ->  (  G :  Type* ) ->  [  Fintype  G ] ->  [  Group  G ] ->  (  hG :   Fintype.card  G = n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n ≠  0 ) ->  (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  hG :   Fintype.card  G = n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n"]},
  {"theorem":
   "∀ (X : Type ?u.2192475) [inst : TopologicalSpace X], CompactSpace X → ∀ (A : Set X), IsClosed A → IsCompact A",
   "some-correct": null,
   "round-trip": "**Compactness of Closed Sets** ",
   "prompt": "If a topological space is compact, then every subset is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  CompactSpace  X ) ->  (  A :  Set  X ) ->  (  hA :  IsClosed  A ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  (  A :  Set  X ) ->  IsCompact  A"]},
  {"theorem":
   "∀ (G : Type ?u.4060447) [inst : Fintype G] [inst : Group G], (∃ g, g ≠ 1) → Finite G",
   "some-correct": null,
   "round-trip": "If a group has a nontrivial element, then it is finite. ",
   "prompt":
   "A finitely-presented group containing a torsion element is finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Fintype  G ] ->  [  Group  G ] ->  (  h :  ∃     g  : G ,  g ≠  1 ) ->  Finite  G",
    " (  G :  Type* ) ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  h :  ∃     g  : G ,  g ≠  1 ) ->  Finite  G",
    " (  G :  Type* ) ->  [  Group  G ] ->  [  Fintype  G ] ->  (  h :  ∃     x  : G ,  x ≠  1 ) ->  Finite  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  ∃     x  : G ,  x ≠  1 ) ->  Finite  G"]},
  {"theorem":
   "∀ (X : Type ?u.4276605) [inst : TopologicalSpace X] (A : Set X),\n  (∀ (x : X), x ∈ A → ∃ U, IsClosed U ∧ x ∈ U) → IsClosed A",
   "some-correct": null,
   "round-trip": "**Closed Sets** ",
   "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 ,  ∃     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  : X  )  (  hx  :  x ∈ A  )  ,  ∃    (   C :  Set  X ) ,   IsClosed  C ∧   x ∈ C ∧  C ⊆ A ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     B  :  Set  X ,   IsClosed  B ∧   x ∈ B ∧  B ⊆ A ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     V  :  Set  X ,   IsClosed  V ∧  x ∈ V ) ->  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 ,  ∃     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 ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ,   x ∈ A →  ∃     B  :  Set  X ,   IsClosed  B ∧   x ∈ B ∧  B ⊆ 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 ) ->  (  hA :  ∀  x  ∈ A ,  ∃     B  :  Set  X ,   IsClosed  B ∧  x ∈ B ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃    (   C :  Set  X ) ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  A"]},
  {"theorem":
   "∀ (X : Type ?u.5040700) [inst : TopologicalSpace X]\n  (hX : ∀ (x y : X), ∃ U V, IsOpen U ∧ IsOpen V ∧ x ∈ U ∧ y ∈ V ∧ U ∩ V = ∅), IsOpen fun x => ?m.5041028 X hX x",
   "some-correct": null,
   "round-trip":
   "If `X` is a topological space such that for all `x,y ∈ X`, there are disjoint open sets `U,V` containing `x,y` respectively, then the set of isolated points is open. ",
   "prompt":
   "A topological space $X$ is Hausdorff if and only if the diagonal map is an open map from $X$ to $X × X$.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀   (  x y  : X  )  ,  ∃     U  V  :  Set  X ,   IsOpen  U ∧   IsOpen  V ∧   x ∈ U ∧   y ∈ V ∧   U ∩ V =  ∅ ) ->  IsOpen   (   λ   ( x : X ) ,  (  x   ,  x )  )"]},
  {"theorem":
   "∀ (D : Type ?u.10919508) [inst : DivisionRing D], Finite D ∨ IsField D",
   "some-correct": null,
   "round-trip": "A division ring is either finite or a field ",
   "prompt": "Every division ring is either a field or finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->   Finite  D ∨  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  H1 :  ¬  IsField  D ) ->  Finite  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  H :  ¬  IsField  D ) ->  Fintype  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->   IsField  R ∨  (   ∀  x   : R ,   x =  0 ∨  x =  1  )",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD :  ¬  IsField  D ) ->  Finite  D"]},
  {"theorem": "∀ (n : ℕ), ∃ p q, n = p * q ∧ Prime p ∧ Prime q",
   "some-correct": null,
   "round-trip":
   " Every natural number `n` can be written as the product of two primes. ",
   "prompt": "Every natural number is the product of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   n =  p * q ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  (  hn :  n ≥  2 ) ->  ∃     p  :  ℕ ,  ∃     q  :  ℕ ,    p * q = n ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,    p * q = n ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  (  hn :  n ≥  2 ) ->  ∃     m  p  :  ℕ ,   Prime  m ∧   Prime  p ∧  n =  m * p",
    " (  n :  ℕ ) ->  (  hn :  n ≥  2 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  (  hnp :  ¬  Prime  n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p ≠ q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   n =  p * q ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  ∃     x  y  :  ℕ ,   Prime  x ∧   Prime  y ∧   x * y = n",
    " (  m :  ℕ ) ->  (  hm :  m ≠  0 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  m =  p * q",
    " (  n :  ℕ ) ->  (  n0 :   0 < n ) ->  ∃    (   p :  ℕ )  (   h :  Prime  p )  (   q :  ℕ )  (   h' :  Prime  q ) ,   p * q = n",
    " ∀  n   :  ℕ ,  ∃     p  q  :  ℕ ,   n =  p * q ∧   Prime  p ∧  Prime  q",
    " ∀  n   :  ℕ ,  ∃    (   p  q :  ℕ ) ,   Prime  p ∧   Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  q  :  ℕ ,    p * q = n ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  (  hn :  n >  0 ) ->  ∃     p  q  :  ℕ ,   p ≤ q ∧   p ≠  1 ∧   q ≠  1 ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  h1 :  n ≠  1 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p * q = n"]},
  {"theorem": "∀ (m : ℕ), ∃ n, m = n ^ 2 ↔ ∃ n, m = 2 * n",
   "some-correct": null,
   "round-trip": "If `m` is a square, then `m` is even. ",
   "prompt": "Every even number is the square of a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  m :  ℕ ) ->  ∃     n  :  ℕ ,   m =  n ^  2 ↔  ∃     n  :  ℕ ,  m =   2 * n",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->  ∃     k  :  ℕ ,   k ^  2 = n",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->  ∃     m  :  ℕ ,   m ^  2 = n",
    " (  m :  ℤ ) ->  (  hm :   2 ∣ m ) ->  ∃     n  :  ℕ ,  m =  n ^  2",
    " (  n :  ℕ ) ->  ∃     k  :  ℕ ,     2 * k = n ↔   n %  2 =  0",
    " (  n :  ℕ ) ->  (  h :  ∃     m  :  ℕ ,  n =   2 * m ) ->  ∃     i  :  ℕ ,  n =  i ^  2",
    " (  n :  ℕ ) ->  (  hn :  Even  n ) ->  ∃     k  :  ℕ ,  n =  k ^  2",
    " (  n :  ℕ ) ->  (  hn2 :   2 ∣ n ) ->  ∃     k  :  ℕ ,  n =   2 * k",
    " (  n :  ℕ ) ->  ∃     m  :  ℤ ,   m ^  2 =   2 * n",
    " (  n :  ℕ ) ->   Even  n →  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℤ ) ->  (  hn2 :   2 ∣ n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  ∃     i  :  ℕ ,    2 * n =  i ^  2",
    " (  n :  ℕ ) ->  (  h :  ∃     m  ,    2 * m = n ) ->  ∃     m  ,   m ^  2 = n",
    " (  n :  ℕ ) ->  (  hn2 :  ∃     m  :  ℕ ,  n =   2 * m ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  hn :  Even  n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  h2_dvd :   2 ∣ n ) ->  ∃     k  :  ℕ ,  n =  k * k"]},
  {"theorem":
   "∀ (X : Type ?u.13571475) [inst : TopologicalSpace X], (∀ (K : Set X), IsCompact K → IsClosed K) → CompactSpace X",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 ] ->  (  h :  ∀  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 ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hc :  ∀  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 ] ->  [  CompactSpace  X ] ->  IsClosed   (  Set.Univ   :  Set  X )",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hcompact :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  S   :  Set  X ,   IsCompact  S →  IsClosed  S ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h :  ∀  A   :  Set  X ,   IsCompact  A →  IsClosed  A ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hx :  ∀  U   :  Set  X ,   IsCompact  U →  IsClosed  U ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X"]},
  {"theorem":
   "∀ (R : Type ?u.14116521) [inst : CommRing R] (p q : R), p * p = p → q * q = q → (p + q) * (p + q) = p + q",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "In a commutative ring, the sum of idempotent elements is idempotent.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  CommRing  R ] ->  (  p q : R ) ->  (  hp :   p * p = p ) ->  (  hq :   q * q = q ) ->    (   p + q  ) *  (   p + q  ) =  p + q",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  p q : R ) ->  (  hp :   p * p = p ) ->  (  hq :   q * q = q ) ->    (   p + q  ) *  (   p + q  ) =  p + q",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  x y : R ) ->  (  hxy :   x * x = x ) ->  (  hyy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x y : R ) ->  (  hxy :   x * x = x ) ->  (  hyy :   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 ] ->  (  a b : R ) ->  (  h1 :   a ^  2 = a ) ->  (  h2 :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  h1 :   a ^  2 = a ) ->  (  h2 :   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  ) ^  2 =  x + y",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  x y : R ) ->  (  hx :   x * x = x ) ->  (  hy :   y * y = 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 ] ->  (  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",
    " (  A :  Type* ) ->  [  CommRing  A ] ->  {  e₁ e₂ : A } ->  (  h_e₁ :   e₁ * e₁ = e₁ ) ->  (  h_e₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " (  A :  Type* ) ->  [  CommRingₓ  A ] ->  {  e₁ e₂ : A } ->  (  h_e₁ :   e₁ * e₁ = e₁ ) ->  (  h_e₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " (  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 ] ->  {  a b : R } ->  (  h_idem :   a * a = a ) ->  (  h_idem' :   b * b = b ) ->  (  h_comm :   a * b =  b * a ) ->    a + b -  a * b =  0",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  {  a b : R } ->  (  h_idem :   a * a = a ) ->  (  h_idem' :   b * b = b ) ->  (  h_comm :   a * b =  b * a ) ->    a + b -  a * b =  0",
    " (  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",
    " (  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 * 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 ] ->  (  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"]},
  {"theorem":
   "∀ (n : ℕ),\n  1 < n → ∀ (p : Finset (Fin n)), Finset.card p = n → ∀ (q : Finset (Fin n)), Finset.card q = n → p ≠ q → Prime n",
   "some-correct": null,
   "round-trip":
   "If `n` is a prime, then `n` is the only set of size `n` that is closed under multiplication. ",
   "prompt": "The number of partitions of a finite set is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h1 :   1 < n ) ->  ∀  p   :  Finset   (   Fin  n  ) ,   p.card = n →  ∀  q   :  Finset   (   Fin  n  ) ,   q.card = n →   p ≠ q →  Prime  n",
    " (  n :  ℕ ) ->  (  h1 :   1 < n ) ->  ∀  p   :  Finset   (   Finₓ  n  ) ,   p.card = n →  ∀  q   :  Finset   (   Finₓ  n  ) ,   q.card = n →   p ≠ q →  Prime  n",
    " (  n :  ℕ ) ->  (  h :  n ≥  1 ) ->  (  n_prime :  ∀  m  ,    1 < m →   m ∣ n →  m = n ) ->  ∃    (   f :   Fin  n →  Fin  n ) ,  (   ∀  i   :  Fin  n ,   f  i ≠ i  )",
    " (  n :  ℕ ) ->  (  h :  n ≥  1 ) ->  (  n_prime :  ∀  m  ,    1 < m →   m ∣ n →  m = n ) ->  ∃    (   f :   Finₓ  n →  Finₓ  n ) ,  (   ∀  i   :  Finₓ  n ,   f  i ≠ i  )"]},
  {"theorem":
   "∀ (α : Type ?u.16089063) [inst : PartialOrder α], (∃ m, ∀ (a : α), a ≤ m) → ∃ u, ∀ (b : α), u ≤ b",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "If a poset has a maximal element, then it has a unique minimal element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type* ) ->  [  PartialOrder  α ] ->  (  h :  ∃     m  : α ,  ∀  a   : α ,  a ≤ m ) ->  ∃    (   u : α ) ,  ∀  b   : α ,  u ≤ b",
    " (  α :  Type* ) ->  [  PartialOrderₓ  α ] ->  (  h :  ∃     m  : α ,  ∀  a   : α ,  a ≤ m ) ->  ∃    (   u : α ) ,  ∀  b   : α ,  u ≤ b",
    " (  α :  Type  u ) ->  [  Preorder  α ] ->  (  hα :  ∃     x  : α ,  ∀  y   : α ,  x ≤ y ) ->  ∃!     y  : α ,  ∀  z   : α ,  y ≤ z",
    " (  α :  Type  u ) ->  [  Preorderₓ  α ] ->  (  hα :  ∃     x  : α ,  ∀  y   : α ,  x ≤ y ) ->  ∃!     y  : α ,  ∀  z   : α ,  y ≤ z",
    " (  X :  Type  u ) ->  [  PartialOrderₓ  X ] ->  (  a : X ) ->  (  h :  ∀  x   : X ,   a ≤ x →  x = a ) ->  IsGlb   {   x  |  a ≤ x } a",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hmax :  ∃     m  : P ,  ∀  p   : P ,  m ≤ p ) ->  ∃!     m  : P ,  ∃!     m  : P ,  ∀  p   : P ,  p ≤ m",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hmax :  ∃     m  : P ,  ∀  p   : P ,  m ≤ p ) ->  ∃!     m  : P ,  ∃!     m  : P ,  ∀  p   : P ,  p ≤ m",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  h :  ∃     y  : P ,  ∀  z   : P ,   z ≤ y →  z = y ) ->  ∃!     x  : P ,  ∀  y   : P ,  x ≤ y",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  h :  ∃     y  : P ,  ∀  z   : P ,   z ≤ y →  z = y ) ->  ∃!     x  : P ,  ∀  y   : P ,  x ≤ y",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hPmax :  ∃     a  : P ,  ∀  b   : P ,   a ≤ b →  a = b ) ->  ∃!     a  : P ,  ∀  b   : P ,  a ≤ b",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hPmax :  ∃     a  : P ,  ∀  b   : P ,   a ≤ b →  a = b ) ->  ∃!     a  : P ,  ∀  b   : P ,  a ≤ b",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  M : P ) ->  (  hM :  ∀  x  ,  x ≤ M ) ->  ∃!     p  : P ,  ∀  q  ,   q ≤ p →  q = p",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  M : P ) ->  (  hM :  ∀  x  ,  x ≤ M ) ->  ∃!     p  : P ,  ∀  q  ,   q ≤ p →  q = p",
    " (  P :  Type* ) ->  [  Preorder  P ] ->  (  max : P ) ->  (  max_unique :  ∀  p   : P ,  p ≤ max ) ->  ∃     min  : P ,  ∀  q   : P ,  min ≤ q",
    " (  P :  Type* ) ->  [  Preorderₓ  P ] ->  (  max : P ) ->  (  max_unique :  ∀  p   : P ,  p ≤ max ) ->  ∃     min  : P ,  ∀  q   : P ,  min ≤ q",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hm :  ∃    (   x : P ) ,  ∀  y   : P ,  x ≤ y ) ->  ∃!    (   x : P ) ,  ∀  y   : P ,  x ≤ y",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hm :  ∃    (   x : P ) ,  ∀  y   : P ,  x ≤ y ) ->  ∃!    (   x : P ) ,  ∀  y   : P ,  x ≤ y",
    " (  L :  Type* ) ->  [  PartialOrder  L ] ->  (  x : L ) ->  (  hx :  ∀  y   : L ,   x ≤ y →  x = y ) ->  ∃!     y  ,  ∀  z  ,  y ≤ z",
    " (  L :  Type* ) ->  [  PartialOrderₓ  L ] ->  (  x : L ) ->  (  hx :  ∀  y   : L ,   x ≤ y →  x = y ) ->  ∃!     y  ,  ∀  z  ,  y ≤ z",
    " (  X :  Type* ) ->  [ h :  PartialOrder  X ] ->  (  a : X ) ->  (  h_max :  ∀  x   : X ,   a ≤ x →  a = x ) ->  ∃!     b  : X ,  ∀  x   : X ,  b ≤ x",
    " (  X :  Type* ) ->  [ h :  PartialOrderₓ  X ] ->  (  a : X ) ->  (  h_max :  ∀  x   : X ,   a ≤ x →  a = x ) ->  ∃!     b  : X ,  ∀  x   : X ,  b ≤ x",
    " (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  H :  ∃     x  : X ,  ∀  y   : X ,  x ≤ y ) ->  (  H' :  ∃     x  : X ,  ∀  y   : X ,  y ≤ x ) ->  ∃     x  : X ,  ∀  y   : X ,   x ≤ y ∧  (    y ≤ x ↔  x = y  )",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  H :  ∃     x  : X ,  ∀  y   : X ,  x ≤ y ) ->  (  H' :  ∃     x  : X ,  ∀  y   : X ,  y ≤ x ) ->  ∃     x  : X ,  ∀  y   : X ,   x ≤ y ∧  (    y ≤ x ↔  x = y  )",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  [  Nonempty  P ] ->  (  hP :  ∃     m  ,  ∀  a   : P ,  a ≤ m ) ->  ∃     m  ,  ∀  a   : P ,  m ≤ a",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  [  Nonempty  P ] ->  (  hP :  ∃     m  ,  ∀  a   : P ,  a ≤ m ) ->  ∃     m  ,  ∀  a   : P ,  m ≤ a"]},
  {"theorem":
   "(R : Type ?u.21558813) →\n  [inst : Ringₓ R] →\n    {M : Type ?u.21558821} →\n      [inst_1 : AddCommGroupₓ M] →\n        [inst_2 : Module R M] →\n          (U : Type ?u.21559332) → [inst_3 : Fintype U] → (f : U → M) → LinearIndependent R f → CommRing R",
   "some-correct": null,
   "round-trip":
   " If `R` is a ring, `M` is an `R`-module, and `f : U → M` is a linear independent family, then `R` is a commutative ring. ",
   "prompt": "If a module over a ring is free, then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  Ringₓ  R ] ->  {  M :  Type* } ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  U :  Type* ) ->  [  Fintype  U ] ->  (  f :  U → M ) ->  (  hf :  LinearIndependent  R f ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  {  M :  Type* } ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  U :  Type* ) ->  [  Fintype  U ] ->  (  f :  U → M ) ->  (  hf :  LinearIndependent  R f ) ->  CommRingₓ  R"]},
  {"theorem":
   "(R : Type ?u.25409667) → [inst : Ringₓ R] → Group (Units R) → CommRing R",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 ] ->  (  hR :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hG :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hG :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hG :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hG :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hg :  Group   (   Units  R  ) ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hg :  Groupₓ   (   Units  R  ) ) ->  Commutative  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 :  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* ) ->  [  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 ] ->  (  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 ] ->  (  u :  Units  R ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  u :  Units  R ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  Commutative  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* ) ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R"]},
  {"theorem": "∀ (n : ℕ), n > 10 → ∃ m p, m > 0 ∧ Prime p ∧ n = m ^ 2 + p",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every natural number larger than `10` is the sum of a square and a prime.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃     m  p  :  ℕ ,   m >  0 ∧   Prime  p ∧  n =   m ^  2 + p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 + b ∣ n ∧  Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     a  b  :  ℕ ,    (    a ^  2 + b  ) = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃     p  m  ,  p.prime ∧   m ^  2 =  n - p",
    " (  n :  ℕ ) ->  (  hn :  n ≥  10 ) ->  ∃     a  b  :  ℕ ,     a ^  2 +  b ^  2 = n ∧  Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   x  y :  ℕ ) ,     x ^  2 +  y ^  2 = n ∧  Prime  y",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  q  :  ℕ ,     p ^  2 + q = n ∧  Prime  q",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  :  ℕ ,  ∃     a  b  ,     a * a +  b * b = n ∧  Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     x  y  :  ℕ ,     x * x +  y * y = n ∧  Prime  y",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃     x  y  :  ℕ ,   Prime  y ∧    x ^  2 + y = n",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃     x  :  ℕ ,    x ^  2 < n ∧  Prime   (   n -  x ^  2  )",
    " (  k :  ℕ ) ->  (  hk :  k ≥  10 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  ∃     n  :  ℕ ,    n ^  2 + p = k",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃     p  m  :  ℕ ,   m ∈  Finset.range  n ∧   Prime  p ∧    m ^  2 + p = n",
    " (  n :  ℕ ) ->  (  h :   10 < n ) ->  ∃    (   a  p :  ℕ ) ,   n =   a ^  2 + p ∧  Prime  p"]},
  {"theorem":
   "∀ (X : Type ?u.25494909) (Y : Type ?u.25494912) (Z : Type ?u.25494915) [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,
   "round-trip":
   "If the composition of two functions is continuous, then so are the functions. ",
   "prompt":
   "If the composition of two functions is continuous, then each of them is continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  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",
    " {  X :  Type* } ->  {  Y :  Type* } ->  {  Z :  Type* } ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  h_fg :  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  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  Y → Z ) ->  (  g :  X → Y ) ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  (  hcomp :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  Y Z :  Type* ) ->  [  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 ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->    Continuous  f ∧  Continuous  g →  Continuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " (  Y X :  Type* ) ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  X ] ->  (  f g :  Y → X ) ->  (  hfg :  Continuous   (   f ∘ g  ) ) ->   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 ) ->  (  h :  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 ∧  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 ) ->  (  hgf :  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"]},
  {"theorem":
   "∀ (G : Type ?u.26927815) [inst : Group G] (a b c : G), a * b = b * a → b * c = c * b → a * c = c * a",
   "some-correct": null,
   "round-trip": "The group axioms are symmetric. ",
   "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 ) ->  (  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 :   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 ) ->  (  h_comm_ab :   a * b =  b * a ) ->  (  h_comm_bc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h_comm_ab :   a * b =  b * a ) ->  (  h_comm_bc :   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 ) ->    a * b =  b * a →    b * c =  c * b →   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->    a * b =  b * a →    b * c =  c * b →   a * c =  c * a",
    " (  G :  Type* ) ->  [  Monoid  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Monoidₓ  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 ) ->    a * b =  b * a →    b * c =  c * b →   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  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 ) ->  (  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",
    " (  M :  Type* ) ->  [  Monoid  M ] ->  (  a b c : M ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  M :  Type* ) ->  [  Monoidₓ  M ] ->  (  a b c : M ) ->  (  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 :   a * b =  b * a ) ->  (  k :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  k :   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* ) ->  [  CommGroup  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 } ->  (  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 ) ->  (  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* ) ->  [  CommGroup  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  CommGroupₓ  G ] ->  (  a b c : G ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a"]},
  {"theorem":
   "∀ (R : Type ?u.28122501) (S : Type ?u.28122504) [inst : Ringₓ R] [inst_1 : Ringₓ S] (f : RingHom R S) (a : R),\n  RingHom.toFun f a = 0 → a = 0",
   "some-correct": null,
   "round-trip": "If `f` is a ring homomorphism and `f a = 0`, then `a = 0`. ",
   "prompt":
   "If an element maps to zero under a ring homomorphism, then it is zero.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R S :  Type* ) ->  [  Ringₓ  R ] ->  [  Ringₓ  S ] ->  (  f :  RingHom  R S ) ->  (  a : R ) ->    f  a =  0 →  a =  0",
    " (  R S :  Type* ) ->  [  Ringₓ  R ] ->  [  Ringₓ  S ] ->  (  h :  RingHom  R S ) ->  (  x : R ) ->  (  hx :   h  x =  0 ) ->  x =  0"]},
  {"theorem": "∀ (P Q : Prop), (P → Q) → Q → P",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 ) ->  P →  Q →  Q → P",
    " {  P :  Prop } ->  {  Q :  Prop } ->  (  h :  P → Q ) ->  Q → P",
    " (  P Q :  Prop ) ->  P →  Q → P",
    " (  P Q :  Prop ) ->   (   P → Q  ) ↔  (   Q → P  )",
    " (  P Q :  Prop ) ->  (  hpq :  P → Q ) ->  Q → P",
    " (  P Q :  Prop ) ->  (  h :  P → Q ) ->  Q → P",
    " {  p q :  Prop } ->  (  h :  p → q ) ->  q → p",
    " (  P Q :  Prop ) ->  (  H :  P → Q ) ->  Q → P",
    " (  P Q :  Prop ) ->  (  hPQ :  P → Q ) ->  Q → P"]},
  {"theorem": "∀ (n m : ℕ), n = m ↔ ∃ p h, n % p = 0 ∧ m % p = 0",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Two natural numbers are equal if and only if they are both divisible by some prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n m :  ℕ ) ->   n = m ↔  ∃     p  :  ℕ ,  ∃     h  :  Prime  p ,    n % p =  0 ∧   m % p =  0",
    " (  a b :  ℕ ) ->   a = b ↔  ∃     p  :  ℕ ,   Prime  p ∧    a % p =  0 ∧   b % p =  0",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ m ∧  p ∣ n",
    " (  a b :  ℕ ) ->  (  a0 :  a ≠  0 ) ->  (  b0 :  b ≠  0 ) ->   a = b ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ a ∧  p ∣ b",
    " (  a b :  ℕ ) ->   a = b ↔  ∃     p  :  ℕ ,   Nat.Prime  p ∧   p ∣ a ∧  p ∣ b",
    " (  m n :  ℕ ) ->   m = n ↔  ∃    (   p :  ℕ )  (   pp :  Prime  p ) ,   (   p ∣ m  ) ∧  (   p ∣ n  )",
    " (  a b :  ℕ ) ->   a = b →  (   ∃     p  :  ℕ ,   Prime  p ∧    a % p =  0 ∧   b % p =  0  )",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " (  x y :  ℕ ) ->   x = y ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ x ∧  p ∣ y",
    " (  m n :  ℕ ) ->   m = n ↔  ∃    (   p :  ℕ ) ,   Prime  p ∧   p ∣ m ∧  p ∣ n",
    " ∀  m n   :  ℕ ,   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧  (    p ∣ m ∧  p ∣ n  )",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧    m % p =  0 ∧   n % p =  0",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ m ∧  p ∣ n"]}],
 "elaborated": 24}