{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 20,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["A finitely-presented group containing a torsion element is finite.",
  "A topological space $X$ is Hausdorff if and only if the diagonal map is an open map from $X$ to $X × X$.",
  "Every normal subgroup of a group has finite index.",
  "The characteristic polynomial of every matrix has real roots.",
  "In a commutative ring, every prime ideal is contained in a unique maximal ideal.",
  "Every 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.",
  "The initial object of a category is isomorphic to its terminal object."],
 "elaborated-prompts":
 [{"theorem": "∀ {α : Type u} [inst : Ringₓ α], IsField α",
   "some-correct": null,
   "round-trip": "A typeclass that asserts that `α` is a field. ",
   "prompt": "Every ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  IsField  α",
    " {  X :  Type  u } ->  [  Ringₓ  X ] ->  IsField  X",
    " {  α :  Type  u } ->  [  Ring  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Field  α",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  IsField  R"]},
  {"theorem":
   "∀ {K : Type u} {V : Type v} [inst : DivisionRing K] [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 } ->  {  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_1 ) ->  {  V :  Type  u_2 } ->  [  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 ] ->  Nonempty   (   FiniteDimensional  K V  )"]},
  {"theorem": "∀ {G : Type u_1} [inst : Groupₓ G], Monoidₓ.IsTorsion G",
   "some-correct": null,
   "round-trip": "A group is torsion. ",
   "prompt": "Every group is a torsion monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  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, Fintype.card G = p ∧ Fact (Nat.Prime p)",
   "some-correct": null,
   "round-trip": " A simple group is finite and its order is a prime number. ",
   "prompt": "Every finite simple group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  {  h :  IsSimpleGroup  G } ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧  p =  Fintype.card  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  H :  IsSimpleGroup  G ) ->  ∃     p  ,   Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hsimple :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  [  IsSimpleGroup  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  G :  Type  u_1 } ->  [  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_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  [ hG :  IsSimpleGroup  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  H :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,  ∀   (  d  :  ℕ  )  ,   d ∣  Fintype.card  G →   d =  1 ∨  d = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,    Fintype.card  G = p ∧  Nat.Prime  p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  [  IsSimpleGroup  α ] ->  ∃     p  :  ℕ ,  ∃     Prime  :  Fact   (   Nat.Prime  p  ) ,   Fintype.card  α = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  [ h :  IsSimpleGroup  G ] ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧  ∃    (   x : G ) ,   orderOf  x = p"]},
  {"theorem":
   "∀ {G : Type u} [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 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  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",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  Nat.Prime   (   Fintype.card  G  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  Nat.Prime   (   Fintype.card  G  )",
    " {  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_1 } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   n :  ℕ )  (   h :  Nat.Prime  n ) ,   Fintype.card  G = n",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   n :  ℕ )  (   h :  Nat.Prime  n ) ,   Fintype.card  G = n",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  Group  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  Groupₓ  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type* } ->  [  Group  α ] ->  [  Fintype  α ] ->  (  n :  ℕ ) ->  ∃     p  ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type* } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  n :  ℕ ) ->  ∃     p  ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  :  ℕ ,    Fintype.card  G = p ∧  Fact   (   Nat.Prime  p  )",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  {  n :  ℕ } ->  (  h :   Fintype.card  G = n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  {  n :  ℕ } ->  (  h :   Fintype.card  G = n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  (  h :   Fintype.card  α ≠  1 ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  h :   Fintype.card  α ≠  1 ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p"]},
  {"theorem":
   "∀ {α : Type u_1} (A : Set α), coeFn MeasureTheory.volume.toOuterMeasure A = 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 } ->  ∀   (  A  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  A =  0",
    " {  α :  Type  u_1 } ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  {  s :  Set  α } ->    (    ⇑ MeasureTheory.MeasureSpace.volume  ⇑ MeasureTheory.MeasureSpace.volume  )  s =  0"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] [inst_1 : CompactSpace α] {s : Set α}, IsCompact s",
   "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":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  ∀  s  ,  IsCompact  s",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  (  h :  IsCompact  α ) ->  ∀  s   :  Set  α ,  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  IsCompact  α ) ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  IsCompact  α ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  IsCompact  α ) ->  (  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 } ->  [  TopologicalSpace  α ] ->  (  h :  IsCompact  α ) ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  IsCompact  s"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : MeasurableSpace α] {s : Set α},\n  MeasurableSet s → ¬MeasurableSet s → coeFn MeasureTheory.volume.toOuterMeasure s = 0",
   "some-correct": null,
   "round-trip": "**Measure of a Measurable Set** ",
   "prompt":
   "Every set that is Lebesgue measurable but not Borel measurable has Lebesgue measure zero.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  {  s :  Set  α } ->  (  hmeas :  MeasurableSet  s ) ->  (  hnb :  ¬  MeasurableSet  s ) ->   MeasureTheory.MeasureSpace.volume  s =  0"]},
  {"theorem":
   "∀ {X : Type u_1} [inst : TopologicalSpace X] {s : Set X}, (∀ (x : X), x ∈ s → ∃ t, IsClosed t ∧ x ∈ t) → IsClosed s",
   "some-correct": null,
   "round-trip": "**Closed Sets are Intersections of Closed Sets** ",
   "prompt":
   "If every point of a subset of a topological space is contained in some closed set, the subset itself is closed.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :  ∀   (  x  : X  )  ,   x ∈ s →  ∃    (   t :  Set  X ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :  ∀  x  ,   x ∈ s →  ∃    (   t :  Set  X ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     c  :  Set  α ,   IsClosed  c ∧   x ∈ c ∧  c ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     C  :  Set  α ,   IsClosed  C ∧   x ∈ C ∧  C ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  hst :  s ⊆ t ) ->  (  h :  ∀  x  ∈ t ,  ∃     V  :  Set  α ,   IsClosed  V ∧   x ∈ V ∧  V ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     c  :  Set  α ,   IsClosed  c ∧  x ∈ c ) ->  IsClosed  s",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :   (   ∀   (  x  : X  )  ,   x ∈ s →  ∃    (   t :  Set  X ) ,   IsClosed  t ∧  x ∈ t  ) →  IsClosed  s ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  S :  Set  α } ->  (  hS :  ∀  x  ∈ S ,  ∃     U  :  Set  α ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  S",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     C  ,   IsClosed  C ∧   x ∈ C ∧  C ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  ht :  t ⊆ s ) ->  (  hs :  ∀  x  ∈ s ,  ∃     V  :  Set  α ,   x ∈ V ∧  IsClosed  V ) ->  IsClosed  t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  t :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ t →  ∃    (   s :  Set  α ) ,   IsClosed  s ∧  x ∈ s ) ->  IsClosed  t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀  x   : α ,   x ∈ s →  ∃     t  :  Set  α ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ,   x ∈ t →  ∃     v  ,   IsClosed  v ∧  x ∈ v ) ->  (  h2 :  ∀  x  ,   x ∈ t →  ∃!     v  ,   IsClosed  v ∧  x ∈ v ) ->  (  h3 :  s ⊆ t ) ->  IsClosed  s"]},
  {"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 ) ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  e : G } ->  (  h :  IsOfFinOrder  e ) ->  e =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  g : G } ->  (  hg :  IsOfFinOrder  g ) ->  g =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->  (  hx :  IsOfFinOrder  x ) ->  x =  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 } ->  [  Groupₓ  G ] ->  {  x : G } ->  (  h :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  h :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  h :  IsOfFinOrder  x ) ->  x =  1",
    " (  G :  Type  u_1 ) ->  [  Groupₓ  G ] ->  (  x : G ) ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u } ->  [  Group  G ] ->  IsOfFinOrder   1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  IsOfFinOrder   1"]},
  {"theorem":
   "∀ (H : Type u_1) [inst : Groupₓ H] (G : Type u_2) [inst_1 : Groupₓ G],\n  Subgroup H → Monoidₓ.IsTorsionFree H → Monoidₓ.IsTorsionFree G",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "If a subgroup of a group is torsion-free, then the group itself is torsion free.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  H :  Type  u_1 ) ->  [  Groupₓ  H ] ->  (  G :  Type  u_2 ) ->  [  Groupₓ  G ] ->  (  Sub :  Subgroup  H ) ->  (  tfH :  Monoidₓ.IsTorsionFree  H ) ->  Monoidₓ.IsTorsionFree  G"]},
  {"theorem":
   "∀ {α : Type u} (f : FreeGroup α → FreeGroup α), IsGroupHom f → Function.Injective f → Fintype α → Function.Surjective f",
   "some-correct": null,
   "round-trip":
   "If f is a group homomorphism from the free group on α to itself, and if α is finite, then f is surjective. ",
   "prompt":
   "Every injective homomorphism from a finitely generated free group to itself is surjective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  (  f :   FreeGroup  α →  FreeGroup  α ) ->  (  hf :  IsGroupHom  f ) ->  (  hinj :  Function.Injective  f ) ->  (  hfg :  Fintype  α ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  {  G :  Type  v } ->  [  Fintype  α ] ->  [  DecidableEq  α ] ->  [  Groupₓ  G ] ->  (  f :   FreeGroup  α → G ) ->  (  H :  IsGroupHom  f ) ->  (  H' :  Function.Injective  f ) ->  Function.Surjective  f"]},
  {"theorem": "∀ {K : Type u} [inst : DivisionRing K], Finite K ∨ IsField K",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every division ring is either a field or finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  [  DivisionRing  K ] ->   Finite  K ∨  IsField  K",
    " (  K :  Type* ) ->  [  DivisionRing  K ] ->   IsField  K ∨  Finite  K"]},
  {"theorem": "∀ (n : ℕ), ∃ p q, Nat.Prime p ∧ Nat.Prime q ∧ n = p * q",
   "some-correct": null,
   "round-trip":
   "Every natural number 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 :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  x :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = x",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a * b",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   p ≠ q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  (  h0 :   0 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,   n =  a * b ∧   Nat.Prime  a ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  ∃    (   m  p :  ℕ ) ,   Nat.Prime  m ∧   Nat.Prime  p ∧  n =  m * p",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m  p :  ℕ ) ,   n =  m * p ∧   Nat.Prime  m ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,    p * q = n ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " {  n :  ℕ } ->  ∃    (   p  q :  ℕ ) ,  (    Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q  )",
    " {  p :  ℕ } ->  (  hpos :   0 < p ) ->  ∃    (   x  y :  ℕ ) ,   Nat.Prime  x ∧   Nat.Prime  y ∧  p =  x * y",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a * b",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n"]},
  {"theorem": "∀ {n : ℕ}, Even n → ∃ m, m * m = n",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every even number is the square of a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m * m = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃     m  ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   k :  ℕ ) ,  n =  k ^  2",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃     m  :  ℕ ,  n =  m ^  2",
    " {  n :  ℕ } ->  ∃    (   r :  ℕ ) ,    2 *  r ^  2 = n",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  hn :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  ∃    (   m :  ℕ ) ,   Even  m ∧   m ^  2 = n",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " (  n :  ℕ ) ->   Even  n →  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃     m  ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,  n =  m * m"]},
  {"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 } ->  {  β :  Type  v } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  SeparatedSpace  α ] ->  [  CompleteSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  SeparatedSpace  α ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α},\n  (∀ (t : Set α), IsCompact t → IsClosed t) →\n    (IsCompact s ↔ ∀ (t : Set α), IsClosed t → s ⊂ t → ∃ u, IsOpen u ∧ s ⊂ u ∧ u ⊂ t)",
   "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  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  t  :  Set  α  )  ,   IsCompact  t →  IsClosed  t ) ->   IsCompact  s ↔  ∀   (  t  :  Set  α  )  ,   IsClosed  t →   s ⊆ t →  ∃    (   u :  Set  α ) ,   IsOpen  u ∧   s ⊆ u ∧  u ⊆ t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  t  :  Set  α  )  ,   IsCompact  t →  IsClosed  t ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  t  :  Set  α  )  ,   IsCompact  t →  IsClosed  t ) ->   IsCompact  s →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  t  :  Set  α  )  ,   IsCompact  t →  IsClosed  t ) ->   (   ∀   (  s  :  Set  α  )  ,  IsCompact  s  ) ↔  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  t  :  Set  α  )  ,   IsCompact  t →  IsClosed  t ) ->  (  hs' :  ∀  u t   :  Set  α ,   IsCompact  t →   t ⊆ u →  IsCompact  u ) ->  IsCompact  s",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  t  :  Set  α  )  (  ht  :  IsCompact  t  )  ,  IsClosed  t ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  t  :  Set  α  )  ,   IsCompact  t →  IsClosed  t ) ->   IsCompact  s →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->   IsCompact  s →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  C :  Set   (   Set  α  ) } ->  (  hC :  ∀  s   :  Set  α ,   IsCompact  s →  IsClosed  s ) ->   IsCompact  α ↔  IsClosed  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  IsClosed  s ) ->  (  h :  ∀   (  t  :  Set  α  )  (  ht  :  IsCompact  t  )  ,   t ⊆ s →  IsClosed  t ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  t  ,   IsCompact  t →  IsClosed  t ) ->   IsCompact  s →  IsClosed  s"]},
  {"theorem":
   "∀ {α : Type u} [inst : CommRing α] {a b : α}, a = a ^ 2 → b = b ^ 2 → (a + b) ^ 2 = 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 : α } ->  (  h :  a =  a ^  2 ) ->  (  h' :  b =  b ^  2 ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h :  a =  a ^  2 ) ->  (  h' :  b =  b ^  2 ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  x y : α } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  x y : α } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  (  a b : α ) ->  (  h :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  (  a b : α ) ->  (  h :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  h :   a ^  2 = a ) ->  (  h' :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h :   a ^  2 = a ) ->  (  h' :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  h1 :   a * a = a ) ->  (  h2 :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h1 :   a * a = a ) ->  (  h2 :   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",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  (  a b : α ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  e₁ e₂ : α } ->  (  h₁ :   e₁ * e₁ = e₁ ) ->  (  h₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  e₁ e₂ : α } ->  (  h₁ :   e₁ * e₁ = e₁ ) ->  (  h₂ :   e₂ * e₂ = e₂ ) ->    (   e₁ + e₂  ) *  (   e₁ + e₂  ) =  e₁ + e₂",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  x y : α } ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  x y : α } ->  (  hx :   x ^  2 = x ) ->  (  hy :   y ^  2 = y ) ->    (   x + y  ) ^  2 =  x + y",
    " {  α :  Type  u_1 } ->  [  CommRing  α ] ->  (  u v : α ) ->  (  hu :   u ^  2 = u ) ->  (  hv :   v ^  2 = v ) ->    (   u + v  ) ^  2 =  u + v",
    " {  α :  Type  u_1 } ->  [  CommRingₓ  α ] ->  (  u v : α ) ->  (  hu :   u ^  2 = u ) ->  (  hv :   v ^  2 = v ) ->    (   u + v  ) ^  2 =  u + v",
    " {  α :  Type  u } ->  [  NonUnitalCommRing  α ] ->  {  a b : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  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 } ->  [  CommRing  α ] ->  {  e₁ e₂ : α } ->  (  h₁ :   e₁ ^  2 = e₁ ) ->  (  h₂ :   e₂ ^  2 = e₂ ) ->    (   e₁ + e₂  ) ^  2 =  e₁ + e₂",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  e₁ e₂ : α } ->  (  h₁ :   e₁ ^  2 = e₁ ) ->  (  h₂ :   e₂ ^  2 = e₂ ) ->    (   e₁ + e₂  ) ^  2 =  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 } ->  [  CommRing  α ] ->  {  a b : α } ->  (  h1 :  a ≠  0 ) ->  (  h2 :  a ≠  1 ) ->  (  h3 :  b ≠  0 ) ->  (  h4 :  b ≠  1 ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->   a + b ≠  1",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h1 :  a ≠  0 ) ->  (  h2 :  a ≠  1 ) ->  (  h3 :  b ≠  0 ) ->  (  h4 :  b ≠  1 ) ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->   a + b ≠  1"]},
  {"theorem":
   "∀ {α : Type u} [inst : Fintype α], Prime (AddMonoidHom.toFun Multiset.card ?m.4335246)",
   "some-correct": null,
   "round-trip": "The cardinality of a `fintype` is prime. ",
   "prompt": "The number of partitions of a finite set is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Fintype  α ] ->  Prime   (   Multiset.card  α  )"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : Preorder α], (∃ a, ∀ (b : α), ¬b < a) → ExistsUnique fun b => ∀ (c : α), c < b",
   "some-correct": null,
   "round-trip":
   " If `α` is a preorder 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  u_1 } ->  [  Preorder  α ] ->  (  h₁ :  ∃    (   a : α ) ,  ∀   (  b  : α  )  ,  ¬  (   b < a  ) ) ->  ∃!    (   b : α ) ,  ∀   (  c  : α  )  ,  c < b",
    " {  α :  Type  u_1 } ->  [  Preorderₓ  α ] ->  (  h₁ :  ∃    (   a : α ) ,  ∀   (  b  : α  )  ,  ¬  (   b < a  ) ) ->  ∃!    (   b : α ) ,  ∀   (  c  : α  )  ,  c < b",
    " {  α :  Type  u_1 } ->  [  LinearOrder  α ] ->  [  NoBotOrder  α ] ->  (  h :  ∃    (   a : α ) ,  IsTop  a ) ->  ∃!    (   a : α ) ,  IsBot  a",
    " {  α :  Type  u_1 } ->  [  LinearOrderₓ  α ] ->  [  NoBotOrder  α ] ->  (  h :  ∃    (   a : α ) ,  IsTop  a ) ->  ∃!    (   a : α ) ,  IsBot  a",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  [  Nonempty  α ] ->  [  NoBotOrder  α ] ->  (  h :  ∃    (   max : α ) ,  ∀   (  a  : α  )  ,  max ≤ a ) ->  ∃!    (   min : α ) ,  ∀   (  a  : α  )  ,  min ≤ a",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  [  Nonempty  α ] ->  [  NoBotOrder  α ] ->  (  h :  ∃    (   max : α ) ,  ∀   (  a  : α  )  ,  max ≤ a ) ->  ∃!    (   min : α ) ,  ∀   (  a  : α  )  ,  min ≤ a",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  [  Nonempty  α ] ->  [  HasTop  α ] ->  HasInf   (   OrderDual  α  )",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  [  Nonempty  α ] ->  [  HasTop  α ] ->  HasInfₓ   (   OrderDual  α  )",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  [  Nonempty  α ] ->  [  HasTop  α ] ->  HasInf   (   OrderDual  α  )",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  [  Nonempty  α ] ->  [  HasTop  α ] ->  HasInfₓ   (   OrderDual  α  )"]},
  {"theorem":
   "∀ {f : ℕ → ℕ}, Function.IsFixedPt f 0 → ∀ {n : ℕ}, 0 < n → ∃ x, Function.IsPeriodicPt f n x",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 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":
   "{R : Type u_1} →\n  {M : Type u_2} →\n    [inst : Ringₓ R] → [inst_1 : AddCommGroupₓ M] → [inst_2 : Module R M] → [inst : Module.Free R M] → CommRing R",
   "some-correct": null,
   "round-trip":
   " If `M` is a free `R`-module, then `R` is a commutative ring. ",
   "prompt": "If a module over a ring is free, then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u_1 } ->  {  M :  Type  u_2 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  [  Module.Free  R M ] ->  CommRing  R",
    " {  R :  Type  u_1 } ->  {  M :  Type  u_2 } ->  [  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",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :  Module.Free  K V ) ->  CommRing  K",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  h :  Module.Free  K V ) ->  CommRingₓ  K",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  i :  Module.Free  R M ) ->  CommRing  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  i :  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 ] ->  (  h :  Module.Free  R M ) ->  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  h :  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",
    " (  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": "{α : Type u} → [inst : Ringₓ α] → Group (Units α) → CommRing α",
   "some-correct": null,
   "round-trip":
   "If `α` is a ring, and `Units α` is a group, then `α` is a commutative ring. ",
   "prompt":
   "If the set of units of a ring forms a group then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  Group   (   Units  α  ) ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  Group   (   Units  α  ) ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  Groupₓ   (   Units  α  ) ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  Groupₓ   (   Units  α  ) ) ->  CommRingₓ  α",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommGroup   (   Units  R  )",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommGroupₓ   (   Units  R  )",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommGroup   (   Units  R  )",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommGroupₓ   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoid  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoid  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoid  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoid  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoidₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoidₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoidₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddMonoidₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  AddCommGroup   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  AddCommGroup   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  AddCommGroupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  H :  AddCommGroupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  Group  α ] ->  AddCommGroup  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  Group  α ] ->  AddCommGroupₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  Groupₓ  α ] ->  AddCommGroup  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  Groupₓ  α ] ->  AddCommGroupₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Group  α ] ->  AddCommGroup  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Group  α ] ->  AddCommGroupₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Groupₓ  α ] ->  AddCommGroup  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Groupₓ  α ] ->  AddCommGroupₓ  α",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  h :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  h :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  H :  Group   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  H :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  (  H :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  hu :  Group   (   Units  α  ) ) ->  CommMonoid  α",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  hu :  Group   (   Units  α  ) ) ->  CommMonoidₓ  α",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  hu :  Groupₓ   (   Units  α  ) ) ->  CommMonoid  α",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  hu :  Groupₓ   (   Units  α  ) ) ->  CommMonoidₓ  α",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  HJ :  Group   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  HJ :  Group   (   Units  R  ) ) ->  CommRingₓ  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  HJ :  Groupₓ   (   Units  R  ) ) ->  CommRing  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  HJ :  Groupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddCommGroup   (   Units  R  ) ] ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddCommGroup   (   Units  R  ) ] ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ   (   Units  R  ) ] ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ   (   Units  R  ) ] ->  CommRingₓ  R"]},
  {"theorem": "∀ {n : ℕ}, n > 10 → ∃ p q, n = q * q + p ∧ Nat.Prime p",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every natural number larger than `10` is the sum of a square and a prime.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   p :  ℕ )  (   q :  ℕ ) ,   n =   q * q + p ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   p :  ℕ )  (   q :  ℕ ) ,   n =   p * p + q ∧   q >  0 ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   b >  0 ∧   Nat.Prime  b ∧    a * a + b = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ )  (   hb :  Nat.Prime  b ) ,    a * a + b = n",
    " (  n :  ℕ ) ->  (  h :   10 < n ) ->  ∃    (   p :  ℕ )  (   t :  ℕ ) ,   p >  0 ∧   n =  p +  t * t ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->   n >  10 →  ∃    (   a  b :  ℕ ) ,     a * a + b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a * a + b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  b ∧    a * a + b = n",
    " (  n :  ℕ ) ->  (  h :   10 < n ) ->  ∃     a  c  :  ℕ ,   n =   a * a + c ∧  Nat.Prime  c",
    " {  n :  ℕ } ->  (  hn :   10 < n ) ->  ∃    (   p  a  b :  ℕ ) ,   n =   p * p +  a * b ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a * a +  b * b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  h :   10 < n ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  b ∧    a ^  2 + b = n",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   a  p :  ℕ ) ,   Nat.Prime  p ∧  p =  n -  a * a",
    " {  n :  ℕ } ->  (  hn :  n ≥  10 ) ->  ∃    (   p  a :  ℕ ) ,   n =   a * a + p ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  q ∧  n =   p * p + q",
    " {  n :  ℕ } ->  (  h :   11 ≤ n ) ->  ∃    (   a  b :  ℕ ) ,   n =   a * a + b ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  h :   10 < n ) ->  ∃    (   p :  ℕ )  (   q :  ℕ ) ,   n =   (   q * q  ) + p ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->    11 ≤ n →  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b  p :  ℕ ) ,   n =    a * a +  b * b + p ∧  Nat.Prime  p"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} {γ : Type u_3} [inst : TopologicalSpace α] [inst_1 : TopologicalSpace β]\n  [inst_2 : TopologicalSpace γ] {g : α → β} {f : β → γ}, Continuous f → Continuous g → Continuous (f ∘ g) → Continuous f",
   "some-correct": null,
   "round-trip":
   " If `f : β → γ` and `g : α → β` are continuous, then so is `f ∘ g`. ",
   "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 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   Function.comp  f g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  α → β } ->  {  f :  β → γ } ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  (  hfg :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  β → γ } ->  {  f :  α → β } ->  (  hf :  Continuous   (   g ∘ f  ) ) ->   Continuous  g ∧  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  hfg :  Continuous   (   f ∘ g  ) ) ->   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 :  β → γ } ->  (  hf :  Continuous   (   Function.comp  g f  ) ) ->  (  hg :  Continuous  g ) ->  Continuous  f",
    " {  α β :  Type* } ->  {  γ :  Type* } ->  (  a :  α → β ) ->  (  b :  β → γ ) ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   b ∘ a  ) ) ->   Continuous  a ∧  Continuous  b",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hfg :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  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 :  β → γ } ->  (  hgf :  Continuous   (   g ∘ f  ) ) ->  (  hf :  Continuous  f ) ->  Continuous  g"]},
  {"theorem":
   "∀ {S : Type u_1} [inst : CommSemigroup 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 } ->  [  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 } ->  [  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 } ->  [  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",
    " {  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 } ->  [  Distrib  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  Distribₓ  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  SemigroupWithZero  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  SemigroupWithZeroₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  R :  Type  u_1 } ->  [  Ring  R ] ->  {  a b c : R } ->  (  hac :  Commute  a c ) ->  (  hbc :  Commute  b c ) ->  Commute   (   a * b  ) c",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  {  a b c : R } ->  (  hac :  Commute  a c ) ->  (  hbc :  Commute  b c ) ->  Commute   (   a * b  ) c",
    " {  S :  Type  u_1 } ->  [  Monoid  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Monoidₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  R :  Type  u_1 } ->  [  CommRing  R ] ->  {  a b c : R } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  R :  Type  u_1 } ->  [  CommRingₓ  R ] ->  {  a b c : R } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommSemigroup  S ] ->  {  a b c : S } ->  (  hac :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommSemigroupₓ  S ] ->  {  a b c : S } ->  (  hac :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c"]},
  {"theorem":
   "∀ {α : Type u} {β : Type v} [inst : Ringₓ α] [inst_1 : Ringₓ β] {f : α → β} {x : α}, IsRingHom f → 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 :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  hx :   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 :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  hx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  {  x : α } ->    f  x =  0 →  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Semiringₓ  α ] ->  [  Semiringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsSemiringHom  f ) ->    f  x =  0 →  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  hfx :   f  x =  0 ) ->  x =  0",
    " {  R A :  Type* } ->  [  CommRingₓ  A ] ->  [  CommRingₓ  R ] ->  {  f :  R → A } ->  (  hf :  IsRingHom  f ) ->  (  a : R ) ->  (  h :   f  a =  0 ) ->  a =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  CommRingₓ  α ] ->  [  CommRingₓ  β ] ->  {  f :  α → β } ->  {  b : α } ->  (  hf :  IsRingHom  f ) ->  (  h :   f  b =  0 ) ->  b =  0"]},
  {"theorem": "∀ {p q : Prop}, Implies p q → Implies q p",
   "some-correct": null,
   "round-trip": "Implication `→` is symmetric. If `P → Q` then `Q → P`. ",
   "prompt": "Implication `→` is symmetric. If `P → Q` then `Q → P`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  p q :  Prop } ->  (  h :  Implies  p q ) ->  Implies  q p",
    " {  p q :  Prop } ->  (  h :  p → q ) ->  q → p",
    " {  p q :  Prop } ->  (  h₁ :  Implies  p q ) ->  Implies  q p",
    " {  a b :  Prop } ->  (  h :  a → b ) ->  b → a"]},
  {"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",
    " {  n m :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ n ∧  p ∣ m  ) ↔  n = m",
    " (  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 :  ℕ ) ->   m = n ↔  ∃     p  ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " {  m n :  ℕ } ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " {  a b :  ℕ } ->  ∃    (   p :  ℕ ) ,    Nat.Prime  p ∧   a ∣ p ∧  b ∣ p ↔  a = b",
    " (  m n :  ℕ ) ->   m = n ↔  (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n  )",
    " {  m n :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  (    p ∣ m ∧  p ∣ n  )  ) ↔  m = n",
    " {  m n :  ℕ } ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  (    p ∣ m ∧  p ∣ n  )",
    " {  m n :  ℕ } ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣  (   m * n  )",
    " {  m n :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n  ) ↔  m = n"]}],
 "elaborated": 30}