{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["If every proper closed set of a topological space is compact, then the space itself is compact.",
  "A finite graph in which every pair of vertices have precisely one common neighbour contains a vertex that is adjacent to all other vertices.",
  "The number of partitions with odd parts is equal to the number of partitions with distinct parts.",
  "A group whose automorphism group is cyclic is Abelian.",
  "A topological space is normal if and only if any two disjoint closed subsets can be separated by a continuous function.",
  "The complement of the union of two sets is the intersection of their complements.",
  "Every index 2 subgroup of a group is normal.",
  "A finite torsion-free group is trivial",
  "The square root of an irrational number is irrational.",
  "In a finite commutative ring, all prime ideals are maximal.",
  "A topological space $X$ is Hausdorff if and only if the diagonal is a closed set in $X × X$."],
 "elaborated-prompts":
 [{"theorem":
   "∀ {p : ℕ} [inst : Fact (Nat.Prime p)], p % 4 = 1 → ∃ a b, a ^ 2 + b ^ 2 = p",
   "some-correct": null,
   "prompt":
   "Every prime that is `1` greater than a multiple of `4` can be expressed as the sum of two squares.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->    p %  4 =  1 →  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :  p =    (    (   p -  1  ) /  4  ) *  4 +  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp1 :    0 <  p %  4 ∧   p %  4 <  3 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " (  n :  ℕ ) ->  (  hn :   n %  4 =  1 ) ->  ∃    (   p :  ℕ ) ,    p %  4 =  1 ∧   n < p ∧   p <  n +  40 ∧  Nat.Prime  p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp4 :   p %  4 =  3 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  4 =   1 %  4 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h0 :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    0 ≤ a ∧    0 ≤ b ∧    a ^  2 +  b ^  2 = p"]},
  {"theorem":
   "∀ {a b c d e f : ℕ},\n  (∃ x y z w, a = x * x + y * y + z * z + w * w) →\n    (∃ x y z w, b = x * x + y * y + z * z + w * w) → ∃ x y z w, c * d = x * x + y * y + z * z + w * w",
   "some-correct": null,
   "prompt":
   "The product of two numbers, each of which is the sum of four squares, is itself a sum of four squares.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  a b c d e f :  ℕ } ->  (  ha :  ∃    (   x  y  z  w :  ℕ ) ,  a =     x * x +  y * y +  z * z +  w * w ) ->  (  hb :  ∃    (   x  y  z  w :  ℕ ) ,  b =     x * x +  y * y +  z * z +  w * w ) ->  ∃    (   x  y  z  w :  ℕ ) ,   c * d =     x * x +  y * y +  z * z +  w * w",
    " {  x y :  ℕ } ->  ∃    (   a  b  c  d :  ℕ ) ,    (   x =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2  ) ∧  (   y =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2  ) ↔  (   ∃    (   a1  b1  c1  d1 :  ℕ ) ,   x * y =     a1 ^  2 +  b1 ^  2 +  c1 ^  2 +  d1 ^  2  )"]},
  {"theorem":
   "{α : Type u} → [inst : Ring α] → (∀ (a : α), a * a = a) → CommRing α",
   "some-correct": null,
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommRingₓ  α"]},
  {"theorem": "∀ {n : ℕ}, ∃ p q, Nat.Prime p ∧ Nat.Prime q ∧ p = q + 2",
   "some-correct": null,
   "prompt":
   "There are infinitely many pairs of primes that differ exactly by `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   p ≠ q ∧   (    Nat.Prime  p ∧  Nat.Prime  q  ) ∧  (    q - p =  2  )",
    " ∀   {  n  :  ℕ }  ,  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  p =  q +  2",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∃    (   p  q :  ℕ ) ,   p < q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧   q - p =  2",
    " ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  q =  p +  2",
    " ∃    (   a  b :  ℕ )  (   h :   a +  2 = b ) ,   Nat.Prime  a ∧  Nat.Prime  b",
    " ∀  n  ,  ∃     p  ,  ∃     q  ,   n < p ∧   p < q ∧   q <  p +  2 ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   q = p.succ.succ ∧   Nat.Prime  q ∧  Nat.Prime  p",
    " ∃    (   p :  ℕ ) ,  ∀   (  q  :  ℕ  )  ,   q > p →     q %  2 =  0 ∨  Nat.Prime  q →    p +  2 = q ∨   p +  2 =  q +  2",
    " (  x :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  p =  q +  2",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,    p +  2 = q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∃    (   p  q :  ℕ ) ,   p ≠ q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧   q - p =  2"]},
  {"theorem":
   "(K : Type u) → [inst : DivisionRing K] → [inst : Fintype K] → Field K",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " {  R :  Type  u_1 } ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  IsField  R",
    " (  F :  Type  u ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  IsField  F",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fact   (   Finite  K  ) ] ->  [  DivisionRing  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  R :  Type  u ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  IsField  R",
    " {  K :  Type  u_1 } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K"]},
  {"theorem":
   "∀ {α : Sort u_1} {β : Sort u_2} {f : α → β},\n  Function.Injective f → ∀ {g : β → α}, Function.Injective g → ∃ h, Function.bijective h",
   "some-correct": null,
   "prompt":
   "If each of two types can be mapped injectively into the other, then there is a bijection between them.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Sort  u_1 } ->  {  β :  Sort  u_2 } ->  {  f :  α → β } ->  (  hf :  Function.Injective  f ) ->  {  g :  β → α } ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  (  f :  α → β ) ->  (  g :  β → α ) ->  (  h₁ :  Function.Injective  f ) ->  (  h₂ :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->   Function.bijective  f ∧  Function.bijective  g",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  (  hαβ :  ∀   (  f  :  α → β  )  ,  Function.Injective  f ) ->  (  hβα :  ∀   (  f  :  β → α  )  ,  Function.Injective  f ) ->  ∃    (   f :  α → β )  (   g :  β → α ) ,   Function.bijective  f ∧  Function.bijective  g"]},
  {"theorem":
   "∀ {α : Type u_1} {r : α → α → Prop},\n  (∀ (c : Set α) (a : IsChain r c), ∃ ub, ∀ (a : α), a ∈ c → r a ub) → Nonempty α → ∃ m, ∀ (a : α), r m a → r a m",
   "some-correct": null,
   "prompt":
   "Every non-empty poset in which every chain has an upper bound contains a maximal element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  (  hs :  Nonempty  α ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type* } ->  {  r :  α →  α →  Prop } ->  ∀   (  h₁  :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  )  )  (  Trans  :  ∀   {  a b c  : α }  ,   r  a b →   r  b c →  r  a c  )  ,   Nonempty  α →  (   ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m  )",
    " {  α :  Type  u } ->  [  Preorder  α ] ->  [  Nonempty  α ] ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u } ->  [  Preorderₓ  α ] ->  [  Nonempty  α ] ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} {γ : Type u_3} [inst : UniformSpace α] [inst_1 : UniformSpace β]\n  [inst_2 : UniformSpace γ] {f : α → β} {g : β → γ},\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  δ :  Type  u_3 } ->  {  p :  α → β } ->  {  q :  β → δ } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  δ ] ->  (  hq :  UniformContinuous  q ) ->  (  hp :  UniformContinuous  p ) ->  UniformContinuous   (   q ∘ p  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )",
    " {  X :  Type  u_1 } ->  {  Y :  Type  u_2 } ->  {  Z :  Type  u_3 } ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  {  f :  X → Y } ->  {  g :  Y → Z } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  {  F :  β → α } ->  {  hf :  UniformContinuous  f } ->  {  hF :  UniformContinuous  F } ->  UniformContinuous   (   F ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} {γ : Type u_3} [inst : UniformSpace α] [inst_1 : UniformSpace β]\n  [inst_2 : UniformSpace γ] {f : α → β} {g : β → γ},\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  δ :  Type  u_3 } ->  {  p :  α → β } ->  {  q :  β → δ } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  δ ] ->  (  hq :  UniformContinuous  q ) ->  (  hp :  UniformContinuous  p ) ->  UniformContinuous   (   q ∘ p  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )",
    " {  X :  Type  u_1 } ->  {  Y :  Type  u_2 } ->  {  Z :  Type  u_3 } ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  {  f :  X → Y } ->  {  g :  Y → Z } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  {  F :  β → α } ->  {  hf :  UniformContinuous  f } ->  {  hF :  UniformContinuous  F } ->  UniformContinuous   (   F ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ {α : Type u_1} {f : α → α} {x : α}, Function.IsPeriodicPt f 3 x → ∀ (m : ℕ), 0 < m → ∃ y, Function.IsPeriodicPt f m y",
   "some-correct": null,
   "prompt":
   "If a function from the unit interval to itself has a point of period three, then it has points of all positive periods.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  f :  α → α } ->  {  x : α } ->  (  h :  Function.IsPeriodicPt  f  3 x ) ->  ∀  m   :  ℕ ,    0 < m →  ∃     y  : α ,  Function.IsPeriodicPt  f m y",
    " {  f :   ℕ →  ℕ } ->  (  hf :  Function.IsPeriodicPt  f  3  (   0   :  ℕ ) ) ->  ∀  n   :  ℕ ,   n >  0 →  ∃     x  ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  {  f :  α → α } ->  {  x : α } ->  {  m :  ℕ } ->  (  hx :  Function.IsPeriodicPt  f  3 x ) ->  (  hm :   0 < m ) ->  Function.IsPeriodicPt  f m x"]},
  {"theorem":
   "∀ {C : Type u} [inst : CategoryTheory.Category C] [inst_1 : CategoryTheory.Limits.HasTerminal C] {T T' : C}\n  (HT : CategoryTheory.Limits.IsTerminal T),\n  CategoryTheory.Limits.IsTerminal T' → CategoryTheory.IsIso (CategoryTheory.Limits.IsTerminal.from HT T')",
   "some-correct": null,
   "prompt":
   "A terminal object in a category is unique up to unique isomorphism.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  C :  Type  u } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T T' : C } ->  (  HT :  CategoryTheory.Limits.IsTerminal  T ) ->  (  HT' :  CategoryTheory.Limits.IsTerminal  T' ) ->  CategoryTheory.IsIso   (   HT.from  T'  )",
    " {  C :  Type  u₁ } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T T' : C } ->  (  hT :  CategoryTheory.Limits.IsTerminal  T ) ->  (  hT' :  CategoryTheory.Limits.IsTerminal  T' ) ->  CategoryTheory.IsIso   (   hT.from  T'  )"]},
  {"theorem": "∀ {x y z : ℕ}, x > 0 → y > 0 → z > 0 → x ^ 3 + y ^ 3 ≠ z ^ 3",
   "some-correct": null,
   "prompt":
   "The sum of the cubes of two positive integers is never equal to the cube of a third integer.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  x y z :  ℕ } ->  (  hx :  x >  0 ) ->  (  hy :  y >  0 ) ->  (  hz :  z >  0 ) ->    x ^  3 +  y ^  3 ≠  z ^  3",
    " (  a b c :  ℕ ) ->    a ^  3 +  b ^  3 ≠  c ^  3",
    " {  m n :  ℕ } ->  (  h1 :  m ≠  1 ) ->  (  h2 :  n ≠  1 ) ->  ∀   {  k  :  ℕ }  ,    (    m ^  3 +  n ^  3  ) ^  3 ≠  k ^  3",
    " {  a b c :  ℕ } ->  (  cba :   c < b ∨   c = b ∨  c > b ) ->  (  h :    a ^  3 +  b ^  3 =  c ^  3 ) ->   b ^  3 ∣  a ^  3",
    " {  a b c :  ℕ } ->    a ^  3 +  b ^  3 ≠  c ^  3"]},
  {"theorem":
   "∀ {G : Type ?u.1353236} [inst : Group G], (∀ (g : G), g * g = 1) → ∀ (a b : G), a * b = b * a",
   "some-correct": null,
   "prompt":
   "If every element of a group `G` has order `2`, then every pair of elements of `G` commutes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type* } ->  [  Group  G ] ->  (  H :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type* } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g₁ g₂  : G  )  ,   g₁ * g₂ =  g₂ * g₁",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g₁ g₂  : G  )  ,   g₁ * g₂ =  g₂ * g₁",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  a  : G  )  ,   a * a =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  a  : G  )  ,   a * a =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  g  : G  )  ,   (   g * g  ) =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  g  : G  )  ,   (   g * g  ) =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  a  : G  )  ,   a * a =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  a  : G  )  ,   a * a =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  g  : G  )  ,   (   g * g  ) =  1 ) ->  (  a b : G ) ->   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  g  : G  )  ,   (   g * g  ) =  1 ) ->  (  a b : G ) ->   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a"]},
  {"theorem": "∀ {n : ℕ}, Even (n * (n + 1))",
   "some-correct": null,
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " {  n :  ℕ } ->  (  h :  n ≠  0 ) ->  Even   (   n *  (   n +  1  )  )",
    " {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " {  n :  ℕ } ->  Even   (    (   n +  1  ) * n  )",
    " {  n :  ℕ } ->   Even  n →  Even   (   n *  (   n +  1  )  )",
    " {  m n :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " {  m :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " ∀   (  n m  :  ℕ  )  ,  Even   (   n *  (   n +  1  )  )"]},
  {"theorem": "∀ (α : Type u_1), Monoidₓ.IsTorsionFree (FreeGroup α)",
   "some-correct": null,
   "prompt": "Every free group is torsion free.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type  u_1 ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u_1 } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u ) ->  [  DecidableEq  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u_1 ) ->  [  DecidableEq  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  ι :  Type  u_1 } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  ι  )"]},
  {"theorem": "∀ (n : ℕ), n > 1 → ∃ p, p ∣ n ∧ Nat.Prime p",
   "some-correct": null,
   "prompt":
   "Every natural number greater than `1` is divisible by a prime number. ",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   p ∣ n ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :   (   1   :  ℕ ) < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->    1 < n →  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  hn :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n"]},
  {"theorem":
   "(K : Type u) → [inst : DivisionRing K] → [inst : Fintype K] → Field K",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " {  R :  Type  u_1 } ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  IsField  R",
    " (  F :  Type  u ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  IsField  F",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fact   (   Finite  K  ) ] ->  [  DivisionRing  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  R :  Type  u ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  IsField  R",
    " {  K :  Type  u_1 } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α], Fintype α → IsCompact Set.Univ",
   "some-correct": null,
   "prompt": "Every finite topological space is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hfinite :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hfinty :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  f :  Fintype  α ) ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  f :  Finite  α ) ->  IsCompact  α"]},
  {"theorem":
   "∀ {α : Type u} {n : WithTop ℕ}, n ≠ 0 → Function.Surjective FreeGroup.of → Function.Injective FreeGroup.of",
   "some-correct": null,
   "prompt":
   "Every surjective homomorphism from a finitely generated free group to itself is injective.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  {  n :  WithTop   ℕ } ->  (  H :  n ≠  0 ) ->   Function.Surjective   (  FreeGroup.of  ) →  Function.Injective   (  FreeGroup.of  )"]},
  {"theorem":
   "∀ (n : ℕ), 0 < n → n % 2 = 0 → ∃ p q, n = p + q ∧ Nat.Prime p ∧ Nat.Prime q",
   "some-correct": null,
   "prompt":
   "Every positive even integer can be written as the sum of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h :   0 < n ) ->  (  h1 :   n %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   n =  p + q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   p  q  m :  ℕ ) ,   n =  p + q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧    0 < m ∧  n =   p + m + q",
    " {  n :  ℕ } ->  (  hpos :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->  (  hn :   1 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  k :  ℕ ) ->  (  hpos :   0 < k ) ->  (  heven :   k %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  k =  p + q",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " {  n :  ℕ } ->  (  h :   0 < n ) ->  (  he :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  (    (    a + b = n  ) ∨  (    b + a = n  )  )",
    " (  n :  ℕ ) ->     0 < n ∧   n %  2 =  0 →  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->     0 < n ∧   n %  2 =  0 →  ∃    (   x  y :  ℕ ) ,   x ≠ y ∧   Nat.Prime  x ∧   Nat.Prime  y ∧   x + y = n"]},
  {"theorem":
   "∀ {R : Type u} [inst : CommRingₓ R] {n : Type w} [inst_1 : DecidableEq n] [inst_2 : Fintype n] (M : Matrix n n R),\n  AlgHom.toFun (Polynomial.aeval M) (Matrix.charpoly M) = 0",
   "some-correct": null,
   "prompt": "Every matrix satisfies its own characteristic polynomial.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  n :  Type  w } ->  [  DecidableEq  n ] ->  [  Fintype  n ] ->  (  M :  Matrix  n n R ) ->  ⇑    (   Polynomial.aeval  M  )  M.charpoly =  0"]},
  {"theorem": "∀ {n : ℕ}, n * n % 2 = 0 → n % 2 = 0",
   "some-correct": null,
   "prompt": "If the square of a number is even, the number itself is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :    n * n %  2 =  0 ) ->   n %  2 =  0",
    " {  α :  Type  u } ->  [  LinearOrderedCommRing  α ] ->  {  x : α } ->  (  hx :  Even   (   x * x  ) ) ->  Even  x",
    " {  n :  ℕ } ->  (  hn :  Even   (   n ^  2  ) ) ->  Even  n",
    " {  n :  ℕ } ->  (  hn2pos :   0 <  2 ) ->  (  h :  Even   (   n * n  ) ) ->  Even  n",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  a : α } ->   Even   (   a * a  ) →  Even  a",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  x : α } ->   Even   (   x * x  ) →  Even  x",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  x : α } ->     x * x %  2 =  0 →   x %  2 =  0",
    " {  α :  Type  u } ->  [  Ring  α ] ->  {  x : α } ->  (  h :    x * x %  2 =  0 ) ->   x %  2 =  0",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  {  x : α } ->  (  h :    x * x %  2 =  0 ) ->   x %  2 =  0",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a : α } ->  (  hA :  Even   (   a * a  ) ) ->  Even  a",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a : α } ->  (  hA :  Even   (   a * a  ) ) ->  Even  a",
    " {  n :  ℕ } ->   Even   (   n * n  ) →  Even  n",
    " {  n :  ℕ } ->  (  h :  Even   (   n * n  ) ) ->  Even  n",
    " {  n :  ℕ } ->     (   n ^  2  ) %  2 =  0 →   n %  2 =  0",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  x : α } ->  (  h :  Even   (   x ^  2  ) ) ->   x %  2 =  0",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  x : α } ->  (  h :  Even   (   x ^  2  ) ) ->   x %  2 =  0"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α}, (∀ (x : α), x ∈ s → ∃ u, IsOpen u ∧ x ∈ u) → IsOpen s",
   "some-correct": null,
   "prompt":
   "If every point of a subset of a topological space is contained in some open set, the subset itself is open.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  X :  Type  u } ->  [  TopologicalSpace  X ] ->  {  s :  Set  X } ->  (  h :  ∀  x  ∈ s ,  ∃  t  ∈ Set.Univ ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃    (   u :  Set  α ) ,   IsOpen  u ∧  x ∈ u ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h1 :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   U :  Set  α ) ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x   : α ,   x ∈ s →  ∃     t  :  Set  α ,   (   IsOpen  t  ) ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  {  x : α } ->  (  hxs :  ∀  x  ∈ s ,  ∃    (   u :  Set  α ) ,   IsOpen  u ∧  x ∈ u ) ->  IsOpen  s",
    " {  α :  Type  u } ->  {  s t :  Set  α } ->  [  TopologicalSpace  α ] ->  (  ht :  t ⊆ s ) ->  (  hs :  ∀  x  ∈ s ,  ∃     u  ,   IsOpen  u ∧  x ∈ u ) ->  IsOpen  t",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  a  ∈ s ,  ∃    (   U :  Set  α ) ,   IsOpen  U ∧  a ∈ U ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   {  a  }  ,   a ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  a ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s"]},
  {"theorem": "∀ {α : Type u} {x : FreeGroup α}, x ≠ 1 → ¬IsOfFinOrder x",
   "some-correct": null,
   "prompt": "Every non-identity element of a free group is of infinite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  {  x :  FreeGroup  α } ->  (  H :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  [  Fintype  α ] ->  {  x :  FreeGroup  α } ->  (  h :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  {  x :  FreeGroup  α } ->    1 ≠ x →  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  ∀   (  g  :  FreeGroup  α  )  ,   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u_1 } ->  ∀   (  g  :  FreeGroup  α  )  ,   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  {  a :  FreeGroup  α } ->   a ≠  1 →  ∀   (  n  :  ℕ  )  ,  n ≠  orderOf  a",
    " {  α :  Type  u } ->  {  a :  FreeGroup  α } ->   Function.Surjective  FreeGroup.of →   a ≠  1 →  ¬  IsOfFinOrder  a",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  (  x :  FreeGroup  α ) ->   x ≠  1 →  ¬  IsOfFinOrder  x"]},
  {"theorem":
   "∀ {R : Type u_1} [inst : CommRingₓ R] [inst_1 : IsDomain R] [inst_2 : DiscreteValuationRing R] (x : R),\n  IsUnit x ↔ ∃ y, y ≠ 0 ∧ Associated x y",
   "some-correct": null,
   "prompt":
   "An element of a discrete valuation ring is a unit if and only if it has a valuation of zero.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u_1 } ->  [  CommRingₓ  R ] ->  [  IsDomain  R ] ->  [  DiscreteValuationRing  R ] ->  (  x : R ) ->   IsUnit  x ↔  ∃     y  : R ,   y ≠  0 ∧  Associated  x y"]},
  {"theorem":
   "∀ {a b : ℕ}, Nat.gcd a b = 1 → ∀ (N : ℕ), ∃ x y, N = x * a + y * b",
   "some-correct": null,
   "prompt":
   "For any two relatively prime positive integers $a$ and $b$, every sufficiently large natural number $N$ can be written as a linear combination $ax + by$ of $a$ and $b$, where both $x$ and $y$ are natural numbers.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  a b :  ℕ } ->  (  h :   a.gcd  b =  1 ) ->  (  N :  ℕ ) ->  ∃    (   x  y :  ℕ ) ,   ↑ N =   x *  ↑ a +  y *  ↑ b",
    " {  a b N :  ℕ } ->  (  coprime_a_b :  a.coprime  b ) ->  (  hN :  N ≥   (  a   :  ℕ ) * b ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  h :  a.coprime  b ) ->  (  N :  ℕ ) ->  (  hN :  N ≥  a * b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  hab :   a.gcd  b =  1 ) ->  {  n :  ℕ } ->  (  hn :  n >  1 ) ->  ∃    (   x  y :  ℕ ) ,  (      ↑  a *  x +   ↑  b *  y = n  )"]},
  {"theorem": "(R : Type u) → [inst : Field R] → Ring R",
   "some-correct": null,
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Field  F",
    " (  K :  Type  u ) ->  [  Field  K ] ->  CommRing  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  CommRingₓ  K",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ringₓ  F",
    " {  R :  Type  u } ->  [  Field  R ] ->  Ring  R",
    " {  R :  Type  u } ->  [  Field  R ] ->  Ringₓ  R",
    " {  R :  Type  u } ->  [  Field  R ] ->  CommRing  R",
    " {  R :  Type  u } ->  [  Field  R ] ->  CommRingₓ  R",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  K :  Type  v ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  v ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  R :  Type  u ) ->  [  Ring  R ] ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Ring  R ] ->  [  Field  R ] ->  Ringₓ  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  [  Field  R ] ->  Ringₓ  R"]},
  {"theorem": "{α : Type u} → [inst : Ringₓ α] → Group (Units α)",
   "some-correct": null,
   "prompt": "The set of units in a ring forms a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  One  R ] ->  [  Inv  R ] ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  One  R ] ->  [  Inv  R ] ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  AddGroup   (   Units  R  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  AddGroupₓ   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  CommRingₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  CommRingₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  {  a b : α } ->  [  Ringₓ  α ] ->  (  ha :  IsUnit  a ) ->  (  hb :  IsUnit  b ) ->  IsUnit   (   a * b  )"]},
  {"theorem":
   "∀ {G1 G2 : Type u_1} [inst : Groupₓ G1] [inst_1 : Groupₓ G2],\n  Monoidₓ.IsTorsionFree (G1 × G2) → Monoidₓ.IsTorsionFree G1 ∧ Monoidₓ.IsTorsionFree G2",
   "some-correct": null,
   "prompt":
   "If the direct product of two groups is torsion free then each of the groups is torsion free.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G1 G2 :  Type  u_1 } ->  [  Groupₓ  G1 ] ->  [  Groupₓ  G2 ] ->   Monoidₓ.IsTorsionFree   (   G1 × G2  ) →   Monoidₓ.IsTorsionFree  G1 ∧  Monoidₓ.IsTorsionFree  G2",
    " {  G H :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->   Monoidₓ.IsTorsionFree   (   G × H  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  G :  Type  u_1 } ->  {  H :  Type  u_2 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->   Monoidₓ.IsTorsionFree   (   G × H  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  G H :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  (  tG :  Monoidₓ.IsTorsionFree  G ) ->  (  tH :  Monoidₓ.IsTorsionFree  H ) ->  Monoidₓ.IsTorsionFree   (   G × H  )",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  tf :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  [  Fintype  η ] ->  (  tfG :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " (  G H :  Type  u_1 ) ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->   Monoidₓ.IsTorsionFree   (   G × H  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H"]}],
 "elaborated": 29}