{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 20,
 "number-similar-sentences": 12,
 "number-keyword-sentences": 8,
 "include-fixed": false,
 "failures":
 ["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.",
  "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 initial object of a category is isomorphic to its terminal object."],
 "elaborated-prompts":
 [{"theorem": "∀ {R : Type u} [inst : Ringₓ R], IsField R",
   "some-correct": null,
   "prompt": "Every ring is a field.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u } ->  [  Ringₓ  R ] ->  IsField  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  IsField  R",
    " (  R :  Type  u ) ->  [  Ring  R ] ->  Nonempty   (   Field  R  )",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  Nonempty   (   Field  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,
   "prompt": "Every vector space is finite dimensional.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  {  V :  Type  v } ->  [  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 } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  [  Fintype  K ] ->  [  DecidableEq  V ] ->  FiniteDimensional  K V",
    " {  K :  Type  u } ->  {  V :  Type  v } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  (  KV :  Type  w ) ->  [  Inhabited  KV ] ->  FiniteDimensional  K V",
    " {  K :  Type  u_1 } ->  {  V :  Type  u_2 } ->  [  DivisionRing  K ] ->  [  AddCommGroupₓ  V ] ->  [  Module  K V ] ->  FiniteDimensional  K V",
    " {  V :  Type  u_1 } ->  [  Field  V ] ->  FiniteDimensional  V V"]},
  {"theorem": "∀ {G : Type u_1} [inst : CommGroupₓ G], Monoidₓ.IsTorsion G",
   "some-correct": null,
   "prompt": "Every group is a torsion monoid.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  CommGroupₓ  G ] ->  Monoidₓ.IsTorsion  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G",
    " (  G :  Type  u_1 ) ->  [  Groupₓ  G ] ->  Monoidₓ.IsTorsion  G"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] [inst_1 : Fintype G], IsSimpleGroup G → IsPrimePow (Fintype.card G)",
   "some-correct": true,
   "prompt": "Every finite simple group has prime order.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  IsPrimePow   (   Fintype.card  G  )",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃    (   p :  ℕ ) ,    Fintype.card  G = p ∧  Nat.Prime  p",
    " {  α :  Type  u_1 } ->  [  Fintype  α ] ->  [  Groupₓ  α ] ->  (  h :  IsSimpleGroup  α ) ->  ∃     p  ,    Fintype.card  α = p ∧  Fact   (   Nat.Prime  p  )",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  h :  IsSimpleGroup  α ) ->  ∃    (   p :  ℕ ) ,   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",
    " {  α :  Type  u_1 } ->  [  Fintype  α ] ->  [  Groupₓ  α ] ->  (  h :  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_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hsimple :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u_1 } ->  [ hG :  Groupₓ  G ] ->  [ hf :  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  IsPrimePow   (   Fintype.card  G  )",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  IsSimpleGroup  G ) ->  ∃     p  :  ℕ ,   (   Nat.Prime  p  ) ∧  (    Fintype.card  G = p  )",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  h :  IsSimpleGroup  α ) ->  ∃     p  ,    Fintype.card  α = p ∧  Nat.Prime  p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  h :  IsSimpleGroup  α ) ->  ∃    (   p :  ℕ ) ,   Prime  p ∧   Fintype.card  α = p"]},
  {"theorem":
   "∀ {G : Type u} [inst : Groupₓ G] [inst_1 : Fintype G], IsSimpleGroup G",
   "some-correct": null,
   "prompt": "Every finite group is simple.",
   "correct": true,
   "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  α",
    " {  G :  Type  u } ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  IsSimpleGroup  G",
    " {  G :  Type  u } ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  IsSimpleGroup  G",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  IsSimpleGroup  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : Group α] [inst : Fintype α], Fintype.card α ≠ 0 → ∃ p, Fact (Nat.Prime p) ∧ Fintype.card α = p",
   "some-correct": null,
   "prompt": "Every finite group has prime order.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  (  h :   Fintype.card  α ≠  0 ) ->  ∃     p  ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  α = p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  (  h :   Fintype.card  α ≠  0 ) ->  ∃     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",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p  hp :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   p ∣  Fintype.card  G ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p  hp :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   p ∣  Fintype.card  G ∧   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  ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,    ↑ p =  Fintype.card  α ∧  Nat.Prime  p",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  ∃    (   p :  ℕ ) ,    ↑ p =  Fintype.card  α ∧  Nat.Prime  p",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃    (   p :  ℕ ) ,   Fact   (   Nat.Prime  p  ) ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  ∃     p  ,   Prime  p ∧   Fintype.card  G = p",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∃     p  ,   Prime  p ∧   Fintype.card  G = p",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  Nat.Prime   (   Fintype.card  α  )",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  Prime   (   Fintype.card  α  )",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  Prime   (   Fintype.card  α  )",
    " {  G :  Type  u } ->  [  Group  G ] ->  [  Fintype  G ] ->  Prime   (   Fintype.card  G  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  Prime   (   Fintype.card  G  )",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  ∀   (  p  :  ℕ  )  ,    p ∣  Fintype.card  G →  (   ∃    (   g : G ) ,   orderOf  g = p  ) ↔  (   ∃    (   g : G ) ,   orderOf  g =  Fintype.card  G  )",
    " {  α :  Type  u } ->  [  Group  α ] ->  [  Fintype  α ] ->  IsPrimePow   (   Fintype.card  α  )",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  [  Fintype  α ] ->  IsPrimePow   (   Fintype.card  α  )"]},
  {"theorem":
   "∀ {α : Type u_1} {m : MeasureTheory.MeasureSpace α} (s : Set α), coeFn MeasureTheory.volume.toOuterMeasure s = 0",
   "some-correct": null,
   "prompt": "Every set has Lebesgue measure zero.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  {  s :  Set  α } ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  {  s :  Set  α } ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->   MeasureTheory.MeasureSpace.volume   (   Set  α  ) =  0",
    " {  α :  Type  u_1 } ->  ∀   (  s  :  Set  α  )  ,   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  {  m :  MeasurableSpace  α } ->  (  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  s =  0",
    " {  α :  Type  u } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  {  m :  MeasurableSpace  α } ->  (  s :  Set  α ) ->   MeasureTheory.MeasureSpace.volume  s =  0",
    " {  α :  Type  u_1 } ->  [  MeasurableSpace  α ] ->  (  s :  Set  α ) ->   (   MeasureTheory.MeasureSpace.volume  s  ) =  0",
    " {  α :  Type  u_1 } ->  {  m :  MeasureTheory.MeasureSpace  α } ->  (  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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  IsCompact  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  IsCompact  α ) ->  IsCompact  s",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  ∀  s   :  Set  X ,  IsCompact  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  ∀  s  ,  IsCompact   (  s   :  Set  α )",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  [  CompactSpace  X ] ->  (  s :  Set  X ) ->  IsCompact  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  (  h :  CompactSpace  α ) ->  ∀  s  ,  IsCompact  s"]},
  {"theorem":
   "∀ {α : Type u} [inst : MeasurableSpace α] {s : Set α},\n  0 < coeFn MeasureTheory.volume.toOuterMeasure s → ¬MeasurableSet s → coeFn MeasureTheory.volume.toOuterMeasure s = 0",
   "some-correct": false,
   "prompt":
   "Every set that is Lebesgue measurable but not Borel measurable has Lebesgue measure zero.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  MeasurableSpace  α ] ->  {  s :  Set  α } ->  (  hs :   0 <  MeasureTheory.MeasureSpace.volume  s ) ->  (  h :  ¬  MeasurableSet  s ) ->   MeasureTheory.MeasureSpace.volume  s =  0"]},
  {"theorem":
   "{G : Type u} → [inst : Groupₓ G] → [hN : Nontrivial G] → Monoidₓ.Fg G → Monoidₓ.IsTorsion G → Fintype G",
   "some-correct": false,
   "prompt":
   "A finitely-presented group containing a torsion element is finite.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  Groupₓ  G ] ->  [ hN :  Nontrivial  G ] ->   Monoidₓ.Fg  G →   Monoidₓ.IsTorsion  G →  Fintype  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  Monoidₓ.Fg  G ) ->   Monoidₓ.IsTorsion  G →  Fintype  G",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  h :  Monoidₓ.IsTorsion  G ) ->  (  hg :  Groupₓ.Fg  G ) ->  Fintype  G",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [ hN :  Nontrivial  G ] ->  [  Fintype   (   G /  1  ) ] ->   Monoidₓ.IsTorsion  G →  Fintype  G"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α}, (∀ (x : α), x ∈ s → ∃ K, IsClosed K ∧ x ∈ K) → 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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     K  :  Set  α ,   IsClosed  K ∧  x ∈ K ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  S T :  Set  α } ->  (  hS :  ∀   (  x  : α  )  ,   x ∈ S →  ∃    (   C :  Set  α ) ,   IsClosed  C ∧   x ∈ C ∧  C ⊆ T ) ->  IsClosed  S",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :  ∀   (  x  : X  )  ,   x ∈ s →  ∃    (   C :  Set  X ) ,   IsClosed  C ∧  x ∈ C ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ t →  ∃    (   s' :  Set  α ) ,   x ∈ s' ∧  IsClosed  s' ) ->  t ⊆  Closure  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ t ,  ∃     u  :  Set  α ,   IsClosed  u ∧  x ∈ u ) ->  (  hst :  s ⊆ 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  : α  )  (  hs  :  x ∈ s  )  ,  ∃    (   c :  Set  α ) ,   IsClosed  c ∧   x ∈ c ∧  c ⊆ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀  x  ,   x ∈ s →  ∃     t  ,   IsClosed  t ∧  x ∈ t ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->   (   ∀  x  ∈ s ,  ∃     t  :  Set  α ,   IsClosed  t ∧  x ∈ t  ) →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α )  (   ht :  IsClosed  t ) ,   x ∈ t ∧  t ⊆ s ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  ht :  IsClosed  t ) ->  (  hs :  t ⊆ s ) ->  (  hxs :  ∀  x   : α ,   x ∈ s →  ∃     s  ,   IsClosed  s ∧   x ∈ s ∧  s ⊆ s ) ->  IsClosed  s",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  {  A :  Set  X } ->  (  hA :  ∀   (  x  : X  )  ,   x ∈ A →  ∃    (   F :  Set  X ) ,   x ∈ F ∧  IsClosed  F ) ->  IsClosed  A"]},
  {"theorem":
   "∀ {X : Type u} {Y : Type v} [inst : TopologicalSpace X] [inst_1 : TopologicalSpace Y],\n  (IsOpenMap fun x => (x, x)) ↔ T2Space X",
   "some-correct": null,
   "prompt":
   "A topological space $X$ is Hausdorff if and only if the diagonal map is an open map from $X$ to $X × X$.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->   IsOpenMap   (   λ   ( x : α ) ,  (  x   ,  x )  ) ↔  T2Space  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->   IsOpenMap   (   λ x ,  (  x   ,  x )  ) ↔  T2Space  α",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->   T2Space  X ↔  IsOpenMap   (   λ x ,  (  x   ,  x )  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->   T2Space  α ↔  IsOpenMap   (   λ   ( x : α ) ,  (  x   ,  x )  )",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->   T2Space  X ↔  IsOpenMap   (   λ   ( a : X ) ,  (  a   ,  a )  )",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->   IsOpenMap   (   λ   ( x : X ) ,  (  x   ,  x )  ) ↔  T2Space  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->   T2Space  α ↔  IsOpenMap   (   λ x ,  (  x   ,  x )  )",
    " {  X :  Type  u } ->  {  Y :  Type  v } ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->   IsOpenMap   (   λ x : Y ,  (  x   ,  x )  ) ↔  T2Space  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->   T2Space  α ↔  IsOpenMap   (   λ a : α ,  (  a   ,  a )  )",
    " {  X :  Type  u_1 } ->  [  TopologicalSpace  X ] ->   T2Space  X ↔  ∀   (  x  : X  )  ,  IsOpenMap   (   λ   ( x : X ) ,  (  x   ,  x )  )",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->   T2Space  X ↔  (   IsOpenMap   (   λ x : X ,  (  x   ,  x )  )  )"]},
  {"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": true,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->  (  hx :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->  (  h :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u_1 } ->  [  Fintype  G ] ->  [  Group  G ] ->  (  h :   Fintype.card  G <  2 ) ->  ∀   (  x  : G  )  ,  x =  1",
    " {  G :  Type  u_1 } ->  [  Fintype  G ] ->  [  Groupₓ  G ] ->  (  h :   Fintype.card  G <  2 ) ->  ∀   (  x  : G  )  ,  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->  [  Fintype  G ] ->  (  hx :  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",
    " {  α :  Type  u } ->  [  Groupₓ  α ] ->  {  g : α } ->  (  h :  IsOfFinOrder  g ) ->   (  g   : α ) =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->    orderOf  x =  0 ↔  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->  (  H :  IsOfFinOrder  x ) ->  x =  1",
    " {  G :  Type  u } ->  (  G :  Type  u ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  x : G ) ->   IsOfFinOrder  x →  x =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  {  x : G } ->   IsOfFinOrder  x →  x =  1"]},
  {"theorem":
   "∀ {α β : Type u} [inst : Fintype α] {f : FreeGroup α → FreeGroup β},\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": true,
   "comments": "",
   "all-elabs":
   [" {  α β :  Type  u } ->  [  Fintype  α ] ->  {  f :   FreeGroup  α →  FreeGroup  β } ->  (  hf :  IsGroupHom  f ) ->  (  H :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  {  f :   FreeGroup  α →  FreeGroup  α } ->  (  hf :  IsGroupHom  f ) ->  (  hi :  Function.Injective  f ) ->  Function.Surjective  f",
    " {  α :  Type  u_1 } ->  {  G :  Type  u_2 } ->  [  Groupₓ  G ] ->  [  Fintype  α ] ->  [  DecidableEq  G ] ->  (  f :   FreeGroup  α → G ) ->  (  hf :  IsGroupHom  f ) ->  (  hif :  Function.Injective  f ) ->  Function.Surjective  f"]},
  {"theorem": "∀ (K : Type u) [inst : DivisionRing K], IsField K ∨ Finite K",
   "some-correct": null,
   "prompt": "Every division ring is either a field or finite.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->   IsField  K ∨  Finite  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->   Finite  K ∨  IsField  K",
    " (  R :  Type  u ) ->  [  DivisionRing  R ] ->   IsField  R ∨  Finite  R",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->   IsField  K ∨  (   ∃    (   n :  ℕ ) ,   FiniteDimensional.finrank  K K = n  )",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->   IsField  K ∨  Finite  K"]},
  {"theorem":
   "∀ {n : ℕ}, 0 < n → ∃ p₁ p₂, Nat.Prime p₁ ∧ Nat.Prime p₂ ∧ p₁ * p₂ = n",
   "some-correct": null,
   "prompt": "Every natural number is the product of two primes.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :   0 < n ) ->  ∃    (   p₁  p₂ :  ℕ ) ,   Nat.Prime  p₁ ∧   Nat.Prime  p₂ ∧   p₁ * p₂ = n",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,    p * q = n ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " (  n :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a * b = n",
    " {  n :  ℕ } ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   m  p :  ℕ ) ,   n =  m * p ∧   Nat.Prime  m ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  ∃    (   p  q :  ℕ ) ,   n =  p * q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  (  h0 :  n ≠  0 ) ->  (  h1 :  n ≠  1 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p * q = n",
    " {  n :  ℕ } ->  (  npos :   0 < n ) ->  ∃    (   m  p :  ℕ ) ,   Nat.Prime  m ∧   Nat.Prime  p ∧   m * p = n",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   m  p :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  m ∧  n =  p * m",
    " (  n :  ℕ ) ->  (  h0 :   0 < n ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a * b",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p * q",
    " (  n :  ℕ ) ->  ∃    (   a  b :  ℕ ) ,   Prime  a ∧   Prime  b ∧   a * b = n"]},
  {"theorem": "∀ {n : ℕ}, n % 2 = 0 → ∃ m, n = m * m",
   "some-correct": null,
   "prompt": "Every even number is the square of a natural number.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  hn :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m * m",
    " {  n :  ℕ } ->   Even  n →  ∃    (   k :  ℕ ) ,  n =  k ^  2",
    " {  m :  ℕ } ->   Even  m →  ∃    (   n :  ℕ ) ,  m =  n ^  2",
    " (  n :  ℕ ) ->   Even  n →  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " (  n :  ℕ ) ->   Even  n →  ∃    (   c :  ℕ ) ,  n =  c ^  2",
    " {  n :  ℕ } ->  (  hn :  Even  n ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " {  n :  ℕ } ->   Even  n →  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " {  n :  ℕ } ->  (  h :  Even  n ) ->  ∃    (   m :  ℕ ) ,   m ^  2 = n",
    " (  n :  ℕ ) ->  (  hn :   n %  2 =  0 ) ->  ∃    (   t :  ℕ ) ,   t < n ∧   t ^  2 = n",
    " (  n :  ℕ ) ->   Even  n →  ∃    (   k :  ℕ ) ,  n =  k * k",
    " {  n :  ℕ } ->  (  hn :  Even  n ) ->  ∃    (   k :  ℕ ) ,  n =  k * k",
    " {  n :  ℕ } ->  (  h :   n %  2 =  0 ) ->  ∃    (   k :  ℕ ) ,  n =  k ^  2",
    " {  n :  ℕ } ->  (  hn :   n %  2 =  0 ) ->  ∃    (   k :  ℕ ) ,  n =  k ^  2",
    " {  n :  ℕ } ->  (  Even :   n %  2 =  0 ) ->  ∃    (   m :  ℕ ) ,  n =  m ^  2",
    " (  b :  ℕ ) ->   Even  b →  ∃    (   m :  ℕ ) ,  b =  m ^  2",
    " (  n :  ℕ ) ->   Even  n →  ∃    (   m :  ℕ ) ,   m ^  2 = n"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} [inst : UniformSpace α] [inst_1 : UniformSpace β] {f : α → β},\n  Continuous f → UniformContinuous f",
   "some-correct": null,
   "prompt": "Every continuous function is uniformly continuous.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  X :  Type  u_1 } ->  {  Y :  Type  u_2 } ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  {  f :  X → Y } ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  (  f :  α → β ) ->  (  hf :  Continuous  f ) ->  UniformContinuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  (  f :  Continuous  f ) ->  UniformContinuous  f",
    " {  X :  Type* } ->  {  Y :  Type* } ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  {  f :  X → Y } ->  (  h :  Continuous  f ) ->  UniformContinuous  f"]},
  {"theorem":
   "∀ {X : Type u} [inst : TopologicalSpace X] {K : Set X}, IsCompact K → IsClosed K → CompactSpace X",
   "some-correct": true,
   "prompt":
   "If every compact subset of a topological space is closed, then the space is compact.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  {  K :  Set  X } ->  (  hK :  IsCompact  K ) ->  (  hKc :  IsClosed  K ) ->  CompactSpace  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  (  hs  :  IsCompact  s  )  ,  IsClosed  s ) ->  CompactSpace  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  CompactSpace  α ] ->  {  s :  Set  α } ->  (  hs :  IsCompact  s ) ->  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  CompactSpace  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  K  :  Set  α  )  ,   IsCompact  K →  IsClosed  K ) ->  CompactSpace  α",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  hs :  ∀   (  K  :  Set  X  )  ,   IsCompact  K →  IsClosed  K ) ->   IsCompact  s →  IsClosed  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  K  :  Set  α  )  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  CompactSpace  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hcompact_closure :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s ) ->  CompactSpace  α",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  is_compact_of_closed :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s } ->  IsCompact  α",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  {  h :  ∀  s   :  Set  X ,   IsCompact  s →  IsClosed  s } ->  IsCompact  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  K  :  Set  α  )  ,   IsCompact  K ↔  IsClosed  K ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  K  :  Set  α  )  ,   IsCompact  K →  IsClosed  K ) ->  ∀   (  s  :  Set  α  )  ,  IsCompact  s",
    " {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  (  H :  ∀   (  K  :  Set  X  )  ,   IsCompact  K →  IsClosed  K ) ->  IsCompact  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  compact_is_closed :  ∀   (  s  :  Set  α  )  ,   IsCompact  s →  IsClosed  s } ->  IsCompact  α"]},
  {"theorem":
   "∀ {α : Type u} [inst : NonUnitalRing α] (a b : α), a = b * a → b = a * b → a + b = b",
   "some-correct": true,
   "prompt":
   "In a commutative ring, the sum of idempotent elements is idempotent.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  (  a b : α ) ->  (  h :  a =  b * a ) ->  (  h2 :  b =  a * b ) ->   a + b = 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",
    " {  R :  Type  u } ->  [  CommRing  R ] ->  {  x y : R } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  x y : R } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  α :  Type  u_1 } ->  [  CommRing  α ] ->  {  x y : α } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  α :  Type  u_1 } ->  [  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ₓ  α ] ->  {  x y : α } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  α :  Type  u_1 } ->  [  CommRing  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    a + b -  a * b =   a + b -  b * a",
    " {  α :  Type  u_1 } ->  [  CommRingₓ  α ] ->  {  a b : α } ->  (  ha :   a * a = a ) ->  (  hb :   b * b = b ) ->    a + b -  a * b =   a + b -  b * a",
    " {  α :  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 } ->  [  NonUnitalRing  α ] ->  {  x y : α } ->  (  hx :   x * x = x ) ->  (  hy :   y * y = y ) ->    (   x + y  ) *  (   x + y  ) =  x + y",
    " {  α :  Type  u } ->  [  NonUnitalRing  α ] ->  {  a b : α } ->  (  h :   a + b = a ) ->   a ^  2 = a",
    " {  α :  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"]},
  {"theorem":
   "∀ {n : ℕ} (p : Finset (Finset ℕ)), Finset.card p = 2 ^ (n - 1) → Nat.Prime n",
   "some-correct": null,
   "prompt": "The number of partitions of a finite set is a prime number.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  p :  Finset   (   Finset   ℕ  ) ) ->  (  hn :  p.card =   2 ^  (   n -  1  ) ) ->  Nat.Prime  n"]},
  {"theorem":
   "∀ {α : Type u} [inst : Preorder α] [inst_1 : NoMinOrder α] (a : α), IsMax a → Nonempty α",
   "some-correct": true,
   "prompt":
   "If a poset has a maximal element, then it has a unique minimal element.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Preorder  α ] ->  [  NoMinOrder  α ] ->  (  a : α ) ->  (  h :  IsMax  a ) ->  Nonempty  α",
    " {  α :  Type  u } ->  [  Preorderₓ  α ] ->  [  NoMinOrder  α ] ->  (  a : α ) ->  (  h :  IsMax  a ) ->  Nonempty  α",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  max :  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  a m →  r  a a ) ->  ∃!    (   i : α ) ,  ∀   (  a  : α  )  ,   r  i a →  r  a a",
    " {  α :  Type  u } ->  [  LinearOrder  α ] ->  [  Nonempty  α ] ->  (  max :  ∃    (   m : α ) ,  ¬  ∃    (   x : α ) ,  ¬  x ≤ m ) ->  ∃!    (   a : α ) ,  ∀   (  a'  : α  )  ,  a' ≤ a",
    " {  α :  Type  u } ->  [  LinearOrderₓ  α ] ->  [  Nonempty  α ] ->  (  max :  ∃    (   m : α ) ,  ¬  ∃    (   x : α ) ,  ¬  x ≤ m ) ->  ∃!    (   a : α ) ,  ∀   (  a'  : α  )  ,  a' ≤ a"]},
  {"theorem":
   "∀ {f : ℕ → ℕ}, Function.IsFixedPt f 0 → ∀ (n : ℕ), n ≠ 0 → ∃ 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": true,
   "comments": "",
   "all-elabs":
   [" {  f :   ℕ →  ℕ } ->  (  xf :  Function.IsFixedPt  f  0 ) ->  ∀   (  n  :  ℕ  )  ,   n ≠  0 →  ∃     x  ,  Function.IsPeriodicPt  f n x",
    " {  f :   ℕ →  ℕ } ->  (  hf :  Function.IsFixedPt  f  0 ) ->  (  n :  ℕ ) ->  (  hn :   0 < n ) ->  Function.IsPeriodicPt  f n  0",
    " {  f :   ℕ →  ℕ } ->  {  n :  ℕ } ->  (  hf :  ∃     x  ,   f  x = x ) ->  (  h :   0 < n ) ->  ∃     y  ,  Function.IsPeriodicPt  f n y",
    " {  f :   ℕ →  ℕ } ->  (  hf :   0 ≤  f   0 ) ->  (  h :  ∃     x  ,  x ≤  f  x ) ->  ∀  n  ,    0 < n →  ∃     x  ,   x ≤  f  x ∧  Function.IsPeriodicPt  f n x"]},
  {"theorem": "∀ (r : ℤ), IsSquare r → ∃ z, z ^ 2 = r",
   "some-correct": false,
   "prompt": "The square root of an rational number is rational.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" (  r :  ℤ ) ->   IsSquare  r →  ∃    (   z :  ℤ ) ,   z ^  2 = r"]},
  {"theorem":
   "{α : Type u} →\n  Type u_1 →\n    {β : Type v} →\n      [inst : Ringₓ α] → [inst_1 : AddCommGroupₓ β] → [inst_2 : Module α β] → [inst : Module.Free α β] → CommRing α",
   "some-correct": null,
   "prompt": "If a module over a ring is free, then the ring is commutative.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  (  ι :  Type  u_1 ) ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  AddCommGroupₓ  β ] ->  [  Module  α β ] ->  [  Module.Free  α β ] ->  CommRing  α",
    " {  α :  Type  u } ->  (  ι :  Type  u_1 ) ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  AddCommGroupₓ  β ] ->  [  Module  α β ] ->  [  Module.Free  α β ] ->  CommRingₓ  α",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRing  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->   Module.Free  R M →  CommRingₓ  R",
    " (  R :  Type  u ) ->  (  M :  Type  v ) ->  [  CommRingₓ  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 ] ->  [  Module.Free  R M ] ->  CommRingₓ  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  M :  Type  v ) ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  h :  Module.Free  R M ) ->  (  x y : R ) ->   x * y =  y * x",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  CommRingₓ  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 ] ->  [  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",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  {  ι :  Type  u_1 } ->  (  b :  Basis  ι R M ) ->  Commutative  R",
    " {  R :  Type  u } ->  {  M :  Type  v } ->  [  CommRingₓ  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 ] ->   Module.Free  R M →  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  {  M :  Type  u_2 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  h :  Module.Free  R M ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  {  M :  Type  u_2 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  M ] ->  [  Module  R M ] ->  (  h :  Module.Free  R M ) ->  CommRingₓ  R",
    " {  R :  Type  u_1 } ->  {  α :  Type  u_2 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  α ] ->  [  Module  R α ] ->  (  f :  FreeGroup  α ) ->  CommRing  R",
    " {  R :  Type  u_1 } ->  {  α :  Type  u_2 } ->  [  Ringₓ  R ] ->  [  AddCommGroupₓ  α ] ->  [  Module  R α ] ->  (  f :  FreeGroup  α ) ->  CommRingₓ  R"]},
  {"theorem":
   "{α : Type u} → [inst : Ringₓ α] → [inst : Group (Units α)] → CommRing α",
   "some-correct": null,
   "prompt":
   "If the set of units of a ring forms a group then the ring is commutative.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Group   (   Units  α  ) ] ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Group   (   Units  α  ) ] ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Groupₓ   (   Units  α  ) ] ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Groupₓ   (   Units  α  ) ] ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  Group   (   Units  α  ) ] ->  AddCommGroup  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  Group   (   Units  α  ) ] ->  AddCommGroupₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  Groupₓ   (   Units  α  ) ] ->  AddCommGroup  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  Groupₓ   (   Units  α  ) ] ->  AddCommGroupₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  Group   (   Units  α  ) ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  Group   (   Units  α  ) ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  Groupₓ   (   Units  α  ) ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  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  ι",
    " {  ι :  Type  u } ->  [  Ringₓ  ι ] ->  (  h :  Groupₓ   (   Units  ι  ) ) ->  CommRingₓ  ι",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  MulZeroClass  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  Group   (   Units  R  ) ] ->  MulZeroClassₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  MulZeroClass  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  Groupₓ   (   Units  R  ) ] ->  MulZeroClassₓ  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  g :  Units  R ) ->  (  h :  IsGroupHom  g ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  g :  Units  R ) ->  (  h :  IsGroupHom  g ) ->  CommRingₓ  R"]},
  {"theorem": "∀ {n : ℕ}, n > 10 → ∃ a b, a ^ 2 + b ^ 2 = n ∧ Nat.Prime b",
   "some-correct": null,
   "prompt":
   "Every natural number larger than `10` is the sum of a square and a prime.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   x  y :  ℕ ) ,     x ^  2 +  y ^  2 = n ∧  Nat.Prime  y",
    " (  n :  ℕ ) ->  (  hn :  n >  10 ) ->  ∃    (   x  p :  ℕ ) ,   Nat.Prime  p ∧    x * x + p = n",
    " {  n :  ℕ } ->  (  hn :   10 < n ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 + b = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->    10 < n →  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  h1 :  n >  10 ) ->  ∃     a  b  :  ℕ ,   n =   a * a + b ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,     a ^  2 +  b ^  2 = n ∧  Nat.Prime  b",
    " (  n :  ℕ ) ->  (  h :  n >  10 ) ->  ∃    (   m :  ℕ )  (   p :  ℕ ) ,   n =   m ^  2 + p ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   i  p :  ℕ ) ,   n =   i * i + p ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ )  (   hp :  Nat.Prime  b ) ,    a * a + b = n",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   p :  ℕ )  (   t :  ℕ ) ,   Nat.Prime  p ∧    t * t + p = n",
    " {  n :  ℕ } ->  (  h :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   n =   a * a + b ∧  Nat.Prime  b",
    " {  n :  ℕ } ->  (  hn :  n >  10 ) ->  ∃    (   a  b :  ℕ ) ,   n =   a * a + b ∧  Nat.Prime  b"]},
  {"theorem":
   "∀ {X : Type u_1} {Y : Type u_2} {Z : Type u_3} [inst : TopologicalSpace X] [inst_1 : TopologicalSpace Y]\n  [inst_2 : TopologicalSpace Z] {f : X → Y} {g : Y → Z}, Continuous f → Continuous g → Continuous (g ∘ f)",
   "some-correct": true,
   "prompt":
   "If the composition of two functions is continuous, then each of them is continuous.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  X :  Type  u_1 } ->  {  Y :  Type  u_2 } ->  {  Z :  Type  u_3 } ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  {  f :  X → Y } ->  {  g :  Y → Z } ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  Continuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  β → γ ) ->  (  g :  α → β ) ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  f ∧  Continuous  g",
    " {  α :  Type* } ->  {  β :  Type* } ->  {  γ :  Type* } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  g :  β → γ } ->  {  f :  α → β } ->  (  h :  Continuous   (   g ∘ f  ) ) ->   Continuous  g ∧  Continuous  f",
    " {  X Y Z :  Type* } ->  [  TopologicalSpace  X ] ->  [  TopologicalSpace  Y ] ->  [  TopologicalSpace  Z ] ->  (  f :  Y → Z ) ->  (  g :  X → Y ) ->  (  h :  Continuous   (   f ∘ g  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  hfg :  Continuous   (   g ∘ f  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  h :  Continuous   (   g ∘ f  ) ) ->  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_3 } ->  {  γ :  Type  u_5 } ->  [ tα :  TopologicalSpace  α ] ->  [ tβ :  TopologicalSpace  β ] ->  [ tγ :  TopologicalSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  Continuous  f ) ->  (  hg :  Continuous  g ) ->  Continuous   (   f ∘ g  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  (  f :  α → β ) ->  (  g :  β → γ ) ->   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 :  β → γ } ->  (  hgf :  Continuous   (   g ∘ f  ) ) ->  Continuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  h :  Continuous   (   λ x ,  f   (   g  x  )  ) ) ->  Continuous  f",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  TopologicalSpace  α ] ->  [  TopologicalSpace  β ] ->  [  TopologicalSpace  γ ] ->  {  r :  α → β } ->  {  s :  β → γ } ->  (  h :  Continuous   (   s ∘ r  ) ) ->   Continuous  r ∧  Continuous  s",
    " {  α :  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 :  β → γ } ->  (  hg :  Continuous  g ) ->  (  hf :  Continuous   (   g ∘ f  ) ) ->  Continuous  f"]},
  {"theorem":
   "∀ {S : Type u} [inst : CommGroup 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": true,
   "comments": "",
   "all-elabs":
   [" {  S :  Type  u } ->  [  CommGroup  S ] ->  {  a b c : S } ->  (  h1 :  Commute  a b ) ->  (  h2 :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u } ->  [  CommGroupₓ  S ] ->  {  a b c : S } ->  (  h1 :  Commute  a b ) ->  (  h2 :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Mul  S ] ->  {  a b c : S } ->  (  hac :  Commute  a c ) ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroup  S ] ->  {  a b c : S } ->  (  h1 :  Commute  a b ) ->  (  h2 :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  {  a b c : S } ->  (  h1 :  Commute  a b ) ->  (  h2 :  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 } ->  [  Group  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Groupₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Mul  S ] ->  {  a b c : S } ->  (  h1 :  Commute  a b ) ->  (  h2 :  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 } ->  [  CommMonoidₓ  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 } ->  (  hbc :  Commute  b c ) ->  (  hab :  Commute  a b ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  {  a b c : S } ->  (  hbc :  Commute  b c ) ->  (  hab :  Commute  a b ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroup  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Mul  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hbc :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommGroup  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hac :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  CommGroupₓ  S ] ->  {  a b c : S } ->  (  hab :  Commute  a b ) ->  (  hac :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroup  S ] ->  {  a b c : S } ->  (  h :  Commute  a b ) ->  (  hab :  Commute  b c ) ->  Commute  a c",
    " {  S :  Type  u_1 } ->  [  Semigroupₓ  S ] ->  {  a b c : S } ->  (  h :  Commute  a b ) ->  (  hab :  Commute  b c ) ->  Commute  a c"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} [inst : Ringₓ α] [inst_1 : Ringₓ β] {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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  {  x : α } ->  (  hf :  IsRingHom  f ) ->  (  hfx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  (  x : α ) ->  (  hx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  (  a : α ) ->    f  a =  0 →  a =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  {  x : α } ->  (  hx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type* } ->  {  β :  Type* } ->  [  CommRingₓ  α ] ->  [  CommRingₓ  β ] ->  (  f :  α → β ) ->  (  hf :  IsRingHom  f ) ->  (  x : α ) ->  (  hx :   f  x =  0 ) ->  x =  0",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  (  f :  α → β ) ->  (  H :  IsRingHom  f ) ->  {  x : α } ->    f  x =  0 →  x =  0",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  Ringₓ  α ] ->  [  Ringₓ  β ] ->  {  f :  α → β } ->  (  hf :  IsRingHom  f ) ->  (  a : α ) ->    f  a =  0 →  a =  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": true,
   "comments": "",
   "all-elabs":
   [" {  p q :  Prop } ->  (  h :  Implies  p q ) ->  Implies  q p",
    " {  P Q :  Prop } ->  (  h :  Implies  P Q ) ->  Implies  Q P",
    " {  p q :  Prop } ->   Implies  p q →  Implies  q p"]},
  {"theorem": "∀ (m n : ℕ), m = n ↔ ∃ p, Nat.Prime p ∧ p ∣ m ∧ p ∣ n",
   "some-correct": null,
   "prompt":
   "Two natural numbers are equal if and only if they are both divisible by some prime number.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" (  m n :  ℕ ) ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " (  m n :  ℕ ) ->   m = n ↔  ∃    (   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 ∧   m ∣ p ∧  n ∣ p  )",
    " {  p m n :  ℕ } ->   (   ∃     a  ,   Nat.Prime  a ∧   a ∣ m ∧  a ∣ n  ) ↔  m = 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 :  ℕ } ->   (   ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n  ) ↔  m = n",
    " {  m n :  ℕ } ->  (  hm :  m ≠  0 ) ->  (  hn :  n ≠  0 ) ->   m = n ↔  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧   p ∣ m ∧  p ∣ n",
    " {  m n :  ℕ } ->   (   ∀   (  p  :  ℕ  )  ,   Nat.Prime  p →  (    p ∣ m ↔  p ∣ n  )  ) ↔  m = n",
    " {  m n :  ℕ } ->   (   ∃    (   a :  ℕ ) ,   Nat.Prime  a ∧   a ∣ m ∧  a ∣ n  ) ↔  m = n",
    " {  n m :  ℕ } ->  (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (    (    n ∣ p ∧  m ∣ p  ) ↔  n = m  )"]}],
 "elaborated": 32}