{"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 group is a torsion monoid.",
  "Every set has Lebesgue measure zero.",
  "Every set that is Lebesgue measurable but not Borel measurable has Lebesgue measure zero.",
  "A topological space $X$ is Hausdorff if and only if the diagonal map is an open map from $X$ to $X × X$.",
  "Any finite order element in a group is equal to the identity.",
  "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.",
  "The complement of the union of two sets contains the union of their complements.",
  "The square root of an rational number is rational.",
  "If a module over a ring is free, then the ring is commutative.",
  "The initial object of a category is isomorphic to its terminal object."],
 "elaborated-prompts":
 [{"theorem": "(R : Type ?u.12742) → [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 ] ->  (  h :  ∀   (  a  : A  )  (  ha  :  a ≠  0  )  ,  ∃     b  : A ,   b * a =  1 ) ->  IsField  A",
    " ∀   (  R  :  Type*  )  [   Ringₓ  R ]  ,  IsField  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  IsField  R ) ->  IsField  R",
    " (  α :  Type* ) ->  [  Ring  α ] ->  Field  α",
    " (  α :  Type* ) ->  [  Ringₓ  α ] ->  Field  α",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Field  R",
    " (  A :  Type* ) ->  [  Ring  A ] ->  Field  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  Field  A",
    " (  F :  Type* ) ->  [  Ring  F ] ->  Field  F",
    " (  F :  Type* ) ->  [  Ringₓ  F ] ->  Field  F",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  IsField  R"]},
  {"theorem":
   "∀ (n : ℕ) (G : Type ?u.858311) [inst : Groupₓ G],\n  Fintype G → IsSimpleGroup G → Fintype.card G = n → ∃ p, Prime p ∧ n = p",
   "some-correct": null,
   "round-trip": "If `G` is a simple group of order `n`, then `n` is a prime. ",
   "prompt": "Every finite simple group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG_fin :  Fintype  G ) ->  (  hG_simple :  IsSimpleGroup  G ) ->  (  hG_card :   Fintype.card  G = n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  n = p"]},
  {"theorem":
   "∀ (G : Type ?u.1006492) [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",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Fintype  G ) ->  IsSimpleGroup  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hGfin :  Fintype  G ) ->  IsSimpleGroup  G"]},
  {"theorem":
   "∀ (G : Type ?u.1295475) [inst : Group G], Fintype G → (∀ (x : G), x ≠ 1) → ∃ p, Prime p ∧ ∃ n, p ^ n = Fintype.card G",
   "some-correct": null,
   "round-trip":
   "If a group is finite and has no trivial elements, then its order is a prime power. ",
   "prompt": "Every finite group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  Fintype  G ) ->  (  hx :  ∀   (  x  : G  )  ,  x ≠  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  (   ∃     n  :  ℕ ,   p ^ n =  Fintype.card  G  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Fintype  G ) ->  (  hx :  ∀   (  x  : G  )  ,  x ≠  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  (   ∃     n  :  ℕ ,   p ^ n =  Fintype.card  G  )",
    " (  G :  Type* ) ->  [  Group  G ] ->  [  Fintype  G ] ->  ∀  x   : G ,   x ≠  1 →  ∃     p  ,   x ^ p =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∀  x   : G ,   x ≠  1 →  ∃     p  ,   x ^ p =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  Finite  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧  (   ∀  x   : G ,   x ≠  1 →   x =  1 →  p =  1  )",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Finite  G ) ->  ∃     p  :  ℕ ,   Prime  p ∧  (   ∀  x   : G ,   x ≠  1 →   x =  1 →  p =  1  )",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  Finset  G ) ->  (  h :  ∀  x y   : G ,   x * y =  y * x ) ->  ∃     n  :  ℕ ,   (   ∀  p   :  ℕ ,   Prime  p →   p ∣ n →  p =  2  ) ∧  ∀  k   :  ℕ ,   k ∣ n →   k =  1 ∨  k = n",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Finset  G ) ->  (  h :  ∀  x y   : G ,   x * y =  y * x ) ->  ∃     n  :  ℕ ,   (   ∀  p   :  ℕ ,   Prime  p →   p ∣ n →  p =  2  ) ∧  ∀  k   :  ℕ ,   k ∣ n →   k =  1 ∨  k = n",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  Fintype  G ) ->  (  hn :  Nat.Prime   (   Fintype.card  G  ) ) ->  ∃     x  : G ,  x ≠  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  Fintype  G ) ->  (  hn :  Nat.Prime   (   Fintype.card  G  ) ) ->  ∃     x  : G ,  x ≠  1"]},
  {"theorem":
   "∀ (X : Type ?u.1652061) [inst : TopologicalSpace X] [inst_1 : CompactSpace X] (A : Set X), IsCompact A",
   "some-correct": null,
   "round-trip": "**Compactness of a Set** ",
   "prompt": "If a topological space is compact, then every subset is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  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 :  IsCompact  X ) ->  (  A :  Set  X ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  (  A :  Set  X ) ->  IsCompact  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  cX :  IsCompact  X ) ->  (  T :  Set  X ) ->  IsCompact  T",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  (  A :  Set  X ) ->  IsCompact  A"]},
  {"theorem":
   "∀ (G : Type ?u.3381383) [inst : Group G] [inst_1 : Fintype G] (f : ℕ → G) (m : ℕ),\n  f m ≠ 1 → ∃ n, ∀ (i : ℕ), n ≤ i → f i = 1",
   "some-correct": null,
   "round-trip":
   "If `f` is a sequence of elements of a finite group, then it must eventually be the identity. ",
   "prompt":
   "A finitely-presented group containing a torsion element is finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  [  Fintype  G ] ->  (  f :  Π n :  ℕ , G ) ->  (  m :  ℕ ) ->  (  hm :   f  m ≠  1 ) ->  ∃     n  :  ℕ ,  ∀  i   :  ℕ ,   n ≤ i →   f  i =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  f :  Π n :  ℕ , G ) ->  (  m :  ℕ ) ->  (  hm :   f  m ≠  1 ) ->  ∃     n  :  ℕ ,  ∀  i   :  ℕ ,   n ≤ i →   f  i =  1"]},
  {"theorem":
   "∀ (X : Type ?u.3570271) [inst : TopologicalSpace X] (A : Set X),\n  (∀ (x : X), x ∈ A → ∃ U, IsClosed U ∧ x ∈ U) → IsClosed A",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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* ) ->  [ T :  TopologicalSpace  X ] ->  (  S :  Set  X ) ->  (  hS :  ∀  x  ∈ S ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  S",
    " (  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 ,  ∃     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 ] ->  (  Y :  Set  X ) ->  (  hY :  ∀  y  ∈ Y ,  ∃     C  :  Set  X ,   IsClosed  C ∧   y ∈ C ∧  C ⊆ Y ) ->  IsClosed  Y",
    " (  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 ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  h :  ∀  x  ,   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 ,  ∃     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"]},
  {"theorem":
   "∀ (G : Type ?u.10956469) [inst : Groupₓ G] (H : Set G), IsSubgroup H → (∀ (x : G), x ∈ H → x ≠ 1) → ∀ (x : G), x ≠ 1",
   "some-correct": null,
   "round-trip":
   "If `H` is a subgroup of `G` and `x` is not the identity of `G`, then `x` is not in `H`. ",
   "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 :  Set  G ) ->  (  IsSubgroup :  IsSubgroup  H ) ->  (  H_torsionfree :  ∀  x   : G ,   x ∈ H →  x ≠  1 ) ->  ∀  x   : G ,  x ≠  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Subgroup  G ) ->  (  H_free :  ∀  g  ,   g ∈ H →  g =  1 ) ->  ∀  g  ,  g =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  H_tor :  ∀  g   : G ,   g ∈ H →  g =  1 ) ->  (  HSub :  IsSubgroup  H ) ->  ∀  g   : G ,  g =  1"]},
  {"theorem":
   "∀ (G : Type ?u.12284277) [inst : Group G] (n : ℕ) (f : Fin n → G), Function.Injective f → ∀ (x : G), ∃ z, x = f z",
   "some-correct": null,
   "round-trip":
   " If `f` is injective, then every element of `G` is equal to `f z` for some `z`. ",
   "prompt":
   "Every injective homomorphism from a finitely generated free group to itself is surjective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  n :  ℕ ) ->  (  f :   Fin  n → G ) ->  (  hf :  Function.Injective  f ) ->  ∀  x   : G ,  ∃     z  :  Fin  n ,  x =  f  z",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  n :  ℕ ) ->  (  f :   Finₓ  n → G ) ->  (  hf :  Function.Injective  f ) ->  ∀  x   : G ,  ∃     z  :  Finₓ  n ,  x =  f  z",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  n :  ℕ ) ->  (  f :   Fin  n → G ) ->  (  hf :  Function.Injective  f ) ->  ∀  x   : G ,  ∃     z  :  Fin  n ,  x =  f  z",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  n :  ℕ ) ->  (  f :   Finₓ  n → G ) ->  (  hf :  Function.Injective  f ) ->  ∀  x   : G ,  ∃     z  :  Finₓ  n ,  x =  f  z"]},
  {"theorem":
   "∀ (D : Type ?u.12624477) [inst : DivisionRing D], IsField D ∨ Finite D",
   "some-correct": null,
   "round-trip": "A division ring is either a field or finite ",
   "prompt": "Every division ring is either a field or finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->   IsField  D ∨  Finite  D",
    " (  K :  Type* ) ->  [  DivisionRing  K ] ->   IsField  K ∨  ∃     n  ,  Finite  n",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->   Finite  D ∨  ∃    (   x : D ) ,   x ≠  0 ∧  x ≠  1",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->   Finite  D ∨  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->   IsField  D ∨  ¬  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->   Finite  D ∨  ∃     x  : D ,   x ≠  0 ∧  ∀  y   : D ,   y ≠  0 →  ∃!     z  : D ,   x * z = y"]},
  {"theorem": "∀ (n : ℕ), n ≠ 1 → ∃ p q, Prime p ∧ Prime q ∧ p ≠ q ∧ p * q = n",
   "some-correct": null,
   "round-trip":
   "If `n` is not 1, then it 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 :  ℕ ) ->  (  hn :  n ≠  1 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p ≠ q ∧   p * q = n",
    " (  n :  ℕ ) ->  (  hn :   0 < n ) ->  ∃     p  q  :  ℕ ,    p * q = n ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  (  hn :   1 < n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  (  h :  n ≠  0 ) ->  ∃     m  p  :  ℕ ,   m ≠  0 ∧   p ≠  0 ∧   n =  m * p ∧   Nat.Prime  m ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n ≠  0 ) ->  ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧  n =  a * b",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℤ ,   p * q = n",
    " (  n :  ℕ ) ->  (  h :  n ≠  0 ) ->  ∃     m  p  :  ℕ ,   m ≠  1 ∧   m ≠ p ∧   p ≠  1 ∧  n =  m * p",
    " (  n :  ℕ ) ->  (  h :   2 ≤ n ) ->  ∃     a  b  :  ℕ ,   a ≠  1 ∧   b ≠  1 ∧   a * b = n",
    " (  n :  ℕ ) ->  ∃     a  b  :  ℕ ,   (    (   a >  1  ) ∧  (   b >  1  )  ) ∧  ∀  d   :  ℕ ,    d ∣ a ∧  d ∣ b →   d =  1 ∨   d = a ∨  d = b",
    " (  n :  ℕ ) ->  (  h :  n ≠  1 ) ->  ∃     p  q  :  ℕ ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  (  hn :  n ≠  0 ) ->  ∃     m  p  :  ℕ ,   p ≠  1 ∧   p ≠ m ∧   m ≠  1 ∧   m * p = n",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃     p  q  ,   n =  p * q ∧   p ≠ q ∧   Prime  p ∧  Prime  q",
    " (  n :  ℕ ) ->  (  h :  n >  0 ) ->  ∃     x  y  :  ℕ ,   Prime  x ∧   Prime  y ∧  n =  x * y",
    " (  n :  ℕ ) ->  (  h2 :   2 ∣ n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p * q = n",
    " (  m :  ℕ ) ->  (  m_gt_1 :  m >  1 ) ->  ∃     m'  m''  ,   m' >  1 ∧   m'' >  1 ∧   Prime  m' ∧   Prime  m'' ∧  m =  m' * m''"]},
  {"theorem": "∀ (n : ℕ), Even n → ∃ m, n = m ^ 2",
   "some-correct": null,
   "round-trip": "Every even number is a square. ",
   "prompt": "Every even number is the square of a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->   Even  n →  ∃     m  :  ℕ ,  n =  m ^  2",
    " ∀  n   :  ℤ ,  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->   Even  n →  ∃     m  ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  h :   2 ∣ n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  (  h :  ∃    (   x :  ℕ ) ,   x ^  2 =   2 * n ) ->  ∃    (   x :  ℕ ) ,   x *  2 = n",
    " (  n :  ℕ ) ->    2 ∣ n →  ∃     m  :  ℕ ,  n =  m ^  2",
    " (  n :  ℕ ) ->  ∃     k  :  ℕ ,  n =  k * k",
    " (  n :  ℤ ) ->  (  h2 :   2 ∣ n ) ->  ∃     k  :  ℕ ,  n =  k ^  2",
    " (  n :  ℕ ) ->  (  h :   n %  2 =  0 ) ->  ∃     k  :  ℕ ,   k ^  2 = n",
    " (  n :  ℕ ) ->  (  h2 :   2 ∣ n ) ->  ∃     k  :  ℕ ,  n =  k ^  2",
    " (  n :  ℕ ) ->    (    2 * n   :  ℤ ) ^  2 =   4 *  n ^  2",
    " (  a :  ℕ ) ->  (  h :   a %  2 =  0 ) ->  ∃     b  :  ℕ ,  a =  b * b",
    " (  x :  ℤ ) ->  (  hx :   x %  2 =  0 ) ->  ∃     n  :  ℕ ,  x =  n ^  2",
    " (  n :  ℕ ) ->   Even  n →  ∃     m  :  ℕ ,  n =  m * m",
    " (  m :  ℕ ) ->  (  H :  ∃     n  ,  m =   2 * n ) ->  ∃     n  ,  m =  n ^  2"]},
  {"theorem":
   "∀ (X : Type ?u.18261926) [inst : TopologicalSpace X], (∀ (K : Set X), IsCompact K → IsClosed K) → CompactSpace X",
   "some-correct": null,
   "round-trip": "If every compact set is closed, then the space is compact. ",
   "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 :  ∀  C   :  Set  X ,   IsCompact  C →  IsClosed  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  H :  ∀  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 ] ->  (  hA :  ∀  A   :  Set  X ,   IsCompact  A →  IsClosed  A ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  K   :  Set  X ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h1 :  ∀  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 :  ∀  C   :  Set  X ,   IsCompact  C →  IsClosed  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  A   :  Set  X ,   IsCompact  A →  IsClosed  A ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  H :  ∀  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 ] ->  (  H :  ∀   (  K  :  Set  X  )  (  hK  :  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 ] ->  (  hX :  ∀  S   :  Set  X ,   IsCompact  S →  IsClosed  S ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀   (  K  :  Set  X  )  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X"]},
  {"theorem":
   "∀ (R : Type ?u.18866217) [inst : CommRing R] (e1 e2 : R), e1 ^ 2 = e1 → e2 ^ 2 = e2 → (e1 + e2) ^ 2 = e1 + e2",
   "some-correct": null,
   "round-trip":
   "If `e1` and `e2` are idempotent elements of a commutative ring, then `e1 + e2` is idempotent. ",
   "prompt":
   "In a commutative ring, the sum of idempotent elements is idempotent.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  CommRing  R ] ->  (  e1 e2 : R ) ->  (  he1 :   e1 ^  2 = e1 ) ->  (  he2 :   e2 ^  2 = e2 ) ->    (   e1 + e2  ) ^  2 =  e1 + e2",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  e1 e2 : R ) ->  (  he1 :   e1 ^  2 = e1 ) ->  (  he2 :   e2 ^  2 = e2 ) ->    (   e1 + e2  ) ^  2 =  e1 + e2",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  r s : R ) ->  (  hr :   r * r = r ) ->  (  hs :   s * s = s ) ->    (   r + s  ) *  (   r + s  ) =  r + s",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  r s : R ) ->  (  hr :   r * r = r ) ->  (  hs :   s * s = s ) ->    (   r + s  ) *  (   r + s  ) =  r + s",
    " (  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 ] ->  (  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* ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  hab :   a ^  2 = a ) ->  (  hba :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  hab :   a ^  2 = a ) ->  (  hba :   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 } ->  (  h_a_idem :   a * a = a ) ->  (  h_b_idem :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  {  a b : R } ->  (  h_a_idem :   a * a = a ) ->  (  h_b_idem :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " (  X :  Type* ) ->  [  CommRing  X ] ->  (  x y : X ) ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " (  X :  Type* ) ->  [  CommRingₓ  X ] ->  (  x y : X ) ->  (  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* ) ->  [  CommSemiring  R ] ->  {  a b : R } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommSemiringₓ  R ] ->  {  a b : R } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type  u ) ->  [  CommRing  R ] ->  (  a b : R ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type  u ) ->  [  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 ] ->  (  a b : R ) ->  (  h :   a ^  2 = a ) ->  (  h' :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  a b : R ) ->  (  h :   a ^  2 = a ) ->  (  h' :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  r s : R ) ->  (  hr :   r ^  2 = r ) ->  (  hs :   s ^  2 = s ) ->    (   r + s  ) ^  2 =  r + s",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  r s : R ) ->  (  hr :   r ^  2 = r ) ->  (  hs :   s ^  2 = s ) ->    (   r + s  ) ^  2 =  r + s",
    " (  A :  Type* ) ->  [  CommRing  A ] ->  (  a b : A ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " (  A :  Type* ) ->  [  CommRingₓ  A ] ->  (  a b : A ) ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  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* ) ->  [  CommRing  R ] ->  (  E :  Finset  R ) ->  (  hE :  ∀  x  ∈ E ,   x ^  2 = x ) ->  ∀   (  x  : R  )  ,   x ∈ E →   x =  0 ∨  x =  1",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  E :  Finset  R ) ->  (  hE :  ∀  x  ∈ E ,   x ^  2 = x ) ->  ∀   (  x  : R  )  ,   x ∈ E →   x =  0 ∨  x =  1"]},
  {"theorem":
   "∀ (n : ℕ), Prime (Fintype.card { f // Finset.card f = n }) → 2 ≤ n",
   "some-correct": null,
   "round-trip":
   "The cardinality of the set of subsets of a finite set of cardinality `n` is prime iff `n ≥ 2`. ",
   "prompt": "The number of partitions of a finite set is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  p :  Prime   (   Fintype.card   { f  :  Finset   (   Finₓ  n  ) //  f.card = n }  ) ) ->   2 ≤ n"]},
  {"theorem":
   "∀ (X : Type ?u.19354011) [inst : PartialOrder X] (f : X → Prop),\n  (∃ x, ∀ (y : X), f y → y ≤ x) → (∃ x, ∀ (y : X), f y → x ≤ y) → ∃ x, ∀ (y : X), f y → x = y",
   "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":
   [" (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  f :  X →  Prop ) ->  (  hf :  ∃     x  ,  ∀  y  ,   f  y →  y ≤ x ) ->  (  hf' :  ∃     x  ,  ∀  y  ,   f  y →  x ≤ y ) ->  ∃     x  ,  ∀  y  ,   f  y →  x = y",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  f :  X →  Prop ) ->  (  hf :  ∃     x  ,  ∀  y  ,   f  y →  y ≤ x ) ->  (  hf' :  ∃     x  ,  ∀  y  ,   f  y →  x ≤ y ) ->  ∃     x  ,  ∀  y  ,   f  y →  x = y",
    " (  L :  Type* ) ->  [  PartialOrder  L ] ->  (  hL_has_max :  ∃     l  : L ,  ∀  l'   : L ,   l' ≤ l →  l' = l ) ->  (  l l' : L ) ->  (  hll' :  l' ≤ l ) ->  l = l'",
    " (  L :  Type* ) ->  [  PartialOrderₓ  L ] ->  (  hL_has_max :  ∃     l  : L ,  ∀  l'   : L ,   l' ≤ l →  l' = l ) ->  (  l l' : L ) ->  (  hll' :  l' ≤ l ) ->  l = l'",
    " (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  h :  ∃     m  : X ,  ∀  x   : X ,  m ≤ x ) ->  ∃!     x  : X ,  ∀  y   : X ,  x ≤ y",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  h :  ∃     m  : X ,  ∀  x   : X ,  m ≤ x ) ->  ∃!     x  : X ,  ∀  y   : X ,  x ≤ y",
    " (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  mx : X ) ->  (  h :  ∀  x   : X ,  mx ≤ x ) ->  ∃     mn  : X ,  ∀  x   : X ,  mn ≤ x",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  mx : X ) ->  (  h :  ∀  x   : X ,  mx ≤ x ) ->  ∃     mn  : X ,  ∀  x   : X ,  mn ≤ x",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hMax :  ∃     x  : P ,  ∀  y   : P ,  y ≤ x ) ->  ∃!     x  : P ,  ∀  y   : P ,  x ≤ y",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hMax :  ∃     x  : P ,  ∀  y   : P ,  y ≤ x ) ->  ∃!     x  : P ,  ∀  y   : P ,  x ≤ y",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  m : P ) ->  (  H :  ∀  x   : P ,  x ≤ m ) ->  ∃     n  : P ,   n ≤ m ∧  ∀  x   : P ,   n ≤ x →  x = n",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  m : P ) ->  (  H :  ∀  x   : P ,  x ≤ m ) ->  ∃     n  : P ,   n ≤ m ∧  ∀  x   : P ,   n ≤ x →  x = n",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  hP_max :  ∃     a  : P ,  ∀  b   : P ,  b ≤ a ) ->  ∃     b  : P ,  ∀  c   : P ,   b ≤ c ∧  ∀  d   : P ,   c ≤ d →  c = d",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  hP_max :  ∃     a  : P ,  ∀  b   : P ,  b ≤ a ) ->  ∃     b  : P ,  ∀  c   : P ,   b ≤ c ∧  ∀  d   : P ,   c ≤ d →  c = d",
    " (  P :  Type* ) ->  [  Preorder  P ] ->  (  maximal :  ∃    (   x : P ) ,  ∀   (  y  : P  )  ,  x ≤ y ) ->  ∃!    (   x : P ) ,  ∀   (  y  : P  )  ,  y ≤ x",
    " (  P :  Type* ) ->  [  Preorderₓ  P ] ->  (  maximal :  ∃    (   x : P ) ,  ∀   (  y  : P  )  ,  x ≤ y ) ->  ∃!    (   x : P ) ,  ∀   (  y  : P  )  ,  y ≤ x",
    " (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  H :  ∃     m  : X ,  ∀  x   : X ,  m ≤ x ) ->  ∃!     m  : X ,  ∀  x   : X ,   m ≤ x ∧  ¬  (   x ≤ m  )",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  H :  ∃     m  : X ,  ∀  x   : X ,  m ≤ x ) ->  ∃!     m  : X ,  ∀  x   : X ,   m ≤ x ∧  ¬  (   x ≤ m  )",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  h :  ∃     x  : P ,  ∀  y   : P ,  x ≤ y ) ->  ∃!     x  : P ,  ∀  y   : P ,  y ≤ x",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  h :  ∃     x  : P ,  ∀  y   : P ,  x ≤ y ) ->  ∃!     x  : P ,  ∀  y   : P ,  y ≤ x",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  x : P ) ->  (  hx :  ∀   (  y  : P  )  ,   y ≤ x →  y = x ) ->  ∃!     y  ,  y ≤ x",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  x : P ) ->  (  hx :  ∀   (  y  : P  )  ,   y ≤ x →  y = x ) ->  ∃!     y  ,  y ≤ x"]},
  {"theorem":
   "∀ (f : { x // Membership.Mem x (Set.Icc 0 1) } → { x // Membership.Mem x (Set.Icc 0 1) }),\n  (∃ x, f x = x) → ∀ (n : ℕ), n ≥ 1 → n ≠ 1 → ∃ x, f (f x) = x",
   "some-correct": null,
   "round-trip":
   " If `f` is a function on `[0, 1]` with a fixed point, then it has a periodic point of period 2. ",
   "prompt":
   "If a function from the unit interval to itself has a fixed point, then it has points of all positive periods.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  f :   Set.Icc   0  1 →  Set.Icc   0  1 ) ->  (  h_fp :  ∃     x  ,   f  x = x ) ->  (  n :  ℕ ) ->  (  hn :  n ≥  1 ) ->  (  hn2 :  n ≠  1 ) ->  ∃     x  ,   f   (   f  x  ) = x"]},
  {"theorem":
   "(R : Type ?u.23719134) → [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 ] ->  (  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 ] ->  [  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_unit_group :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_unit_group :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_unit_group :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_unit_group :  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 ] ->  (  h_units :  Group   (   Units  R  ) ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_units :  Groupₓ   (   Units  R  ) ) ->  Commutative  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->  (  hR :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->  (  hR :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->  (  hR :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->  (  hR :  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 ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRingₓ  R"]},
  {"theorem": "∀ (n : ℕ), 10 < n → ∃ x p, x ^ 2 + p = n ∧ Prime p",
   "some-correct": null,
   "round-trip":
   "Every positive integer `n > 10` is the sum of a square and a prime. ",
   "prompt":
   "Every natural number larger than `10` is the sum of a square and a prime.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃     b  p  ,  p.prime ∧    b ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃     x  p  ,     x ^  2 + p = n ∧  Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   k  p :  ℕ )  (   hp :  Prime  p ) ,    k ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  ∃    (   x :  ℕ ) ,    x ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  Nonempty   (   ∃     a  b  :  ℕ ,     a ^  2 + b = n ∧  Prime  b  )",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  ∃     m  :  ℕ ,    m ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   p :  ℕ ) ,   Prime  p ∧  ∃    (   m :  ℕ ) ,    m ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     p  ,  ∃     m  :  ℕ ,   Prime  p ∧   n =   m ^  2 + p ∧  p >  10",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃     x  y  :  ℕ ,     x * x +  y * y = n ∧  Prime  y"]},
  {"theorem":
   "∀ (X : Type ?u.23774541) (Y : Type ?u.23774544) (Z : Type ?u.23774547) [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": "query for translation failed: index out of bounds: 0",
   "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 ) ->  (  h :  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 ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " (  X Y Z :  Type* ) ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  Y → Z ) ->  (  g :  X → Y ) ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  (  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 :  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",
    " (  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 ) ->  (  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 :  Y → Z ) ->  (  g :  X → Y ) ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  X Y Z :  Type* } ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  H :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " (  α β γ :  Type* ) ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  h :  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 ) ->  (  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 ) ->  (  h :  Continuous  f ) ->  (  h' :  Continuous  g ) ->  (  hfg :  ∀  x   : X ,  Continuous   (   λ   ( y : Y ) ,  g   (   f  y  )  ) ) ->  Continuous   (   λ x : X ,  g   (   f  x  )  )"]},
  {"theorem":
   "∀ (G : Type ?u.25158091) [inst : CommGroup G] (a b c : G), a * b = b * a → b * c = c * b → a * c = c * a",
   "some-correct": null,
   "round-trip":
   "If `a` and `b` commute, and `b` and `c` commute, then `a` and `c` commute. ",
   "prompt":
   "If `a` commutes with `b` and `b` commutes with `c` then `a` commutes with `c`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  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 ) ->  (  h1 :   a * b =  b * a ) ->  (  h2 :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h1 :   a * b =  b * a ) ->  (  h2 :   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* ) ->  [  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* ) ->  [  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",
    " (  α :  Type* ) ->  [  CommRing  α ] ->  (  a b c : α ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  α :  Type* ) ->  [  CommRingₓ  α ] ->  (  a b c : α ) ->  (  hab :   a * b =  b * a ) ->  (  hbc :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  x y z : G ) ->  (  hxy :   x * y =  y * x ) ->  (  hyz :   y * z =  z * y ) ->   x * z =  z * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  x y z : G ) ->  (  hxy :   x * y =  y * x ) ->  (  hyz :   y * z =  z * y ) ->   x * z =  z * x",
    " (  a b c :  ℤ ) ->  (  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 ) ->  (  hb :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  {  a b c : G } ->  (  h :   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 } ->  (  ha :   a * b =  b * a ) ->  (  hb :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  h :    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 ∧   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  h1 :   b * c =  c * b ) ->   a * c =  c * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  a b c : G ) ->  (  h :   a * b =  b * a ) ->  (  h1 :   b * c =  c * b ) ->   a * c =  c * a"]},
  {"theorem":
   "∀ (A : Type ?u.25941252) (B : Type ?u.25941255) [inst : Ringₓ A] [inst_1 : Ringₓ B] (h : RingHom A B) (x : A),\n  RingHom.toFun h x = 0 → x = 0",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "If an element maps to zero under a ring homomorphism, then it is zero.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  A B :  Type* ) ->  [  Ringₓ  A ] ->  [  Ringₓ  B ] ->  (  h :  RingHom  A B ) ->  (  x : A ) ->    h  x =  0 →  x =  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 Q :  Prop ) ->  (  h :  P → Q ) ->  Q → P",
    " (  P Q :  Prop ) ->  P →  Q → P",
    " (  p q :  Prop ) ->   (   p → q  ) →  (   q → p  )",
    " {  P Q :  Prop } ->  (  h :  P → Q ) ->  Q → P",
    " (  P Q :  Prop ) ->  (  HPQ :  P → Q ) ->  Q → P",
    " (  P :  Prop ) ->  (  Q :  Prop ) ->   (   P → Q  ) →  (   Q → P  )"]},
  {"theorem": "∀ (m n : ℕ), m = n ↔ ∃ p, ∀ (d : ℕ), d ∣ p → d ∣ m ∧ d ∣ n",
   "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":
   [" (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,  ∀   (  d  :  ℕ  )  ,   d ∣ p →   d ∣ m ∧  d ∣ n",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧   m % p =  n % p",
    " (  a b :  ℕ ) ->  (  h' :  ∃     p  :  ℕ ,   Prime  p ∧    a % p =  0 ∧   b % p =  0 ) ->  a = b",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  :  ℕ ,   Prime  p ∧   p ∣ m ∧  p ∣ n",
    " (  n m :  ℕ ) ->   n = m ↔  ∃     p  ,   Prime  p ∧   p ∣ n ∧  p ∣ m",
    " (  x y :  ℕ ) ->   x = y ↔  ∃     p  :  ℕ ,   Nat.Prime  p ∧    x % p =  0 ∧   y % p =  0",
    " {  p :   ℕ →  Prop } ->  (  a b :  ℕ ) ->  (  h :  ∃     n  :  ℕ ,   Prime  n ∧    a % n =  0 ∧   b % n =  0 ) ->  a = b",
    " (  m n :  ℕ ) ->   m = n ↔  ∃     p  ,   Prime  p ∧   p ∣ m ∧  p ∣ n"]}],
 "elaborated": 24}