{"total-prompts": 29,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["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.",
  "Every surjective homomorphism from a finitely generated free group to itself is injective.",
  "The square root of an irrational number is irrational.",
  "In a finite commutative ring, all prime ideals are maximal."],
 "elaborated-prompts":
 [{"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α},\n  IsCompact s → s ≠ ∅ → ∀ {t : Set α}, IsClosed t → t ≠ s → IsCompact t",
   "some-correct": null,
   "prompt":
   "If every proper closed set of a topological space is compact, then the space itself is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  IsCompact  s ) ->  (  p :  s ≠  ∅ ) ->  {  t :  Set  α } ->  (  ht :  IsClosed  t ) ->  (  hp :  t ≠ s ) ->  IsCompact  t"]},
  {"theorem":
   "∀ {x y : ℕ},\n  (∃ a b c d, a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2 = x) →\n    (∃ a b c d, a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2 = y) → ∃ a b c d, a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2 = x * y",
   "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":
   [" {  x y :  ℕ } ->  (  hx :  ∃    (   a  b  c  d :  ℕ ) ,      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 = x ) ->  (  hy :  ∃    (   a  b  c  d :  ℕ ) ,      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 = y ) ->  ∃    (   a  b  c  d :  ℕ ) ,      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =  x * y",
    " {  a b c d :  ℤ } ->  (  h1 :  ∃    (   x  y  z  w :  ℤ ) ,  a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  (  h2 :  ∃    (   x  y  z  w :  ℤ ) ,  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  ∃    (   m  n  p  q :  ℤ ) ,   c * d =     m ^  2 +  n ^  2 +  p ^  2 +  q ^  2"]},
  {"theorem":
   "{α : Type u_1} → [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_1 } ->  [  Ring  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ring  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  Commutative  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  Commutative  α",
    " {  α :  Type  u } ->  [  Mul  α ] ->  [  Add  α ] ->  [  One  α ] ->  (  HMul :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Mul  α ] ->  [  Add  α ] ->  [  One  α ] ->  (  HMul :  ∀  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 } ->  [  Ringₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α"]},
  {"theorem": "ℕ → ∃ p q, p ≠ q ∧ p - q = 2 ∧ Nat.Prime p ∧ Nat.Prime q",
   "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 ∧  ∀   (  r  :  ℕ  )  ,   Nat.Prime  r →   r = p ∨  r = q",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p  q :  ℕ ) ,   p ≠ q ∧    p - q =  2 ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   q =  p +  2 ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  (    p +  2 = q  )",
    " ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p - q =  2",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   n ≤ p ∧   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p +  2 = q",
    " ∃    (   p  q :  ℕ ) ,   p ≠ q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧   p +  2 = q",
    " (  n :  ℕ ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a +  2 = b"]},
  {"theorem":
   "∀ {K : Type u} [inst : Fintype K] [inst : DivisionRing K], IsField K",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Fact   (   IsField  K  )",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  D :  Type  u ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D"]},
  {"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 } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  α → γ } ->  {  h :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  (  hh :  UniformContinuous  h ) ->  (  h :  ∀  x  ,   h   (   f  x  ) =  g  x ) ->  UniformContinuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  γ ] ->  [  UniformSpace  β ] ->  [  UniformSpace  α ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  h :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  (  hf :  UniformContinuous   (   β → γ  ) ) ->  (  hg :  UniformContinuous   (   α → β  ) ) ->  UniformContinuous   (   α → γ  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :   α ⊕ α → β } ->  {  g :  α → β } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ   ( x : α ) ,  f   (   Sum.inl   (   g  x  )  )  )"]},
  {"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 } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  α → γ } ->  {  h :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  (  hh :  UniformContinuous  h ) ->  (  h :  ∀  x  ,   h   (   f  x  ) =  g  x ) ->  UniformContinuous  g",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  γ ] ->  [  UniformSpace  β ] ->  [  UniformSpace  α ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  h :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  (  hf :  UniformContinuous   (   β → γ  ) ) ->  (  hg :  UniformContinuous   (   α → β  ) ) ->  UniformContinuous   (   α → γ  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :   α ⊕ α → β } ->  {  g :  α → β } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ   ( x : α ) ,  f   (   Sum.inl   (   g  x  )  )  )"]},
  {"theorem":
   "∀ {α : Type u_1} [inst : LinearOrder α] {f : α → α} {x : α},\n  Function.IsPeriodicPt f 3 x → x < f x → ∀ (a : ℕ), a ∈ { b | 0 < b } → ∃ y, Function.IsPeriodicPt f a 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 } ->  [  LinearOrder  α ] ->  {  f :  α → α } ->  {  x : α } ->  (  hf :  Function.IsPeriodicPt  f  3 x ) ->  (  h :  x <  f  x ) ->  ∀  a  ∈  {   b   :  ℕ |   0 < b } ,  ∃     y  ,  Function.IsPeriodicPt  f a y",
    " {  α :  Type  u_1 } ->  [  LinearOrderₓ  α ] ->  {  f :  α → α } ->  {  x : α } ->  (  hf :  Function.IsPeriodicPt  f  3 x ) ->  (  h :  x <  f  x ) ->  ∀  a  ∈  {   b   :  ℕ |   0 < b } ,  ∃     y  ,  Function.IsPeriodicPt  f a y",
    " {  α :  Type  u_1 } ->  [  LinearOrder  α ] ->  (  f :  α → α ) ->  (  x : α ) ->  (  h :  Function.IsPeriodicPt  f  3 x ) ->  ∀  n   :  ℕ ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  [  LinearOrderₓ  α ] ->  (  f :  α → α ) ->  (  x : α ) ->  (  h :  Function.IsPeriodicPt  f  3 x ) ->  ∀  n   :  ℕ ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  LinearOrder  α ] ->  [  LinearOrder  β ] ->  [  Zero  α ] ->  [  One  α ] ->  [  Zero  β ] ->  [  One  β ] ->  {  f :  α → β } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∃     x  ,  ∀  m   :  ℕ ,  Function.IsPeriodicPt  f m x",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  LinearOrder  α ] ->  [  LinearOrderₓ  β ] ->  [  Zero  α ] ->  [  One  α ] ->  [  Zero  β ] ->  [  One  β ] ->  {  f :  α → β } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∃     x  ,  ∀  m   :  ℕ ,  Function.IsPeriodicPt  f m x",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  LinearOrderₓ  α ] ->  [  LinearOrder  β ] ->  [  Zero  α ] ->  [  One  α ] ->  [  Zero  β ] ->  [  One  β ] ->  {  f :  α → β } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∃     x  ,  ∀  m   :  ℕ ,  Function.IsPeriodicPt  f m x",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  LinearOrderₓ  α ] ->  [  LinearOrderₓ  β ] ->  [  Zero  α ] ->  [  One  α ] ->  [  Zero  β ] ->  [  One  β ] ->  {  f :  α → β } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∃     x  ,  ∀  m   :  ℕ ,  Function.IsPeriodicPt  f m x"]},
  {"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  )",
    " {  x y :  ℕ } ->  (  hxy :  x ≠ y ) ->  ∀  z  ,    x ^  3 +  y ^  3 ≠  z ^  3",
    " {  a b c :  ℕ } ->  (  ha :   0 < a ) ->  (  hb :   0 < b ) ->  (  hc :   0 < c ) ->    a ^  3 +  b ^  3 ≠  c ^  3",
    " ∀   (  x y z  :  ℕ  )  ,    x ^  3 +  y ^  3 ≠  z ^  3",
    " {  a b c :  ℕ } ->    a ^  3 +  b ^  3 ≠  c ^  3",
    " {  n m k :  ℤ } ->  (  n0 :  n >  0 ) ->  (  m0 :  m >  0 ) ->  (  k0 :  k >  0 ) ->    n ^  3 +  m ^  3 ≠  k ^  3"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Group G], (∀ (a : G), a * a = 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  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 ] ->  (  card2 :  ∀   (  x  : G  )  ,   2 ∣   (   x ^  2  ) . order ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  card2 :  ∀   (  x  : G  )  ,   2 ∣   (   x ^  2  ) . order ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " {  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 :  ∀   (  x  : G  )  ,   orderOf  x =  2 ) ->  ∀   (  x y  : G  )  ,  Commute  x y",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " {  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"]},
  {"theorem": "∀ {n : ℕ}, Even ((n + 1) * n)",
   "some-correct": null,
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  Even   (    (   n +  1  ) * n  )",
    " {  m :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " {  m :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " (  m :  ℕ ) ->  Even   (   m *  (   m +  1  )  )",
    " {  n :  ℕ } ->  (  h :  n ≠  0 ) ->  Even   (   n *  (   n +  1  )  )"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] {H : Set G}, (∃ a, H = { x | x * a = a * x }) → IsNormalSubgroup H",
   "some-correct": null,
   "prompt": "Every index 2 subgroup of a group is normal.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  {  H :  Set  G } ->  (  index_h :  ∃     a  : G ,  H =  {   x  |   x * a =  a * x } ) ->  IsNormalSubgroup  H"]},
  {"theorem": "∀ {α : Type u}, Monoidₓ.IsTorsionFree (FreeGroup α)",
   "some-correct": null,
   "prompt": "Every free group is torsion free.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u ) ->  [  DecidableEq  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u_1 ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] [inst_1 : Fintype G], Nontrivial G → ¬Monoidₓ.IsTorsionFree G",
   "some-correct": null,
   "prompt": "A finite torsion-free group is trivial",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hG :  Monoidₓ.IsTorsionFree  G ) ->   (   1   : G ) =  0",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hN :  Nontrivial  G ) ->  ¬  Monoidₓ.IsTorsionFree  G"]},
  {"theorem":
   "∀ {K : Type u} [inst : Fintype K] [inst : DivisionRing K], IsField K",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Fact   (   IsField  K  )",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  D :  Type  u ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D"]},
  {"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  α ] ->  (  h :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hf :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  f :  Fintype  α ) ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h_fin :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  TopologicalSpace  α ] ->  IsCompact   (  Set.Univ   :  Set  α )",
    " (  α :  Type  u ) ->  [  TopologicalSpace  α ] ->   Finite  α →  IsCompact  α"]},
  {"theorem":
   "∀ (n : ℕ), 0 < n → n % 2 = 0 → ∃ p q, Nat.Prime p ∧ Nat.Prime q ∧ p + q = n",
   "some-correct": null,
   "prompt":
   "Every positive even integer can be written as the sum of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  h :    0 < n ∧   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " {  n :  ℕ } ->  (  hn :    0 < n ∧   n %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p + q",
    " ∀   (  k  :  ℕ  )  ,   k >  0 →    k %  2 =  0 →  ∃     a  b  :  ℕ ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = k",
    " {  n :  ℕ } ->  (  hpos :   0 < n ) ->  (  heven :   2 ∣ n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  k :  ℕ ) ->  (  hpos :  k >  0 ) ->  (  heven :   k %  2 =  0 ) ->  ∃     a  b  :  ℕ ,   Nat.Prime  a ∧   Nat.Prime  b ∧  k =  a + b",
    " {  n :  ℕ } ->  (  hn :   0 < n ) ->  (  he :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->    n >  0 ∧   n %  2 =  0 →  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :  ¬   (   2   :  ℕ ) ∣ n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hn :   0 < n ) ->  (  he :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n"]},
  {"theorem": "∀ {n : ℕ}, n ^ 2 % 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 ^  2 %  2 =  0 ) ->   n %  2 =  0",
    " {  α :  Type  u } ->  [  LinearOrderedField  α ] ->  {  a : α } ->   Even   (   a * a  ) →  Even  a",
    " {  n :  ℕ } ->  (  hn :  Even   (   n * n  ) ) ->  Even  n",
    " {  n :  ℤ } ->   Even   (   n ^  2  ) →  Even  n",
    " {  m :  ℕ } ->   Even   (   m * m  ) →  Even  m",
    " {  n :  ℕ } ->  (  h :  Even   (    2 * n  ) ) ->  Even  n",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a : α } ->     (   a * a  ) %  2 =  0 →   a %  2 =  0",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a : α } ->     (   a * a  ) %  2 =  0 →   a %  2 =  0",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  DecidableEq  α ] ->  (  a : α ) ->   Even   (   a * a  ) →  Even  a",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  (  a : α ) ->   Even   (   a * a  ) →  Even  a",
    " {  n :  ℕ } ->  (  Hn2 :  Even   (   n * n  ) ) ->  Even  n",
    " {  n :  ℕ } ->   Even   (   n * n  ) →  Even  n",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  x : α } ->  (  hx2 :  IsSquare   (   x * x  ) ) ->  Even  x",
    " {  n :  ℕ } ->   Even   (   n ^  2  ) →  Even  n"]},
  {"theorem":
   "∀ {α : Type u} [inst : DecidableEq α] (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 } ->  [  DecidableEq  α ] ->  (  x :  FreeGroup  α ) ->   x ≠  1 →  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   g ≠  1 →  ¬  (   IsOfFinOrder  g  )",
    " {  α :  Type  u } ->  (  a :  FreeGroup  α ) ->   a ≠  1 →  ¬  IsOfFinOrder  a",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->  (  hg :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  {  x :  FreeGroup  α } ->   ¬  IsOfFinOrder  x →  x ≠  1",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  {  w :  FreeGroup  α } ->  (  h :   (   FreeGroup.of  w  ) ≠  1 ) ->  ¬  IsOfFinOrder   (   FreeGroup.of  w  )",
    " {  α :  Type  u } ->  (  x :  FreeGroup  α ) ->   x ≠  1 →  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  ∀   (  g  :  FreeGroup  α  )  (  h  :  g ≠  1  )  ,  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->  (  H :  g ≠  1 ) ->  ¬  IsOfFinOrder  g"]},
  {"theorem":
   "∀ {a b : ℕ}, gcd a b = 1 → ∀ (N : ℕ), b ≤ N → ∃ x y, N = a * x + b * y",
   "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 :  ℕ } ->  (  hand :   gcd  a b =  1 ) ->  (  N :  ℕ ) ->  (  h :  b ≤ N ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  hab :   a.gcd  b =  1 ) ->  (  N :  ℕ ) ->  (  hN :  N >  0 ) ->  ∃    (   x  y :  ℕ )  (   hx :    0 < x ∧   0 < y ) ,   ↑ N =    ↑  a *  x +   ↑  b *  y",
    " {  a b :  ℕ } ->  (  hab :   a.gcd  b =  1 ) ->  {  N :  ℕ } ->  (  hN :  N ≥  a * b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  hab :   a.gcd  b =  1 ) ->  {  N :  ℕ } ->  (  hN :  N ≥  a + b ) ->  ∃    (   x  y :  ℕ ) ,   ↑ N =    ↑  a *  x +   ↑  b *  y",
    " {  a b :  ℕ } ->  (  h :  IsCoprime  a b ) ->  (  N :  ℕ ) ->  (  hN :  N >  a * b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  N a b :  ℤ } ->  (  h1 :  N >  0 ) ->  (  h2 :   a.gcd  b =  1 ) ->  ∃    (   x  y :  ℤ ) ,  N =   a * x +  b * y",
    " {  a b N :  ℕ } ->  (  h :   gcd  a b =  1 ) ->  (  hN :  N ≥   a + b -  1 ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y"]},
  {"theorem": "(K : Type u) → [inst : Field K] → Ring K",
   "some-correct": null,
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  K :  Type  u ) ->  [  Field  K ] ->  [  DecidableEq  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  [  DecidableEq  K ] ->  Ringₓ  K",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ringₓ  F",
    " {  K :  Type  u } ->  [  Field  K ] ->  Ring  K",
    " {  K :  Type  u } ->  [  Field  K ] ->  Ringₓ  K",
    " (  R :  Type  u ) ->  [  Field  R ] ->  CommRing  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  CommRingₓ  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  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 ] ->  Ring  R",
    " {  R :  Type  u } ->  [  Field  R ] ->  Ringₓ  R",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  F :  Type  u ) ->  [  Field  F ] ->  IsRingHom  RingHom.id"]},
  {"theorem": "{R : Type u_1} → [inst : Ringₓ R] → Group (Units R)",
   "some-correct": null,
   "prompt": "The set of units in a ring forms a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  AddGroup   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  AddGroupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  AddGroup   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  AddGroupₓ   (   Units  α  )"]},
  {"theorem":
   "∀ {G H : Type u_1} [inst : Groupₓ G] [inst_1 : Groupₓ H],\n  Monoidₓ.IsTorsionFree (G × H) → Monoidₓ.IsTorsionFree G ∧ Monoidₓ.IsTorsionFree H",
   "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":
   [" {  G H :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->   Monoidₓ.IsTorsionFree   (   G × H  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  hf :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  tf :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  G_1 G_2 :  Type  u_1 } ->  [  Groupₓ  G_1 ] ->  [  Groupₓ  G_2 ] ->  (  tf :  Monoidₓ.IsTorsionFree   (   G_1 × G_2  ) ) ->  Monoidₓ.IsTorsionFree  G_1",
    " {  G G' :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  G' ] ->   Monoidₓ.IsTorsionFree   (   G × G'  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  G'",
    " {  G₁ G₂ :  Type  u_1 } ->  [  Groupₓ  G₁ ] ->  [  Groupₓ  G₂ ] ->  (  h :  Monoidₓ.IsTorsionFree   (   G₁ × G₂  ) ) ->   Monoidₓ.IsTorsionFree  G₁ ∧  Monoidₓ.IsTorsionFree  G₂",
    " {  G1 G2 :  Type  u_1 } ->  [  Groupₓ  G1 ] ->  [  Groupₓ  G2 ] ->  (  h :  Monoidₓ.IsTorsionFree   (   G1 × G2  ) ) ->   Monoidₓ.IsTorsionFree  G1 ∧  Monoidₓ.IsTorsionFree  G2",
    " {  G :  Type  u_1 } ->  {  H :  Type  u_2 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->   Monoidₓ.IsTorsionFree   (   G × H  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H"]}],
 "elaborated": 23}