{"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.",
  "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$.",
  "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 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,
   "prompt": "Every ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  IsField  α",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  IsField  R",
    " {  α :  Type  u } ->  [  Ring  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Field  α",
    " {  R :  Type* } ->  [  Ringₓ  R ] ->  IsField  R"]},
  {"theorem":
   "∀ (k : Type u_1) (V : Type u_2) [inst : DivisionRing k] [inst_1 : AddCommGroupₓ V] [inst_2 : Module k V],\n  FiniteDimensional k V",
   "some-correct": null,
   "prompt": "Every vector space is finite dimensional.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  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 ] ->  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 } ->  [  DivisionRing  K ] ->  (  V :  Type  v ) ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V",
    " {  k :  Type  u_1 } ->  [  DivisionRing  k ] ->  {  V :  Type  u_2 } ->  [  AddCommGroupₓ  V ] ->  [  Module  k V ] ->  FiniteDimensional  k V",
    " (  k :  Type  u ) ->  (  V :  Type  v ) ->  [  Field  k ] ->  [  AddCommGroupₓ  V ] ->  [  Module  k V ] ->  FiniteDimensional  k V"]},
  {"theorem": "∀ {G : Type u_1} [inst : Groupₓ G], Monoidₓ.IsTorsion G",
   "some-correct": null,
   "prompt": "Every group is a torsion monoid.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  Monoidₓ.IsTorsion  α",
    " (  G :  Type  u_1 ) ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G"]},
  {"theorem":
   "∀ {G : Type u} [inst : Groupₓ G] [inst_1 : Fintype G],\n  Finite G → IsSimpleGroup G → ∃ p, Fact (Nat.Prime p) ∧ Fintype.card G = p",
   "some-correct": null,
   "prompt": "Every finite simple group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hfinite :  Finite  G ) ->  (  hsimple :  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 ] ->  (  simple :  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 ] ->  [  IsSimpleGroup  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  s :  IsSimpleGroup  G ) ->  Nat.Prime   (   Fintype.card  G  )",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  hsimple :  IsSimpleGroup  α ) ->  ∃    (   p :  ℕ ) ,   (   Fact   (   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 ] ->  {  P :  Prop } ->  [ isS :  IsSimpleGroup  G ] ->  (  h :   Fintype.card  G ≠  (   1   :  ℕ ) ) ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   p ≠  1 ∧  p ∣  Fintype.card  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   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  } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,   Prime  p ∧   Fintype.card  G = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  hsimple :  IsSimpleGroup  α ) ->  ∃    (   p :  ℕ ) ,    Fintype.card  α = p ∧  Fact   (   Nat.Prime  p  )"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] [inst_1 : Fintype G], IsSimpleGroup G",
   "some-correct": null,
   "prompt": "Every finite group is simple.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  x : α ) ->  IsSimpleGroup  α",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  IsSimpleGroup  α",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G",
    " {  α :  Type  u } ->  {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  IsSimpleGroup  G"]},
  {"theorem":
   "∀ {G : Type u} {g : G} [inst : Groupₓ G] [inst_1 : Fintype G], IsOfFinOrder g → ∃ p, Nat.Prime p ∧ orderOf g = p",
   "some-correct": null,
   "prompt": "Every finite group has prime order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  {  g : G } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsOfFinOrder  g ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   orderOf  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  )",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃     p  :  ℕ ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃     p  :  ℕ ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type* } ->  [  Fintype  α ] ->  [  Group  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  α :  Type* } ->  [  Fintype  α ] ->  [  Groupₓ  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  {  p :  ℕ } ->  [ hp :  Fact   (   Nat.Prime  p  ) ] ->  (  h :   Fintype.card  G = p ) ->  IsCyclic  G",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  Prime   (   Fintype.card  G  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  Prime   (   Fintype.card  G  )",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   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",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->    Fintype.card  G >  0 →  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->    Fintype.card  G >  0 →  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  G = 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",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   Fintype.card  α = 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  )",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ )  (   hp :  Nat.Prime  p ) ,   Fintype.card  α = p",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ )  (   hp :  Nat.Prime  p ) ,   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,  ∃    (   h :  Fact   (   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"]},
  {"theorem": "∀ (s : Set ℕ), coeFn MeasureTheory.volume.toOuterMeasure s = 0",
   "some-correct": null,
   "prompt": "Every set has Lebesgue measure zero.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  s :  Set   ℕ ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  {  s :  Set  α } ->    ↑   (   measure_theory.measure_space.borel   _  ) . volume  s =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u } ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  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 } ->  ∀   {  A  :  Set  α }  ,   MeasureTheory.MeasureSpace.volume  A =  0",
    " {  α :  Type  u } ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] [inst_1 : CompactSpace α] (s : Set α), IsCompact s",
   "some-correct": null,
   "prompt": "If a topological space is compact, then every subset is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  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  u } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  (  s :  Set  α ) ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  IsCompact  α ) ->  (  s :  Set  α ) ->  IsCompact  s",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  (  h :  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 } ->  [ t :  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  {  s :  Set  α } ->  IsCompact  s"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α} {t : Set α},\n  (∀ (x : α), x ∈ s → ∃ V, x ∈ V ∧ IsClosed V) → IsClosed s",
   "some-correct": null,
   "prompt":
   "If every point of a subset of a topological space is contained in some closed set, the subset itself is closed.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  H :  ∀  x  ∈ s ,  ∃     V  :  Set  α ,   x ∈ V ∧  IsClosed  V ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  U :  Set  α } ->  (  H :  ∀  x  ∈ U ,  ∃  C  ∈  {   C   :  Set  α |  IsClosed  C } ,  x ∈ C ) ->  IsClosed  U",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  ,   IsClosed  t ∧   x ∈ t ∧  t ⊆ s ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ,   x ∈ s →  ∃     U  ,   IsClosed  U ∧  x ∈ U ) ->  IsClosed  s",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :  ∀  x  ∈ s ,  ∃     t  :  Set  X ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  :  Set  α ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   c :  Set  α ) ,   IsClosed  c ∧  x ∈ c ) ->   IsClosed  s ↔  s ⊆ t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  hst :  t ⊆ s ) ->  (  h :  ∀  x  ∈ s ,  ∃     V  ,   IsClosed  V ∧   x ∈ V ∧  V ⊆ t ) ->  IsClosed  t",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  [  DecidablePred  s ] ->  (  h :  ∀  x  ∈ s ,  ∃     t  :  Set  α ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  S :  Set  α } ->  {  p :  α →  Prop } ->  (  hp :  ∀   (  x  : α  )  ,   p  x →  ∃     U  :  Set  α ,   IsClosed  U ∧  x ∈ U ) ->  (  h :  ∀   (  x  : α  )  ,   p  x →  x ∈ S ) ->  IsClosed  S",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ,   x ∈ s →  ∃     t  ,   t ⊆ s ∧  IsClosed  t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  S :  Set  α } ->  {  T :  Set   (   Set  α  ) } ->  (  h :  ∀  x  ,   x ∈ S →  ∃  V  ∈ T ,  x ∈ V ) ->   (   ∃  s  ∈  Closure  T ,  s ⊆ S  ) →  IsClosed  S",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  hx :  ∀  x   : X ,   x ∈ s →  ∃     t  :  Set  X ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [ t :  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ,   x ∈ s →  ∃     t  ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  S :  Set  α } ->  (  hS :  ∀  x  ∈ S ,  ∃     C  :  Set  α ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  S",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  ht :  IsClosed  t ) ->  (  h :  ∀  x  ∈ s ,  ∃     u  ,   IsClosed  u ∧   x ∈ u ∧  u ⊆ t ) ->  IsClosed   (   s ∩ t  )"]},
  {"theorem":
   "∀ {G : Type u} [inst : Groupₓ G] {x : G}, IsOfFinOrder x → x = 1",
   "some-correct": null,
   "prompt": "Any finite order element in a group is equal to the identity.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  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 } ->  (  hx :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->    orderOf  x =  1 ↔  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 } ->  [  Groupₓ  G ] ->  (  x : G ) ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  IsOfFinOrder  x ) ->  x =  1"]},
  {"theorem":
   "∀ {n : ℕ} {X : Type ?u.10235252} [inst : Fintype X] {f : FreeGroup X → FreeGroup X},\n  IsGroupHom f → Function.Injective f → Function.Surjective f",
   "some-correct": null,
   "prompt":
   "Every injective homomorphism from a finitely generated free group to itself is surjective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  {  X :  Type* } ->  [  Fintype  X ] ->  {  f :   FreeGroup  X →  FreeGroup  X } ->  (  hf :  IsGroupHom  f ) ->  (  hf_inj :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  (  f :   FreeGroup  α →  FreeGroup  α ) ->  (  hf :  IsGroupHom  f ) ->  (  h1 :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  {  β :  Type* } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  [  Groupₓ  β ] ->  (  f :  α → β ) ->  (  hf :  IsGroupHom  f ) ->  (  hfi :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  Fintype  α ] ->  [  DecidableEq  α ] ->  {  f :   FreeGroup  α →  FreeGroup  β } ->  (  hf :  IsGroupHom  f ) ->  (  hi :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  {  A :  Type  v } ->  [  Groupₓ  A ] ->  (  f :   FreeGroup  α → A ) ->  (  hf :  IsGroupHom  f ) ->  (  hfi :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  {  G :  FreeGroup  α } ->   Function.Injective  G →  Function.Surjective  G"]},
  {"theorem":
   "∀ (K : Type u) [inst : DivisionRing K], IsField K ∨ Module.Finite K K",
   "some-correct": null,
   "prompt": "Every division ring is either a field or finite.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->   IsField  K ∨  Module.Finite  K K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->   IsField  K ∨  Finite  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->   ¬  IsField  K ∨  Finite  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->   FiniteDimensional.finrank  K K ≤  2"]},
  {"theorem": "∀ (n : ℕ), ∃ a b, Nat.Prime a ∧ Nat.Prime b ∧ n = a * b",
   "some-correct": null,
   "prompt": "Every natural number is the product of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a * b",
    " (  n :  ℕ ) ->  ∃    (   p  p' :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  p' ∧  n =  p * p'",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m  p :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  m ∧  n =  m * p",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   n =  p * q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   p ≠ q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  m :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,    a * b = m ∧   Nat.Prime  a ∧  Nat.Prime  b",
    " (  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 :  ℕ } ->  ∃     p  q  :  ℕ ,   n =  p * q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " {  n :  ℕ } ->  (  hn :   0 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->   ¬  n =  0 →  ∃    (   p  q :  ℕ ) ,   Prime  p ∧   Prime  q ∧  n =  p * q",
    " {  n :  ℕ } ->  (  h :   0 < n ) ->  ∃    (   i  j :  ℕ ) ,   Nat.Prime  i ∧   Nat.Prime  j ∧   i * j = n",
    " (  n :  ℕ ) ->  ∃    (   p₁  p₂ :  ℕ ) ,   Nat.Prime  p₁ ∧   Nat.Prime  p₂ ∧  n =  p₁ * p₂",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   p₁  p₂ :  ℕ ) ,   n =  p₁ * p₂ ∧   Prime  p₁ ∧  Prime  p₂"]},
  {"theorem": "∀ {n : ℕ}, n % 2 = 0 → ∃ m, n = m ^ 2",
   "some-correct": null,
   "prompt": "Every even number is the square of a natural number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,  ∃    (   q :  ℤ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m * m",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   a :  ℕ ) ,  n =  a ^  2",
    " {  n :  ℕ } ->  (  Even :  Even  n ) ->  ∃    (   k :  ℕ ) ,  n =  k * k",
    " {  a :  ℤ } ->  (  h :   2 ∣ a ) ->  ∃    (   b :  ℕ ) ,  a =  b * b",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->   Even  n →  ∃    (   a :  ℕ ) ,   a ^  2 = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   a :  ℕ ) ,   a ^  2 = n",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,   m * m = n"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : UniformSpace α] {β : Type u_2} [inst_1 : UniformSpace β] (f : α → β),\n  Continuous f → UniformContinuous f",
   "some-correct": null,
   "prompt": "Every continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  UniformSpace  α ] ->  {  β :  Type  u_2 } ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  h :  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  β ] ->  (  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.16689747 hf)",
   "some-correct": null,
   "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 α), IsCompact s → IsClosed s) → CompactSpace α",
   "some-correct": null,
   "prompt":
   "If every compact subset of a topological space is closed, then the space is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  H :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  CompactSpace  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hs :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  CompactSpace  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hK :  ∀  K   :  Set  α ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀  s  ,   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  α } ->  (  hs :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->   IsCompact  α ↔  IsClosed  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : CommRing α] {a b : α}, a * a = a → b * b = b → a + b = a + b * b",
   "some-correct": null,
   "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 * b",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->   a + b =  a +  b * b",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  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 : α } ->  (  ha :   a ^  2 = a ) ->  (  hb :   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 } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h1 :   a ^  2 = a ) ->  (  h2 :   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 } ->  {  a b : α } ->  [  CommRing  α ] ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  {  a b : α } ->  [  CommRingₓ  α ] ->  (  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ₓ  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  a + b",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a b : α } ->  (  ab_idem :   a * a = a ) ->  (  bc_idem :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  (   a + b  )",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  ab_idem :   a * a = a ) ->  (  bc_idem :   b * b = b ) ->    (   a + b  ) *  (   a + b  ) =  (   a + b  )",
    " {  α :  Type  u_1 } ->  [  CommRing  α ] ->  {  a b : α } ->  (  h₁ :   a ^  2 = a ) ->  (  h₂ :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  a + b",
    " {  α :  Type  u_1 } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  h₁ :   a ^  2 = a ) ->  (  h₂ :   b ^  2 = b ) ->    (   a + b  ) ^  2 =  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  α ] ->  {  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 : α } ->  (  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"]},
  {"theorem":
   "∀ {n : ℕ}, 1 < n → Nat.Prime (Fintype.card { p // Finset.card p ≤ 2 })",
   "some-correct": null,
   "prompt": "The number of partitions of a finite set is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :   1 < n ) ->  Nat.Prime   (   Fintype.card   { p  :  Finset   (   Finₓ  n  ) //  p.card ≤  2 }  )",
    " (  n :  ℕ ) ->  Nat.Prime   (   Fintype.card   { s  :  Finset   (   Finₓ  n  ) //  s.card ≤  2 }  )"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : ConditionallyCompleteLinearOrder α] [inst_1 : Nonempty α] [inst_2 : NoBotOrder α],\n  ExistsUnique fun a => IsTop a",
   "some-correct": null,
   "prompt":
   "If a poset has a maximal element, then it has a unique minimal element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  ConditionallyCompleteLinearOrder  α ] ->  [  Nonempty  α ] ->  [  NoBotOrder  α ] ->  ∃!    (   a : α ) ,  IsTop  a",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  [  NoBotOrder  α ] ->  [  HasTop  α ] ->  {  m : α } ->  (  hm :  IsTop  m ) ->  ∃!    (   x : α ) ,  IsBot  x",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  [  NoBotOrder  α ] ->  [  HasTop  α ] ->  {  m : α } ->  (  hm :  IsTop  m ) ->  ∃!    (   x : α ) ,  IsBot  x",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  {  h :  ∃    (   x : α ) ,  ∀   (  y  : α  )  ,  x ≤ y } ->  ∃!    (   m : α ) ,  ∀   (  x  : α  )  ,  m ≤ x",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  {  h :  ∃    (   x : α ) ,  ∀   (  y  : α  )  ,  x ≤ y } ->  ∃!    (   m : α ) ,  ∀   (  x  : α  )  ,  m ≤ x",
    " {  α :  Type  u_1 } ->  [  PartialOrder  α ] ->  (  h :  ∃     m  ,  ∀  a  ,  m ≤ a ) ->  ∃!     min  : α ,  ∀  a  ,  min ≤ a",
    " {  α :  Type  u_1 } ->  [  PartialOrderₓ  α ] ->  (  h :  ∃     m  ,  ∀  a  ,  m ≤ a ) ->  ∃!     min  : α ,  ∀  a  ,  min ≤ a"]},
  {"theorem":
   "∀ {f : Unit → Unit}, Function.IsFixedPt f 0 → ∀ {n : ℕ}, 0 < n → ∃ x, Function.IsPeriodicPt f n x",
   "some-correct": null,
   "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 :  Unit → Unit } ->  (  hf :  Function.IsFixedPt  f  (   0   : Unit ) ) ->  ∀   {  n  :  ℕ }  ,    0 < n →  ∃     x  : Unit ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  [  One  α ] ->  [  Mul  α ] ->  [  Inv  α ] ->  (  f :  α → α ) ->  (  hx :  Function.IsFixedPt  f  1 ) ->  ∀  n   :  ℕ ,    0 < n →  ∃     x  : α ,  Function.IsPeriodicPt  f n x"]},
  {"theorem":
   "{K : Type u} →\n  {V : Type v} → [inst : Ringₓ K] → [inst_1 : AddCommGroupₓ V] → [inst_2 : Module K V] → Module.Free K V → CommRing K",
   "some-correct": null,
   "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 ] ->  (  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_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 } ->  [  CommRingₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  h :  Module.Free  R M ) ->  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  CommRingₓ  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 ] ->  (  hf :  Module.Free  R M ) ->  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  hf :  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",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Module.Free  K V ] ->  (  ι :  Type  u_1 ) ->  CommRing  K",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  Ringₓ  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Module.Free  K V ] ->  (  ι :  Type  u_1 ) ->  CommRingₓ  K",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  hm :  Module.Free  R M ) ->  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  hm :  Module.Free  R M ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  (  M :  Type  v ) ->  [  CommRingₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  Commutative  R"]},
  {"theorem":
   "{α : Type u} → [inst : Monoidₓ α] → Group (Units α) → CommRing α",
   "some-correct": null,
   "prompt":
   "If the set of units of a ring forms a group then the ring is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  h :  Group   (   Units  α  ) ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  h :  Group   (   Units  α  ) ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  h :  Groupₓ   (   Units  α  ) ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  (  h :  Groupₓ   (   Units  α  ) ) ->  CommRingₓ  α",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->   Group   (   Units  R  ) →  CommRing  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->   Group   (   Units  R  ) →  CommRingₓ  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->   Groupₓ   (   Units  R  ) →  CommRing  R",
    " (  R :  Type  u ) ->  [  CommRingₓ  R ] ->   Groupₓ   (   Units  R  ) →  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  G :  AddCommGroup   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  G :  AddCommGroup   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  G :  AddCommGroupₓ   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  G :  AddCommGroupₓ   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  [  One  R ] ->  [  Ringₓ  R ] ->  (  hunits :  IsSubgroup   (   Units  R  ) ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  [  One  R ] ->  [  Ringₓ  R ] ->  (  hunits :  IsSubgroup   (   Units  R  ) ) ->  CommRingₓ  R",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Monoid   (   Units  α  ) ] ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Monoid   (   Units  α  ) ] ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Monoidₓ   (   Units  α  ) ] ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Monoidₓ   (   Units  α  ) ] ->  CommRingₓ  α",
    " {  α :  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  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_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 ] ->  [  Group   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  CommRingₓ  R",
    " (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRing  R",
    " (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  CommRingₓ  R"]},
  {"theorem": "∀ (n : ℕ), 10 < n → ∃ m p, m ^ 2 + p = n ∧ Nat.Prime p",
   "some-correct": null,
   "prompt":
   "Every natural number larger than `10` is the sum of a square and a prime.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃    (   m  p :  ℕ ) ,     m ^  2 + p = n ∧  Nat.Prime  p",
    " {  m :  ℕ } ->  (  h :  m >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a * a + b = m ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->   n >  10 →  ∃    (   a :  ℕ )  (   p :  ℕ ) ,   Nat.Prime  p ∧    a * a + p = n",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃    (   p :  ℕ )  (   q :  ℕ ) ,    0 < q ∧     q ^  2 + p = n ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :   10 < n ) ->  ∃    (   a :  ℕ )  (   b :  ℕ ) ,     a ^  2 + b = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  h0 :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a :  ℕ ) ,  ∃    (   p :  ℕ ) ,     a * a + p = n ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  hn :   10 < n ) ->  ∃    (   a :  ℕ ) ,  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧    a * a + p = n",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a * a + b = n ∧  Nat.Prime  b",
    " {  m :  ℕ } ->  (  hm :   11 ≤ m ) ->  ∃    (   p :  ℕ )  (   a  b :  ℕ ) ,     a ^  2 + p = m ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   r  s  p :  ℕ ) ,     r * r + p = n ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,    (    a * a + b  ) = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   n =   a * a + b ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  b ∧    a * a + b = n",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃    (   p :  ℕ )  (   q :  ℕ ) ,   n =   p * p + q ∧  Nat.Prime  q",
    " {  n :  ℕ } ->  {  H₁ :  n >  10 } ->  ∃    (   a  b :  ℕ ) ,     a * a +  b * b = n ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   k  p :  ℕ ) ,     k * k + p = n ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b  p :  ℕ ) ,     a * a + p = b ∧   Nat.Prime  p ∧  b = n"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type ?u.38892022} {γ : Type ?u.38892026} [inst : TopologicalSpace α] [inst_1 : TopologicalSpace β]\n  [inst_2 : TopologicalSpace γ] (f : α → β) (g : β → γ), Continuous (g ∘ f) → Continuous f",
   "some-correct": null,
   "prompt":
   "If the composition of two functions is continuous, then each of them is continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type* } ->  {  γ :  Type* } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  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",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  h :  Continuous   (   Function.comp  f g  ) ) ->  Continuous  f",
    " {  α :  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  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  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 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  hgf :  Continuous   (   g ∘ f  ) ) ->  (  hg :  Continuous  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 } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  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  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  α → β } ->  {  f :  β → γ } ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  β → γ } ->  {  g :  α → β } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  g",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g"]},
  {"theorem":
   "∀ {S : Type u_1} [inst : Semigroup S] {a b c : S}, Commute a b → Commute b c → Commute a c",
   "some-correct": null,
   "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 } ->  [  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 } ->  [  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 } ->  [  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 } ->  [  AddMonoid  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  AddMonoidₓ  S ] ->  {  a b c : S } ->  (  hab :  AddCommute  a b ) ->  (  hbc :  AddCommute  b c ) ->  AddCommute  a c",
    " {  S :  Type  u_1 } ->  [  CommMonoid  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommMonoidₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  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"]},
  {"theorem":
   "∀ {α : Type u} {β : Type v} [inst : Ringₓ α] [inst_1 : CommRingₓ β] {f : α → β} {x : α}, IsRingHom f → f x = 0 → x = 0",
   "some-correct": null,
   "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ₓ  α ] ->  [  CommRingₓ  β ] ->  {  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 ) ->  {  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 ) ->  (  hfx0 :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  CommRingₓ  α ] ->  [  CommRingₓ  β ] ->  {  f :  α → β } ->  {  a : α } ->  (  hf :  IsRingHom  f ) ->  (  h :   (   f  a  ) =  0 ) ->  a =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  {  x : α } ->    f  x =  0 →  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  CommRingₓ  α ] ->  [  CommRingₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  hfx :   f  x =  0 ) ->  x =  0"]},
  {"theorem": "∀ {p q : Prop}, Implies p q → Implies q p",
   "some-correct": null,
   "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 :  p ↔ q ) ->  q ↔ p",
    " {  P Q :  Prop } ->   Implies  P Q →  Implies  Q P",
    " {  P Q :  Prop } ->  (  h :  P → Q ) ->  Q → P"]},
  {"theorem": "∀ {n m : ℕ}, n = m ↔ ∃ p, Nat.Prime p ∧ p ∣ n ∧ p ∣ m",
   "some-correct": null,
   "prompt":
   "Two natural numbers are equal if and only if they are both divisible by some prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n m :  ℕ } ->   n = m ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ n ∧  p ∣ m",
    " {  m n :  ℕ } ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " {  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",
    " {  m n :  ℕ } ->  (  m0 :  m ≠  0 ) ->  (  n0 :  n ≠  0 ) ->   m = n ↔  ∃    (   pr :  ℕ ) ,   Nat.Prime  pr ∧   pr ∣ m ∧  pr ∣ n",
    " {  x y :  ℕ } ->  (  hx :  x ≠  0 ) ->  (  hy :  y ≠  0 ) ->   x = y ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ x ∧  p ∣ y",
    " {  a b :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ a ∧  p ∣ b  ) ↔  a = b",
    " {  m n :  ℕ } ->   m = n ↔  ∃     p  :  ℕ ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " {  a b :  ℕ } ->   a = b ↔  ∃    (   p :  ℕ ) ,   p ∣ a ∧   p ∣ b ∧  Nat.Prime  p",
    " {  m n :  ℕ } ->   m = n ↔  (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   m ∣ p ∧  n ∣ p  )"]}],
 "elaborated": 29}