{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 20,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["Every set that is Lebesgue measurable but not Borel measurable has Lebesgue measure zero.",
  "If a subgroup of a group is torsion-free, then the group itself is torsion free.",
  "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.",
  "The number of partitions of a finite set is a prime number.",
  "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.",
  "The initial object of a category is isomorphic to its terminal object."],
 "elaborated-prompts":
 [{"theorem": "{α : Type u} → [inst : Ring α] → Field α",
   "some-correct": null,
   "round-trip": "Any ring can be endowed a field structure. ",
   "prompt": "Every ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ring  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  IsField  α",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  IsField  R",
    " {  A :  Type  u } ->  [  Ringₓ  A ] ->  IsField  A"]},
  {"theorem":
   "∀ (K : Type u) [inst : DivisionRing K] (V : Type v) [inst_1 : AddCommGroupₓ V] [inst_2 : Module K V],\n  FiniteDimensional K V",
   "some-correct": null,
   "round-trip": " A `Module` over a `DivisionRing` is finite-dimensional. ",
   "prompt": "Every vector space is finite dimensional.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->  (  V :  Type  v ) ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V",
    " (  k :  Type  u_1 ) ->  {  V :  Type  u_2 } ->  [  DivisionRing  k ] ->  [  AddCommGroupₓ  V ] ->  [  Module  k V ] ->  FiniteDimensional  k V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Nontrivial  K ] ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  {  n :  ℕ } ->  FiniteDimensional  K V",
    " {  k :  Type  u_1 } ->  {  V :  Type  u_2 } ->  [  DivisionRing  k ] ->  [  AddCommGroupₓ  V ] ->  [  Module  k V ] ->  FiniteDimensional  k V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Field  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DecidableEq  K ] ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  u_1 } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V"]},
  {"theorem": "∀ {G : Type u_1} [inst : CommGroupₓ G], Monoidₓ.IsTorsion G",
   "some-correct": null,
   "round-trip": "A commutative group is torsion. ",
   "prompt": "Every group is a torsion monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  CommGroupₓ  G ] ->  Monoidₓ.IsTorsion  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G",
    " (  G :  Type  u_1 ) ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] [inst_1 : Fintype G], IsSimpleGroup G → ∃ p, Fact (Nat.Prime p) ∧ Fintype.card G = p",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every finite simple group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hsimple :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  [  IsSimpleGroup  G ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  ,  ∃     h  :  Fact   (   Nat.Prime  p  ) ,   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   (   Fact   (   Nat.Prime  p  )  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  s :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   (   Fact   (   Nat.Prime  p  )  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hG :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  [  IsSimpleGroup  G ] ->  Prime   (   Fintype.card  G  )",
    " {  G :  Type  u } ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  hsimple :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hs :  IsSimpleGroup  G ) ->  ∃     p  ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] [inst_1 : Fintype G], IsSimpleGroup G",
   "some-correct": null,
   "round-trip":
   " A group is simple if and only if it is nontrivial and has no nontrivial normal subgroups. ",
   "prompt": "Every finite group is simple.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  [  DecidableEq  G ] ->  IsSimpleGroup  G",
    " (  G :  Type  u_1 ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  G :  Type* } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  Groupₓ  α ] ->  IsSimpleGroup  α"]},
  {"theorem":
   "∀ {G : Type u} [inst : Group G] [inst : Fintype G], ∃ p, Fact (Nat.Prime p) ∧ Fintype.card G = p",
   "some-correct": null,
   "round-trip":
   " Every finite group is isomorphic to a group of prime order. ",
   "prompt": "Every finite group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  [  Fintype  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ )  (   hp :  Fact   (   Nat.Prime  p  ) ) ,   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ )  (   hp :  Fact   (   Nat.Prime  p  ) ) ,   Fintype.card  G = p",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧  (    Fintype.card  G = p  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧  (    Fintype.card  G = p  )",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " (  G :  Type  u ) ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧  p ∣  Fintype.card  G",
    " (  G :  Type  u ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧  p ∣  Fintype.card  G",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧  p ∣  Fintype.card  G",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧  p ∣  Fintype.card  G",
    " {  G :  Type  } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ )  (   h :  Fact   (   Nat.Prime  p  ) ) ,   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ )  (   h :  Fact   (   Nat.Prime  p  ) ) ,   Fintype.card  G = p",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,  (    Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p  )",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,  (    Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p  )",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃     p  ,    Fintype.card  α = p ∧  (   Fact   (   Nat.Prime  p  )  )",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃     p  ,    Fintype.card  α = p ∧  (   Fact   (   Nat.Prime  p  )  )"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : MeasurableSpace α] [inst : MeasureTheory.MeasureSpace α] (s : Set α),\n  coeFn MeasureTheory.volume.toOuterMeasure s = 0",
   "some-correct": null,
   "round-trip": "**Volume of a Set** ",
   "prompt": "Every set has Lebesgue measure zero.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type* } ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    "  MeasureTheory.MeasureSpace.volume   ∅ =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  [  MeasureTheory.MeasureSpace  α ] ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  ∀   (  U  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  U =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  {  A :  Set  α } ->   MeasureTheory.MeasureSpace.volume  A =  0",
    " {  α :  Type  u } ->  ∀  s   :  Set  α ,  s =  ∅",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] [inst_1 : CompactSpace α] (s : Set α), IsCompact s",
   "some-correct": null,
   "round-trip": " Every subset of a compact space is compact. ",
   "prompt": "If a topological space is compact, then every subset is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  (  s :  Set  α ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  IsCompact  α ) ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  ∀  s   :  Set  α ,  IsCompact  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  IsCompact  α ) ->  (  s :  Set  α ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  IsCompact  α ) ->  ∀   (  t  :  Set  α  )  ,  IsCompact  t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  IsCompact  α ) ->  (  s :  Set  α ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  (  S :  Set  α ) ->  IsCompact  S",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  IsCompact  α ) ->  {  s :  Set  α } ->  IsCompact  s"]},
  {"theorem":
   "∀ {G : Type u_3} [inst : Groupₓ G] [inst_1 : Fintype G], (∃ x, x ^ 2 = 1) → Monoidₓ.IsTorsionFree G",
   "some-correct": null,
   "round-trip":
   "A finite group is torsion-free if and only if it has no elements of order 2. ",
   "prompt":
   "A finitely-presented group containing a torsion element is finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_3 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->   (   ∃     x  : G ,   x ^  2 =  1  ) →  Monoidₓ.IsTorsionFree  G"]},
  {"theorem":
   "∀ {α : Type u} [t : TopologicalSpace α] {s : Set α}, (∀ (y : α), y ∈ s → ∃ t_1, IsClosed t_1 ∧ y ∈ t_1) → IsClosed s",
   "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":
   [" {  α :  Type  u } ->  [ t :  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  y  : α  )  ,   y ∈ s →  ∃     t  :  Set  α ,   IsClosed  t ∧  y ∈ t ) ->  IsClosed  s",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  hs :  ∀  x  ,   x ∈ s →  ∃     a  ,   IsClosed  a ∧  x ∈ a ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ t ,  ∃     U  :  Set  α ,   IsClosed  U ∧  x ∈ U ) ->  (  Sub :  s ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     V  ,   IsClosed  V ∧   x ∈ V ∧  V ⊆ t ) ->  (  ht :  IsClosed  t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  t ⊆ s ) ->  (  ht :  ∀  x  ,   x ∈ s →  ∃     u  ,  u.is_closed ∧   x ∈ u ∧  u ⊆ t ) ->  IsClosed  t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s U :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   V :  Set  α ) ,   IsClosed  V ∧   x ∈ V ∧  V ⊆ U ) ->  IsClosed  s",
    " {  X :  Type  u_1 } ->  {  s :  Set  X } ->  [  TopologicalSpace  X ] ->  (  h :  ∀  x  ∈ s ,  ∃     C  :  Set  X ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  s",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s t :  Set  X } ->  (  closed_points :  ∀  x  ∈ t ,  ∃     U  ,   IsClosed  U ∧  x ∈ U ) ->  (  Subset :  s ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     V  :  Set  α ,   IsClosed  V ∧   x ∈ V ∧  V ⊆ t ) ->  (  ht :  IsClosed  t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  :  Set  α ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  {  t :  Set   (   Set  α  ) } ->  (  h :  ∀  x  ∈ s ,  ∃  y  ∈ t ,   x ∈ y ∧  IsClosed  y ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  a  : α  )  ,   a ∈ s →  ∃    (   t :  Set  α ) ,   IsClosed  t ∧  a ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃    (   t :  Set  α ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α], DiscreteTopology α ↔ IsOpenMap fun x => (x, x)",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->   DiscreteTopology  α ↔  IsOpenMap   (   λ x : α ,  (  x   ,  x )  )"]},
  {"theorem":
   "∀ {G : Type u} [inst : Groupₓ G] {x : G}, IsOfFinOrder x → x = 1",
   "some-correct": null,
   "round-trip":
   "If an element of a group is of finite order, then it is the identity. ",
   "prompt": "Any finite order element in a group is equal to the identity.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->  (  hx :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  h :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  ∀   (  g  : G  )  ,   IsOfFinOrder  g →  g =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  g : G ) ->  (  hg :  IsOfFinOrder  g ) ->  g =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u' } ->  [  Groupₓ  G ] ->  {  x : G } ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u } ->  [  CommGroupₓ  G ] ->  (  x : G ) ->  (  hx :  IsOfFinOrder  x ) ->  x =  1"]},
  {"theorem":
   "∀ {α : Type u} [inst : Fintype α] {f : FreeGroup α → FreeGroup α},\n  IsGroupHom f → Function.Injective f → Function.Surjective f",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every injective homomorphism from a finitely generated free group to itself is surjective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  } ->  [  Group  α ] ->  [  Fintype  α ] ->  (  inj :  Function.Injective   (    @ FreeGroup.of  α  _  ) ) ->  Function.Surjective   (    @ FreeGroup.of  α  _  )",
    " {  α :  Type  } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  inj :  Function.Injective   (    @ FreeGroup.of  α  _  ) ) ->  Function.Surjective   (    @ FreeGroup.of  α  _  )",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  {  f :   FreeGroup  α →  FreeGroup  α } ->  (  H :  IsGroupHom  f ) ->  (  Hinj :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Fintype  α ] ->  [  DecidableEq  β ] ->  [  Groupₓ  β ] ->  {  f :   FreeGroup  α → β } ->  (  h :  Function.Injective  f ) ->  (  hf :  IsGroupHom  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Groupₓ  α ] ->  [  Groupₓ  β ] ->  {  f :  α → β } ->  (  h :  IsGroupHom  f ) ->  (  hf :  Function.Injective  f ) ->  (  H :  Fintype  α ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  [ ι :  DecidableEq  α ] ->  {  f :   FreeGroup  α →  FreeGroup  α } ->  (  hf :  IsGroupHom  f ) ->  (  hfi :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  f :   FreeGroup  α →  FreeGroup  β } ->  [  DecidableEq  α ] ->  [  DecidableEq  β ] ->  (  hf :  IsGroupHom  f ) ->  (  hgens :  ∀  a   : α ,   f   (   FreeGroup.of  a  ) ≠  1 ) ->  (  h :  Function.Injective  f ) ->  Function.Surjective  f"]},
  {"theorem": "∀ (K : Type u) [inst : DivisionRing K], IsField K ∨ Finite K",
   "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":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->   IsField  K ∨  Finite  K"]},
  {"theorem": "∀ (n : ℕ), 0 < n → ∃ p q, Nat.Prime p ∧ Nat.Prime q ∧ n = p * q",
   "some-correct": null,
   "round-trip":
   "Every natural number greater than zero can be written as a product of two primes. ",
   "prompt": "Every natural number is the product of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃     m  p  :  ℕ ,   Nat.Prime  m ∧   Nat.Prime  p ∧  n =  m * p",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃     m  p  :  ℕ ,   Nat.Prime  m ∧   Nat.Prime  p ∧   m * p = n",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   n =  p * q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,    p * q = n ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p  q :  ℕ ) ,   n =  p * q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  ∃    (   p  p' :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  p' ∧  n =  p * p'",
    " (  n :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a * b",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,  n =  p * q"]},
  {"theorem": "∀ {n : ℕ}, Even n → ∃ k, n = k ^ 2",
   "some-correct": null,
   "round-trip":
   "If `n` is even, then there exists a natural number `k` such that `n = k^2`. ",
   "prompt": "Every even number is the square of a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  hn :  Even  n ) ->  ∃    (   k :  ℕ ) ,  n =  k ^  2",
    " {  m :  ℕ } ->   Even  m →  ∃    (   n :  ℕ ) ,  m =  n ^  2",
    " {  m :  ℕ } ->  (  h :  Even  m ) ->  ∃    (   n :  ℕ ) ,   n ^  2 = m",
    " {  m :  ℕ } ->   Even  m →  ∃    (   n :  ℕ ) ,  m =  n ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   (   m ^  2   :  ℕ ) = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   i :  ℕ ) ,  n =  i * i",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃     k  ,  n =  k ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->   Even  n →  ∃    (   a :  ℕ ) ,  ∃    (   b :  ℕ ) ,  n =  a ^ b",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   a :  ℕ ) ,   a ^  2 = n",
    " {  n :  ℕ } ->   Even  n →  ∃    (   k :  ℕ ) ,   k ^  2 = n",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m * m",
    " {  n :  ℕ } ->  (  hn :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->    n %  2 =  0 →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  hn :  Even  n ) ->  ∃     m  :  ℕ ,  n =  m ^  2"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} [inst : UniformSpace α] [inst_1 : UniformSpace β] {f : α → β},\n  Continuous f → UniformContinuous f",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  SeparatedSpace  α ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} [inst : UniformSpace α] [inst_1 : UniformSpace β] (f : α → β)\n  (hf : UniformContinuous f), BddAbove (?m.5688658 f hf)",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every uniformly continuous function is bounded above.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  hf :  UniformContinuous  f ) ->  BddAbove  f"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α},\n  (∀ (K : Set α), IsCompact K → IsClosed K) → IsCompact s → IsClosed s",
   "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":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hc :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  K  :  Set  α  )  ,   IsCompact  K →  IsClosed  K ) ->   IsCompact  s →  IsClosed  s",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :  ∀  s   :  Set  X ,   IsCompact  s →  IsClosed  s ) ->   IsCompact  s →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  S  :  Set  α  )  ,   IsCompact  S →  IsClosed  S ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  T2Space  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  k  :  Set  α  )  ,   IsCompact  k →  IsClosed  k ) ->   IsCompact  s ↔  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hk :  ∀   (  S  :  Set  α  )  ,   IsCompact  S →  IsClosed  S ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  T2Space  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  T2Space  α ] ->   (   ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s  ) →  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  K  :  Set  α  )  ,   IsCompact  K →  IsClosed  K ) ->   IsCompact  s →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h_s :  ∀   (  x  :  Set  α  )  ,   IsCompact  x →  IsClosed  x ) ->   IsCompact  s ↔  (   ∀   (  U  :  Set  α  )  ,   IsOpen  U →   s ⊆ U →  (   ∃    (   K :  Set  α ) ,   IsCompact  K ∧   K ⊆ s ∧  K ⊆ U  )  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  ∀   {  s  :  Set  α }  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : CommRing α] {a b : α}, a * a = a → b * b = b → (a + b) * (a + b) = a + b",
   "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":
   [" {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  R :  Type  u } ->  [  CommRing  R ] ->  {  a b : R } ->  (  h1 :   a * a = a ) ->  (  h2 :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  a b : R } ->  (  h1 :   a * a = a ) ->  (  h2 :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  {  a b : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  R :  Type  u_1 } ->  [  CommRing  R ] ->  {  e₁ e₂ : R } ->  (  h₁ :   e₁ * e₁ = e₁ ) ->  (  h₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " {  R :  Type  u_1 } ->  [  CommRingₓ  R ] ->  {  e₁ e₂ : R } ->  (  h₁ :   e₁ * e₁ = e₁ ) ->  (  h₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  h1 :   a ^  2 = a ) ->  (  h2 :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h1 :   a ^  2 = a ) ->  (  h2 :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  e₁ e₂ : α ) ->  (  h₁ :   e₁ * e₁ = e₁ ) ->  (  h₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  e₁ e₂ : α ) ->  (  h₁ :   e₁ * e₁ = e₁ ) ->  (  h₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  {  a b : α } ->  (  h₁ :   a + a = a ) ->  (  h₂ :   b + b = b ) ->     a + b + a + b =  a + b",
    " {  α :  Type  u_1 } ->  [  CommRing  α ] ->  {  a b : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    a + b -  a * b =   (   a + b  ) ^  2",
    " {  α :  Type  u_1 } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    a + b -  a * b =   (   a + b  ) ^  2",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  h₁ :   a * a = a ) ->  (  h₂ :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h₁ :   a * a = a ) ->  (  h₂ :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommSemiring  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommSemiringₓ  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  R :  Type  u } ->  [  CommRing  R ] ->  {  a b : R } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  a b : R } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b"]},
  {"theorem":
   "∀ {α : Type ?u.7594696} [inst : PartialOrder α], (∃ m, ∀ (a : α), m ≤ a) → ExistsUnique fun a => ∀ (b : α), a ≤ b",
   "some-correct": null,
   "round-trip":
   " If `α` is a partial order with a least element, then there exists a unique maximal element. ",
   "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  : α  )  ,  m ≤ a ) ->  ∃!    (   a : α ) ,  ∀   (  b  : α  )  ,  a ≤ b",
    " {  α :  Type* } ->  [  PartialOrderₓ  α ] ->  (  h :  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,  m ≤ a ) ->  ∃!    (   a : α ) ,  ∀   (  b  : α  )  ,  a ≤ b",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  [  NoBotOrder  α ] ->  {  a b : α } ->   a ≤ b →   b ≤ a →  a = b",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  [  NoBotOrder  α ] ->  {  a b : α } ->   a ≤ b →   b ≤ a →  a = b",
    " {  α :  Type  u_1 } ->  [  LinearOrder  α ] ->  (  h :  ∃    (   a : α ) ,  ∀   (  b  : α  )  ,  b ≤ a ) ->  ∃!    (   a : α ) ,  ∀   (  b  : α  )  ,  a ≤ b",
    " {  α :  Type  u_1 } ->  [  LinearOrderₓ  α ] ->  (  h :  ∃    (   a : α ) ,  ∀   (  b  : α  )  ,  b ≤ a ) ->  ∃!    (   a : α ) ,  ∀   (  b  : α  )  ,  a ≤ b",
    " {  α :  Type* } ->  [  PartialOrderₓ  α ] ->  [  Nonempty  α ] ->  [  NoMinOrder  α ] ->  [  NoMaxOrder  α ] ->  ∃    (   f :   ℤ → α ) ,  StrictMono  f"]},
  {"theorem":
   "∀ {f : ℕ → ℕ}, Function.IsFixedPt f 0 → ∀ (n : ℕ), 0 < n → ∃ x, Function.IsPeriodicPt f n x",
   "some-correct": null,
   "round-trip":
   "If `f` has a fixed point at `0`, then it has a periodic point of any prescribed period `n > 0`. ",
   "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 :   ℕ →  ℕ } ->  (  hf :  Function.IsFixedPt  f  0 ) ->  (  n :  ℕ ) ->  (  hn :   0 < n ) ->  ∃     x  :  ℕ ,  Function.IsPeriodicPt  f n x"]},
  {"theorem":
   "{K : Type u} →\n  {V : Type v} →\n    [inst : Ringₓ K] → [inst_1 : AddCommGroupₓ V] → [inst_2 : Module K V] → [inst : Module.Free K V] → CommRing K",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "If a module over a ring is free, then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Module.Free  K V ] ->  CommRing  K",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Module.Free  K V ] ->  CommRingₓ  K",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  StrongRankCondition  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  StrongRankCondition  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRingₓ  R",
    " {  ι :  Type  u_1 } ->  {  K :  Type  u_2 } ->  (  V :  Type  u_3 ) ->  [  Unique  ι ] ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Module.Free  K V ] ->  CommRing  K",
    " {  ι :  Type  u_1 } ->  {  K :  Type  u_2 } ->  (  V :  Type  u_3 ) ->  [  Unique  ι ] ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Module.Free  K V ] ->  CommRingₓ  K",
    " {  R :  Type  u } ->  {  M :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRingₓ  R",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  M :  Type  v } ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRing  R",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  M :  Type  v } ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRingₓ  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  m :  Module.Free  R M ) ->  CommRing  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  m :  Module.Free  R M ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →   @ CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →   @ CommRingₓ  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRing  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRingₓ  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRingₓ  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRing  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRingₓ  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  {  ι :  Type  w } ->  [  Unique  ι ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  b :  Basis  ι R M ) ->  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  {  ι :  Type  w } ->  [  Unique  ι ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  b :  Basis  ι R M ) ->  CommRingₓ  R",
    " {  R :  Type* } ->  {  M :  Type* } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRing  R",
    " {  R :  Type* } ->  {  M :  Type* } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRingₓ  R",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->   Module.Free  K V →  CommRing  K",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->   Module.Free  K V →  CommRingₓ  K",
    " {  α :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  α ] ->  [  AddCommGroupₓ  M ] ->  [  Module  α M ] ->   Module.Free  α M →  CommRing  α",
    " {  α :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  α ] ->  [  AddCommGroupₓ  M ] ->  [  Module  α M ] ->   Module.Free  α M →  CommRingₓ  α",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRing  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRingₓ  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRingₓ  R"]},
  {"theorem":
   "{R : Type u} → [inst : Ringₓ R] → [inst_1 : AddCommGroup (Units R)] → [inst : MulOneClass (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  u } ->  [  Ringₓ  R ] ->  [  AddCommGroup   (   Units  R  ) ] ->  [  MulOneClass   (   Units  R  ) ] ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroup   (   Units  R  ) ] ->  [  MulOneClass   (   Units  R  ) ] ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroup   (   Units  R  ) ] ->  [  MulOneClassₓ   (   Units  R  ) ] ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroup   (   Units  R  ) ] ->  [  MulOneClassₓ   (   Units  R  ) ] ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ   (   Units  R  ) ] ->  [  MulOneClass   (   Units  R  ) ] ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ   (   Units  R  ) ] ->  [  MulOneClass   (   Units  R  ) ] ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ   (   Units  R  ) ] ->  [  MulOneClassₓ   (   Units  R  ) ] ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ   (   Units  R  ) ] ->  [  MulOneClassₓ   (   Units  R  ) ] ->  CommRingₓ  R",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Group   (   Units  α  ) ] ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Group   (   Units  α  ) ] ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Groupₓ   (   Units  α  ) ] ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Groupₓ   (   Units  α  ) ] ->  CommRingₓ  α",
    " {  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":
   "∀ {p : ℕ}, p > 10 → ∃ a b, a ≠ 0 ∧ b ≠ 0 ∧ a * a + b = p ∧ Nat.Prime b",
   "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":
   [" {  p :  ℕ } ->  (  h :  p >  10 ) ->  ∃    (   a  b :  ℕ ) ,   a ≠  0 ∧   b ≠  0 ∧     a * a + b = p ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hpos :   10 < n ) ->  ∃    (   a  b :  ℕ ) ,   n =   a ^  2 + b ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  p :  ℕ ) ,   Nat.Prime  p ∧    a ^  2 + p = n",
    " {  n :  ℕ } ->  (  h :   10 < n ) ->  ∃    (   a  p :  ℕ ) ,    p %  2 =  1 ∧   Nat.Prime  p ∧    a * a + p = n",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a * a + b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :   10 < n ) ->  ∃    (   a  b :  ℕ ) ,     a * a +  b * b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :   10 < n ) ->  ∃    (   p  a  b :  ℕ ) ,   Nat.Prime  p ∧     a * a + p = n ∧    b * b + p = n",
    " (  n :  ℕ ) ->    10 < n →  ∃    (   a  p :  ℕ ) ,     a * a + p = n ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃    (   a :  ℕ ) ,  ∃    (   p :  ℕ ) ,   p > a ∧    a ^  2 + p = n",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃    (   a  b :  ℕ ) ,     a * a + b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃     p  :  ℕ ,  ∃     a  :  ℕ ,     a ^  2 + p = n ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  hn :   10 < n ) ->  ∃    (   a  p :  ℕ ) ,   Nat.Prime  p ∧   p ≤ n ∧  n =   a ^  2 + p",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   n =   a * a + b ∧  Nat.Prime  b",
    " ∀   (  n  :  ℕ  )  ,    10 < n →  ∃    (   a  p :  ℕ ) ,   Nat.Prime  p ∧   p >  10 ∧  n =   a * a + p",
    " {  a :  ℕ } ->    10 < a ↔  ∃    (   b :  ℕ )  (   c :  ℕ ) ,   a =   b ^  2 + c ∧  Nat.Prime  c"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} {γ : Type u_3} [inst : TopologicalSpace α] [inst_1 : TopologicalSpace β]\n  [inst_2 : TopologicalSpace γ] {g : α → β} {f : β → γ}, Continuous (f ∘ g) → 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":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  α → β } ->  {  f :  β → γ } ->  (  fg :  Continuous   (   f ∘ g  ) ) ->  Continuous  g",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  h :  Continuous   (   f ∘ g  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->   Continuous   (   g ∘ f  ) →   Continuous  g ∧  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  h :  Continuous   (   f ∘ g  ) ) ->   Continuous  g ∧  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   f ∘ g  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  Continuous   (   g ∘ f  ) ) ->  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  h :  Continuous   (   Function.comp  f g  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  α → β } ->  (  h :  Continuous   (   Function.comp  g f  ) ) ->   Continuous  g ∧  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  β → γ } ->  {  f :  α → β } ->  (  h :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  H :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  c :  Continuous   (   g ∘ f  ) ) ->   Continuous  g ∧  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  β → γ ) ->  (  g :  α → β ) ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type* } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  α → β } ->  {  f :  β → γ } ->  (  hgf :  Continuous   (   g ∘ f  ) ) ->  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  {  f :  β → α } ->  {  g :  γ → α } ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  g ∧  Continuous  f"]},
  {"theorem":
   "∀ {S : Type u_1} [inst : Semigroup S] {a b c : S}, Commute a b → Commute b c → Commute a c",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "If `a` commutes with `b` and `b` commutes with `c` then `a` commutes with `c`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  S :  Type  u_1 } ->  [  Semigroup  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommSemigroup  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommSemigroupₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroup  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  AddSemigroup  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddSemigroupₓ  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddCommSemigroup  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddCommSemigroupₓ  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddCommSemigroup  S ] ->  {  a b c : S } ->   AddCommute  a b →   AddCommute  b c →  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddCommSemigroupₓ  S ] ->  {  a b c : S } ->   AddCommute  a b →   AddCommute  b c →  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroup  S ] ->  (  a b c : S ) ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  (  a b c : S ) ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  AddCommMonoid  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddCommMonoidₓ  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c"]},
  {"theorem":
   "∀ {α : Type u} {β : Type v} [inst : Ringₓ α] [inst_1 : Ringₓ β] {f : α → β}, IsRingHom f → ∀ (x : α), f 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":
   [" {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  (  x : α ) ->    f  x =  0 →  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  h0 :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  CommRingₓ  α ] ->  [  CommRingₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  {  x : α } ->    f  x =  0 →  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  {  x : α } ->  (  h :   f  x =  0 ) ->  x =  0",
    " {  α :  Type* } ->  {  β :  Type* } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->    f  x =  0 →  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  {  x : α } ->  (  hx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  h :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  hx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  (  b : β ) ->  (  h :   ⟨  f , b ⟩ =  0 ) ->  b =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  z : α } ->  (  hf :  IsRingHom  f ) ->  (  hfz :   f  z =  0 ) ->  z =  0"]},
  {"theorem": "∀ {p q : Prop}, (p → q) → q → p",
   "some-correct": null,
   "round-trip": " If `p → q` and `q` then `p`. ",
   "prompt": "Implication `→` is symmetric. If `P → Q` then `Q → P`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  p q :  Prop } ->  (  h :  p → q ) ->  q → p",
    " {  p q :  Prop } ->  (  h :  Implies  p q ) ->  Implies  q p",
    " {  P Q :  Prop } ->  (  h :  P → Q ) ->  Q → P",
    " {  p q :  Prop } ->   Implies  p q →  Implies  q p",
    " {  p q :  Prop } ->  (  m :  Implies  p q ) ->  Implies  q p"]},
  {"theorem": "∀ (a b : ℕ), a = b ↔ ∃ p, Nat.Prime p ∧ p ∣ a ∧ p ∣ b",
   "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":
   [" (  a b :  ℕ ) ->   a = b ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ a ∧  p ∣ b",
    " {  m n :  ℕ } ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  (    p ∣ m ∧  p ∣ n  )",
    " {  m n :  ℕ } ->   m = n ↔  (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n  )",
    " {  m n :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n  ) ↔  m = n",
    " {  a b :  ℕ } ->   a = b ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ a ∧  p ∣ b",
    " {  p q :  ℕ } ->   (   ∃    (   pr :  ℕ ) ,   Nat.Prime  pr ∧   p ∣ pr ∧  q ∣ pr  ) ↔  p = q",
    " {  m n :  ℕ } ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " {  m n :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣  (   m * n  )  ) ↔  m = n",
    " {  m n :  ℕ } ->   m = n ↔  (   ∃    (   p :  ℕ ) ,   m ∣ p ∧   n ∣ p ∧  Nat.Prime  p  )",
    " {  a b :  ℕ } ->   a = b ↔  (   ∃     p  ,   Nat.Prime  p ∧   p ∣ a ∧  p ∣ b  )",
    " {  n a :  ℕ } ->   n = a ↔  ∃     pr  :  ℕ ,   Nat.Prime  pr ∧   pr ∣ n ∧  pr ∣ a",
    " {  m n :  ℕ } ->   (   ∃     p  :  ℕ ,   Nat.Prime  p ∧  (    p ∣ m ∧  p ∣ n  )  ) ↔  m = n",
    " {  n m :  ℕ } ->   n = m ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ n ∧  p ∣ m",
    " {  n m :  ℕ } ->  (  h1 :  n ≠  0 ) ->  (  h2 :  m ≠  0 ) ->   n = m ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ n ∧  p ∣ m"]}],
 "elaborated": 30}