{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 0,
 "number-keyword-sentences": 0,
 "include-fixed": true,
 "failures":
 ["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.",
  "A terminal object in a category is unique up to unique isomorphism.",
  "The complement of the union of two sets is the intersection of their complements.",
  "Every index 2 subgroup of a group is normal.",
  "Every free group is torsion free.",
  "A finite torsion-free group is trivial",
  "Every surjective homomorphism from a finitely generated free group to itself is injective.",
  "Every matrix satisfies its own characteristic polynomial.",
  "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$.",
  "An element of a discrete valuation ring is a unit if and only if it has a valuation of zero.",
  "If the direct product of two groups is torsion free then each of the groups is torsion free."],
 "elaborated-prompts":
 [{"theorem":
   "∀ (X : Type ?u.202860) [inst : TopologicalSpace X] (hX : IsCompact (?m.203198 X)), IsCompact (?m.203204 X hX)",
   "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":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  C   :  Set  X ,   IsClosed  C →   ¬  C =  ∅ →   IsCompact  C →  IsCompact  X ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  C   :  Set  X ,    IsClosed  C ∧  C ≠  ∅ →  IsCompact  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  C   :  Set  X ,    IsClosed  C ∧  ¬  IsOpen  C →  IsCompact  C ) ->  IsCompact  X"]},
  {"theorem":
   "∀ (p : ℕ), (∀ (q : ℕ), p = q + 4 → ¬Prime q) → Prime p → p = 3 ∨ ∃ m n, p = m ^ 2 + n ^ 2",
   "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 :  ℕ ) ->  (  h :  ∀  q  ,   p =  q +  4 →  ¬  Prime  q ) ->  (  hp :  Prime  p ) ->   p =  3 ∨  ∃     m  n  :  ℕ ,  p =   m ^  2 +  n ^  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h4 :   p %  4 =  1 ) ->  ∃     n  m  :  ℕ ,  p =   n ^  2 +  m ^  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h_mod_4 :   p %  4 =  1 ) ->  ∃     x  y  :  ℕ ,    x ^  2 +  y ^  2 = p",
    " (  p :  ℕ ) ->  (  hp :  ∀  n   :  ℕ ,   p =    4 * n +  1 →  ∃     m  n  :  ℕ ,    m * m +  n * n = p ) ->  ∀  n   :  ℕ ,   Prime   (     4 * n +  1  ) →  ∃     m  n  :  ℕ ,    m * m +  n * n =    4 * n +  1",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h4p :   p %  4 =  1 ) ->  ∃     x  y  :  ℕ ,  (     x ^  2 +  y ^  2 = p  )",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h :   p %  4 =  1 ) ->  ∃     a  b  ,    a ^  2 +  b ^  2 = p",
    " ∀  n   :  ℕ ,    n %  4 =  1 →   Prime  n →  ∃     a  b  :  ℕ ,  n =   a ^  2 +  b ^  2",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  h₁ :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a * a +  b * b = p",
    " ∀   (  p  :  ℕ  )  (  hp  :  Prime  p  )  (  h  :   p %  4 =  1  )  ,  ∃     x  y  :  ℕ ,    x * x +  y * y = p",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  h1_mod_4 :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,  p =   a ^  2 +  b ^  2",
    " (  p :  ℕ ) ->  (  hp1 :    (   p -  1  ) %  4 =  0 ) ->  (  hp :  Prime  p ) ->  ∃     a  b  :  ℕ ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  (  h :  ∃     k  ,  p =   k *  4 +  1 ) ->  (  hp :  Prime  p ) ->  ∃     x  y  :  ℕ ,    x * x +  y * y = p"]},
  {"theorem":
   "∀ (n m : ℤ),\n  (∃ a b c d, n = a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2) →\n    (∃ a b c d, m = a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2) → ∃ a b c d, n * m = a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2",
   "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":
   [" (  n m :  ℤ ) ->  (  hn :  ∃     a  b  c  d  ,  n =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->  (  hm :  ∃     a  b  c  d  ,  m =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->  ∃     a  b  c  d  ,   n * m =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2",
    " (  a b :  ℤ ) ->  (  h :  ∃     x_1  x_2  x_3  x_4  y_1  y_2  y_3  y_4  :  ℤ ,   a =     x_1 ^  2 +  x_2 ^  2 +  x_3 ^  2 +  x_4 ^  2 ∧  b =     y_1 ^  2 +  y_2 ^  2 +  y_3 ^  2 +  y_4 ^  2 ) ->  ∃     z_1  z_2  z_3  z_4  :  ℤ ,   a * b =     z_1 ^  2 +  z_2 ^  2 +  z_3 ^  2 +  z_4 ^  2"]},
  {"theorem":
   "(α : Type ?u.606401) → [inst : Ring α] → (∀ (x : α), x ^ 2 = x) → CommRing α",
   "some-correct": null,
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type* ) ->  [  Ring  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  CommRing  α",
    " (  α :  Type* ) ->  [  Ring  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  CommRingₓ  α",
    " (  α :  Type* ) ->  [  Ringₓ  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  CommRing  α",
    " (  α :  Type* ) ->  [  Ringₓ  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  CommRingₓ  α",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h_idem :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h_idem :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_idem :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_idem :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  H :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  H :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  H :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  H :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  A :  Type* ) ->  [  Ring  A ] ->  (  h1 :  ∀  x   : A ,   x ^  2 = x ) ->  CommRing  A",
    " (  A :  Type* ) ->  [  Ring  A ] ->  (  h1 :  ∀  x   : A ,   x ^  2 = x ) ->  CommRingₓ  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  (  h1 :  ∀  x   : A ,   x ^  2 = x ) ->  CommRing  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  (  h1 :  ∀  x   : A ,   x ^  2 = x ) ->  CommRingₓ  A",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  id :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  id :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  id :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  id :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  Commutative  R"]},
  {"theorem": "ℤ → ∃ p, Prime p ∧ ∃ q, 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":
   [" ∃     l  :  List   ℕ ,  ∀  a  ∈ l ,  ∀  b  ∈ l ,   a ≠ b →   ¬  Prime   (  a  ) ∨  ¬  Prime   (  b  )",
    " ∀  n   :  ℤ ,  ∃     p  :  ℕ ,   Prime  p ∧  ∃     q  :  ℕ ,   Prime  q ∧  p =  q +  2",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   p ≠  2 ∧  ∃     q  :  ℕ ,   Prime  q ∧   p =  q +  2 ∧  q ≠  2",
    " ∃     b  :  ℕ ,  ∀  a   :  ℕ ,    a < b ∧  Prime  a →  Prime   (   a +  2  )",
    " ∃     f  :   ℕ →  ℕ ,  ∀  n  ,   Prime   (   f  n  ) ∧  Prime   (    f  n +  2  )",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  ∃     q  ,   Prime  q ∧  q =  p +  2",
    " ∃     p₁  p₂  :  ℕ ,   Prime  p₁ ∧   Prime  p₂ ∧   p₂ - p₁ =  2",
    " ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧  a =  b +  2",
    " ∃    (   p  q :  ℕ ) ,   Prime  p ∧   Prime  q ∧   p +  2 = q",
    " ∃     x  y  :  ℕ ,   Prime  x ∧   Prime  y ∧   (   x - y  ) =  2",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   Prime  p ∧   Prime  q ∧   q - p =  2"]},
  {"theorem":
   "(D : Type ?u.785216) → [inst : DivisionRing D] → [inst : Fintype D] → Field D",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D",
    " (  F :  Type* ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  [  DecidableEq  F ] ->  Field  F",
    " (  K :  Type* ) ->  [  DivisionRing  K ] ->  (  H1 :  Finite  K ) ->  Field  K",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  (  hR :  Finite  R ) ->  Field  R",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  IsField  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  IsField  R",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  Field  R"]},
  {"theorem":
   "∀ (α : Type ?u.933909) (β : Type ?u.933912) (hαβ : α → β) (hβα : β → α),\n  Function.Injective hαβ → Function.Injective 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":
   [" (  α β :  Type* ) ->  (  hαβ :  α → β ) ->  (  hβα :  β → α ) ->  (  hαβ_inj :  Function.Injective  hαβ ) ->  (  hβα_inj :  Function.Injective  hβα ) ->  Function.bijective  hαβ",
    " {  A :  Type* } ->  {  B :  Type* } ->  (  f :  A → B ) ->  (  g :  B → A ) ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  Function.bijective  f",
    " (  A :  Type* ) ->  (  B :  Type* ) ->  (  f :  A → B ) ->  (  g :  B → A ) ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  Function.bijective  f",
    " (  α β :  Type* ) ->  (  f :  α → β ) ->  (  g :  β → α ) ->  (  hf :  ∀   (  a a'  : α  )  ,    f  a =  f  a' →  a = a' ) ->  (  hg :  ∀   (  b b'  : β  )  ,    g  b =  g  b' →  b = b' ) ->   Function.bijective  f ∧  Function.bijective  g",
    " (  α β :  Type* ) ->  (  f :  α → β ) ->  (  g :  β → α ) ->  (  hf :  ∀  x y   : α ,    f  x =  f  y →  x = y ) ->  (  hg :  ∀  x y   : β ,    g  x =  g  y →  x = y ) ->  ∀  y   : β ,  ∃     x  : α ,   f  x = y"]},
  {"theorem":
   "∀ (V : Type ?u.1344756) [inst : Fintype V] (E : V → V → Prop),\n  (∀ (x : V), (∃ y, E x y) ∧ ∃ y, E y x) →\n    (∀ (x y z : V), E x y ∧ E y z → E x z ∧ E z y) → ∃ x, ∀ (y : V), E x y ∨ E y x",
   "some-correct": null,
   "prompt":
   "A finite graph in which every pair of vertices have precisely one common neighbour contains a vertex that is adjacent to all other vertices.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  V :  Type* ) ->  [  Fintype  V ] ->  (  E :  V →  V →  Prop ) ->  (  nbr :  ∀  x   : V ,   (   ∃     y  : V ,  E  x y  ) ∧  (   ∃     y  : V ,  E  y x  ) ) ->  (  ke :  ∀  x y z   : V ,   (    E  x y ∧  E  y z  ) →   E  x z ∧  E  z y ) ->  ∃     x  : V ,  ∀  y   : V ,   E  x y ∨  E  y x",
    " (  V :  Type* ) ->  [  Fintype  V ] ->  [  DecidableEq  V ] ->  (  E :  V →  V →  Prop ) ->  [  DecidableRel  E ] ->  (  g :  ∀  a b c   : V ,    E  a b ∧  E  b c →  ¬  E  a c ) ->  ∀  a b   : V ,   a ≠ b →   ¬  E  a b →  ∃     x  : V ,  ∀  v   : V ,   E  x v ↔   v = a ∨  v = b"]},
  {"theorem":
   "∀ (α : Type ?u.2063939) [inst : PartialOrder α], (¬∃ a, ∀ (b : α), b ≤ a) → ∃ a, ∀ (b : α), a ≤ b → b = a",
   "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* ) ->  [  PartialOrder  α ] ->  (  hα :  ¬  (   ∃     a  : α ,  ∀  b   : α ,  b ≤ a  ) ) ->  ∃     a  : α ,  ∀  b   : α ,   a ≤ b →  b = a",
    " (  α :  Type* ) ->  [  PartialOrderₓ  α ] ->  (  hα :  ¬  (   ∃     a  : α ,  ∀  b   : α ,  b ≤ a  ) ) ->  ∃     a  : α ,  ∀  b   : α ,   a ≤ b →  b = a"]},
  {"theorem":
   "∀ (X : Type ?u.5252370) (Y : Type ?u.5252373) (Z : Type ?u.5252376) [inst : UniformSpace X] [inst_1 : UniformSpace Y]\n  [inst_2 : UniformSpace Z] (f : X → Y) (g : Y → Z),\n  Continuous f → 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":
   [" (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  H :  Continuous  f ) ->  (  Hf :  UniformContinuous  f ) ->  (  Hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X :  Type* ) ->  [  UniformSpace  X ] ->  (  Y :  Type* ) ->  [  UniformSpace  Y ] ->  (  f :  X → Y ) ->  (  hf :  UniformContinuous  f ) ->  (  Z :  Type* ) ->  [  UniformSpace  Z ] ->  (  g :  Y → Z ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type* } ->  {  β :  Type* } ->  {  γ :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  (  f :  β → γ ) ->  (  hf :  UniformContinuous  f ) ->  (  g :  α → β ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  hf :  UniformContinuous  f ) ->  (  g :  Y → Z ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ x ,  g   (   f  x  )  )"]},
  {"theorem":
   "∀ (X : Type ?u.5492514) (Y : Type ?u.5492517) (Z : Type ?u.5492520) [inst : UniformSpace X] [inst_1 : UniformSpace Y]\n  [inst_2 : UniformSpace Z] (f : X → Y) (g : Y → Z),\n  Continuous f → 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":
   [" (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  H :  Continuous  f ) ->  (  Hf :  UniformContinuous  f ) ->  (  Hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X :  Type* ) ->  [  UniformSpace  X ] ->  (  Y :  Type* ) ->  [  UniformSpace  Y ] ->  (  f :  X → Y ) ->  (  hf :  UniformContinuous  f ) ->  (  Z :  Type* ) ->  [  UniformSpace  Z ] ->  (  g :  Y → Z ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type* } ->  {  β :  Type* } ->  {  γ :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  (  f :  β → γ ) ->  (  hf :  UniformContinuous  f ) ->  (  g :  α → β ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  g :  Y → Z ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  X Y Z :  Type* ) ->  [  UniformSpace  X ] ->  [  UniformSpace  Y ] ->  [  UniformSpace  Z ] ->  (  f :  X → Y ) ->  (  hf :  UniformContinuous  f ) ->  (  g :  Y → Z ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ x ,  g   (   f  x  )  )"]},
  {"theorem":
   "∀ (T : Type ?u.5852545) [inst : TopologicalSpace T] (f : T → T),\n  (∃ x, f (f (f x)) = x) → ∃ x, ℕ → f (f (f (f (f (f (f (f (f (f (f x)))))))))) = f (f (f x))",
   "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":
   [" (  T :  Type* ) ->  [  TopologicalSpace  T ] ->  (  f :  T → T ) ->  (  hpt :  ∃     x  : T ,   f   (   f   (   f  x  )  ) = x ) ->  ∃     x  : T ,  ∀  n   :  ℕ ,   f   (   f   (   f   (   f   (   f   (   f   (   f   (   f   (   f   (   f   (   f  x  )  )  )  )  )  )  )  )  )  ) =  f   (   f   (   f  x  )  )"]},
  {"theorem":
   "∀ (m n : ℕ), 0 < m → 0 < n → (∃ k, k ^ 3 = m ^ 3 + n ^ 3) → ∀ (x : ℕ), ¬x ^ 3 = m ^ 3 + n ^ 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":
   [" (  p q r n :  ℕ ) ->  (  h1 :  Prime  p ) ->  (  h2 :  Prime  q ) ->  (  h3 :  Prime  r ) ->  (  hp :  ¬  (   Prime  n  ) ) ->    p ^  3 +  q ^  3 ≠  r ^  3",
    " (  x y :  ℕ ) ->  (  hx :   0 < x ) ->  (  hy :   0 < y ) ->  ∀  z   :  ℤ ,   z ^  3 ≠   x ^  3 +  y ^  3",
    " (  x y :  ℕ ) ->  (  hx :   0 < x ) ->  (  hy :   0 < y ) ->     (   λ n ,  n ^  3  )  x +   (   λ n ,  n ^  3  )  y ≠   (   λ n ,  n ^  3  )   (   x + y  )",
    " (  m n :  ℕ ) ->  (  hmn :   m >  0 ∧  n >  0 ) ->  ∀  p   :  ℕ ,   p ^  3 ≠   m ^  3 +  n ^  3",
    " (  m n :  ℕ ) ->  (  hm :   0 < m ) ->  (  hn :   0 < n ) ->  (  hmn :  ∃     k  :  ℕ ,   k ^  3 =   m ^  3 +  n ^  3 ) ->  ∀  x   :  ℕ ,  ¬   x ^  3 =   m ^  3 +  n ^  3",
    " (  x y :  ℕ ) ->  (  hx :  x >  0 ) ->  (  hy :  y >  0 ) ->  ¬  ∃     z  :  ℕ ,    x ^  2 +  y ^  2 =  z ^  2",
    " (  a b c :  ℕ ) ->  (  ha :  a >  0 ) ->  (  hb :  b >  0 ) ->  (  hc :  c >  0 ) ->    a ^  3 +  b ^  3 ≠  c ^  3",
    " (  m n :  ℕ ) ->  (  hx :   m ≠  0 ∧  n ≠  0 ) ->  ∀  i   :  ℤ ,     (   i * m  ) ^  3 +   (   i * n  ) ^  3 ≠   m ^  3 +  n ^  3"]},
  {"theorem":
   "∀ (G : Type ?u.7162001) [inst : Group G], (∀ (g : G), g * g = 1) → ∀ (g₁ g₂ : G), g₁ * g₂ = g₂ * g₁",
   "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 ) ->  ∀  g₁ g₂   : G ,   g₁ * g₂ =  g₂ * g₁",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  g   : G ,   g * g =  1 ) ->  ∀  g₁ g₂   : G ,   g₁ * g₂ =  g₂ * g₁",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀  x   : G ,   x ^  2 =  1 ) ->  CommGroup  G",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀  x   : G ,   x ^  2 =  1 ) ->  CommGroupₓ  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  x   : G ,   x ^  2 =  1 ) ->  CommGroup  G",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  x   : G ,   x ^  2 =  1 ) ->  CommGroupₓ  G",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h2 :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h2 :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀  x   : G ,   (   x * x   : G ) =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  x   : G ,   (   x * x   : G ) =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  a   : G ,   a ^  2 =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  a   : G ,   a ^  2 =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  Odd :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  Odd :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀  x   : G ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  x   : G ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀   (  x  : G  )  ,   x ^  2 =  1 ) ->  (  x y : G ) ->   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀   (  x  : G  )  ,   x ^  2 =  1 ) ->  (  x y : G ) ->   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀  a   : G ,   a * a =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  a   : G ,   a * a =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀  x   : G ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x"]},
  {"theorem": "∀ (n : ℕ), n * (n + 1) % 2 = 0",
   "some-correct": null,
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->    (   n *  (   n +  1  )  ) %  2 =  0",
    " (  n m :  ℕ ) ->  (  h :  n =  m +  1 ) ->  Even   (   n * m  )",
    " (  n :  ℕ ) ->  Even   (   n *  (   n +  1  )  )",
    " (  m :  ℕ ) ->  Even   (   m *  (   m +  1  )  )",
    " (  n :  ℕ ) ->    (   n.pred +  1  ) * n.succ =   2 * n",
    " (  n :  ℕ ) ->   2 ∣  n *  (   n +  1  )",
    " (  n :  ℕ ) ->  ∃     k  :  ℕ ,    2 * k =  n *  (   n +  1  )",
    " {  x :  ℕ } ->  (  hx :  x.succ ≠  0 ) ->  ∃     n  ,   x.succ * x =   2 * n",
    " (  n :  ℕ ) ->  Even   (   n *  (   n +  1  )  )",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,    m %  2 =  0 ∧  m =  n *  (   n +  1  )",
    " (  n :  ℕ ) ->  ∃     k  :  ℕ ,   n *  (   n +  1  ) =   2 * k",
    " (  n :  ℕ ) ->    n *  (   n +  1  ) %  2 =  0"]},
  {"theorem": "∀ (n : ℕ), 1 < n → ∃ p, Prime p ∧ p ∣ n",
   "some-correct": null,
   "prompt":
   "Every natural number greater than `1` is divisible by a prime number. ",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hn :   1 < n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  ,  p.prime ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ )  (   hp :  Prime  p ) ,  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  ,   Prime  p ∧  p ∣ n"]},
  {"theorem":
   "(D : Type ?u.16471580) → [inst : DivisionRing D] → [inst : Fintype D] → Field D",
   "some-correct": null,
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D",
    " (  F :  Type* ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  [  DecidableEq  F ] ->  Field  F",
    " (  K :  Type* ) ->  [  DivisionRing  K ] ->  (  H1 :  Finite  K ) ->  Field  K",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  (  hR :  Finite  R ) ->  Field  R",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  IsField  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  IsField  R",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [  Fintype  R ] ->  Field  R"]},
  {"theorem":
   "∀ (X : Type ?u.16556923) [inst : TopologicalSpace X], Finite X → CompactSpace X",
   "some-correct": null,
   "prompt": "Every finite topological space is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  Fintype  X ] ->  CompactSpace  X",
    " (  X :  Type  u ) ->  [  TopologicalSpace  X ] ->  (  hX :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  (   Finite  X  ) ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hXf :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  Fintype  X ] ->  [  TopologicalSpace  X ] ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Fintype  X ) ->  (  hX_finite :  Finite  X ) ->  IsCompact  X"]},
  {"theorem":
   "∀ (n : ℕ), n > 0 ∧ Even n → ∃ a b, Prime a ∧ Prime b ∧ a + b = n",
   "some-correct": null,
   "prompt":
   "Every positive even integer can be written as the sum of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h :   n >  0 ∧  Even  n ) ->  ∃    (   a  b :  ℕ ) ,   Prime  a ∧   Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->  (  h_pos :   0 < n ) ->  (  h_even :  ∃     m  ,  n =   2 * m ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  hn :  n >  0 ) ->  (  hn_even :   n %  2 =  0 ) ->  ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧  n =  a + b",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧   n %  2 =  0 ) ->  ∃    (   x  y :  ℕ ) ,   Prime  x ∧   Prime  y ∧   x + y = n",
    " (  n :  ℕ ) ->  (  h_even :  Even  n ) ->  (  h_pos :   0 < n ) ->  ∃     p  q  :  ℕ ,   (   Prime  p  ) ∧   (   Prime  q  ) ∧  (    p + q = n  )",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧   n %  2 =  0 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  h :   n >  0 ∧  ∃     k  :  ℕ ,  n =   2 * k ) ->  ∃     x  y  :  ℕ ,   n =  x + y ∧   Prime  x ∧  Prime  y",
    " (  n :  ℕ ) ->  (  h1 :   0 < n ) ->  (  hn :  ∃    (   i :  ℕ ) ,    i %  2 =  1 ∧  n =  i + i ) ->  ∃    (   p  p' :  ℕ ) ,   Prime  p ∧   Prime  p' ∧    0 < p ∧    0 < p' ∧   p + p' = n",
    " (  n :  ℕ ) ->  (  hn :   2 ∣ n ) ->  (  hn' :   0 < n ) ->  ∃     p₁  p₂  :  ℕ ,   Prime  p₁ ∧   Prime  p₂ ∧  n =  p₁ + p₂"]},
  {"theorem": "∀ (x : ℤ), (∃ k, x * x = 2 * k) → ∃ k, x = 2 * k",
   "some-correct": null,
   "prompt": "If the square of a number is even, the number itself is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  x :  ℤ ) ->  (  hx :  ∃     k  :  ℤ ,   x * x =   2 * k ) ->  ∃     k  :  ℤ ,  x =   2 * k",
    " (  n :  ℤ ) ->  (  h :   2 ∣  n ^  2 ) ->   2 ∣ n",
    " (  n :  ℕ ) ->  (  h :   (   2   :  ℕ ) ∣  n * n ) ->   (   2   :  ℕ ) ∣ n",
    " (  n :  ℕ ) ->  (  h :    n * n %  2 =  0 ) ->   n %  2 =  0",
    " (  n :  ℕ ) ->  (  hn :    (   n * n  ) %  2 =  0 ) ->   n %  2 =  0",
    " (  n :  ℕ ) ->  (  H :   2 ∣  n ^  2 ) ->   2 ∣ n",
    " (  n :  ℕ ) ->   Even   (   n ^  2  ) →  Even  n",
    " (  n :  ℕ ) ->  (  hn :    2 *  n ^  2 =  0 ) ->   2 ∣ n",
    " (  a :  ℕ ) ->  (  ha :    a ^  2 %  2 =  0 ) ->   a %  2 =  0",
    " (  n :  ℤ ) ->  (  h :  ∃    (   k :  ℤ ) ,   n * n =   2 * k ) ->  ∃    (   k :  ℤ ) ,  n =   2 * k",
    " (  n :  ℤ ) ->  (  h :   2 ∣  n * n ) ->   2 ∣ n",
    " (  n :  ℕ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  n :  ℤ ) ->  (  h :  ∃     m  ,   n ^  2 =   2 * m ) ->  ∃     m  ,  n =   2 * m",
    " (  a :  ℤ ) ->  (  ha :    a ^  2 %  2 =  0 ) ->   a %  2 =  0"]},
  {"theorem":
   "∀ (X : Type ?u.19518568) [inst : TopologicalSpace X] (A : Set X), (∀ (x : X), x ∈ A → ∃ U, IsOpen U ∧ x ∈ U) → IsOpen A",
   "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* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  h :  ∀  x  ,   x ∈ A →  ∃     U  ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  U :  Set  X ) ->  (  hU :  ∀  x  ∈ U ,  ∃    (   V :  Set  X ) ,   IsOpen  V ∧  x ∈ V ) ->  IsOpen  U",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ,   x ∈ A →  ∃     U  :  Set  X ,   x ∈ U ∧  IsOpen  U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ∈ A ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  (  x : X ) ->  (  hx :  x ∈ A ) ->  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U"]},
  {"theorem":
   "∀ (G : Type ?u.20924977) [inst : Group G] (x : G), x ≠ 1 → FreeGroup G → ∃ n, x ^ n = 1",
   "some-correct": null,
   "prompt": "Every non-identity element of a free group is of infinite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  (  x : G ) ->  (  hx :  x ≠  1 ) ->  (  free :  FreeGroup  G ) ->  ∃     n  ,   x ^ n =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  x : G ) ->  (  hx :  x ≠  1 ) ->  (  free :  FreeGroup  G ) ->  ∃     n  ,   x ^ n =  1"]},
  {"theorem":
   "∀ (a b : ℕ), gcd a b = 1 → ∀ (N x y : ℕ), x * a + y * b ≥ N → ∃ a' b', 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 :  ℕ ) ->  (  hab :   gcd  a b =  1 ) ->  (  N x y :  ℕ ) ->  (  hnb :   (    x * a +  y * b  ) ≥ N ) ->  exists     a'  b'  :  ℕ ,   x = a' ∧  y = b'",
    " (  n m :  ℕ ) ->  (  h_coprime :   gcd  n m =  1 ) ->  (  N :  ℕ ) ->  (  hN :  N ≥  n * m ) ->  ∃     x  y  :  ℕ ,  (      n * x +  m * y = N ∧   x ≥  0 ∧  y ≥  0  )",
    " (  a b :  ℕ ) ->  (  hab :  IsCoprime  a b ) ->  (  N :  ℕ ) ->  (  hN :  ∃     x  y  :  ℕ ,  N =   a * x +  b * y ) ->  ∃     x  y  :  ℕ ,   N =   a * x +  b * y ∧   x ≥  0 ∧  y ≥  0",
    " (  a b :  ℕ ) ->  (  h :  a.coprime  b ) ->  (  N :  ℕ ) ->  (  hN :    4 * N ≥  a + b ) ->  ∃     m  n  :  ℕ ,  N =   m * a +  n * b"]},
  {"theorem": "(α : Type ?u.20969377) → [inst : Field α] → Ring α",
   "some-correct": null,
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type* ) ->  [  Field  α ] ->  Ring  α",
    " (  α :  Type* ) ->  [  Field  α ] ->  Ringₓ  α",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ringₓ  F",
    " (  k :  Type* ) ->  [  Field  k ] ->  Ring  k",
    " (  k :  Type* ) ->  [  Field  k ] ->  Ringₓ  k",
    " (  K :  Type* ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type* ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  F :  Type* ) ->  [  Field  F ] ->  CommRing  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  CommRingₓ  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ringₓ  F"]},
  {"theorem": "(R : Type ?u.21594422) → [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* ) ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  x y z :  Units  R ) ->  (  h :    (   x * y  ) * z =  x *  (   y * z  ) ) ->    (   x * y  ) * z =  x *  (   y * z  )",
    " (  α :  Type* ) ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " (  α :  Type* ) ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " (  R :  Type* ) ->  [  Ring  R ] ->  Group   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ring  R ] ->  Groupₓ   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Group   { x  : R //  x ≠  0 }",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  Groupₓ   { x  : R //  x ≠  0 }"]}],
 "elaborated": 25}