{"total-prompts": 42,
 "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.",
  "If a function from the unit interval to itself has a point of period three, then it has points of all positive periods.",
  "A terminal object in a category is unique up to unique isomorphism.",
  "A finitely-presented group containing a torsion element is finite.",
  "The complement of the union of two sets is the intersection of their complements.",
  "The sum of the cubes of two positive integers is never equal to the cube of a third integer.",
  "Every free group is torsion free.",
  "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$.",
  "Every non-identity element of a free group is of infinite order.",
  "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.260566) [inst : TopologicalSpace X] (hcompact : ∀ (C : Set X), IsClosed C → IsCompact C),\n  IsCompact (?m.260770 X hcompact)",
   "some-correct": null,
   "round-trip":
   " The space of compact subsets of a topological space is compact. ",
   "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 ] ->  (  hcompact :  ∀  C   :  Set  X ,   IsClosed  C →  IsCompact  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  ∀  S  ,    IsClosed  S ∧  S ≠ X →  IsCompact  S ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h_compact :  ∀  C   :  Set  X ,   IsClosed  C →   C ≠  ∅ →  IsCompact  C ) ->  IsCompact  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  IsCompact  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  h_compact :  ∀  A   :  Set  X ,   IsClosed  A →  IsCompact  A ) ->  IsCompact  X"]},
  {"theorem": "∀ (p : ℕ), Prime p → p % 4 = 1 → ∃ x y, p = x ^ 2 + y ^ 2",
   "some-correct": null,
   "round-trip": "Every prime `p ≡ 1 [4]` is the sum of two squares. ",
   "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 :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp1 :   p %  4 =  1 ) ->  ∃     x  y  :  ℕ ,  p =   x ^  2 +  y ^  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h :   p %  4 =  1 ) ->  ∃    (   x  y :  ℕ ) ,  p =   x ^  2 +  y ^  2",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h4 :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,    a * a +  b * b = p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  h :   p %  4 =  1 ) ->  ∃     a  b  :  ℕ ,   p =   a ^  2 +  b ^  2 ∧   gcd  a b =  1",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp1 :   p %  4 =  1 ) ->  ∃     x  y  :  ℕ ,  p =   x ^  2 +  y ^  2",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  hp34 :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,   (     a * a +  b * b = p  ) ∧  a ≤ b",
    " (  p :  ℕ ) ->  (  hp :  Nat.Prime  p ) ->  (  hp_mod :   p %  4 =  1 ) ->  ∃     x  y  :  ℤ ,    x * x +  y * y =  ↑ p",
    " (  p :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hp1mod4 :    (   p -  1  ) %  4 =  0 ) ->  ∃     a  b  ,  p =   a ^  2 +  b ^  2"]},
  {"theorem":
   "∀ (a b : ℕ),\n  (∃ x y z w, a = x ^ 2 + y ^ 2 + z ^ 2 + w ^ 2) →\n    (∃ x y z w, b = x ^ 2 + y ^ 2 + z ^ 2 + w ^ 2) → ∃ x y z w, a * b = x ^ 2 + y ^ 2 + z ^ 2 + w ^ 2",
   "some-correct": null,
   "round-trip":
   " If `a` and `b` are sums of four squares, then `a*b` is also a sum of four squares. ",
   "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 :  ℕ ) ->  (  ha :  ∃     x  y  z  w  ,  a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  (  hb :  ∃     x  y  z  w  ,  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  ∃     x  y  z  w  ,   a * b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2",
    " (  a b :  ℤ ) ->  (  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 ) ->  ∃     x  y  z  w  :  ℤ ,   a * b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2"]},
  {"theorem":
   "∀ (R : Type ?u.851143) [inst : CommRing R], (∀ (x : R), x * x = x) → ∀ (x y : R), x * y = y * x",
   "some-correct": null,
   "round-trip":
   " If `R` is a commutative ring and `x * x = x` for all `x : R`, then `x * y = y * x` for all `x y : R`. ",
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type* ) ->  [  CommRing  R ] ->  (  hR :  ∀  x   : R ,   x * x = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  hR :  ∀  x   : R ,   x * x = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  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 ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  a   : R ,   a * a = a ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  a   : R ,   a * a = a ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  hR :  ∀  a   : R ,   a ^  2 = a ) ->  ∀  a b   : R ,   a * b =  b * a",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  hR :  ∀  a   : R ,   a ^  2 = a ) ->  ∀  a b   : R ,   a * b =  b * a",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  id :  ∀  a  ,   a ^  2 = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  id :  ∀  a  ,   a ^  2 = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  id :  ∀  a  ,   a ^  2 = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  id :  ∀  a  ,   a ^  2 = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  a   : R ,   a * a = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  a   : R ,   a * a = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  a   : R ,   a * a = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  a   : R ,   a * a = a ) ->  CommRingₓ  R",
    " (  A :  Type* ) ->  [  Ring  A ] ->  (  h :  ∀  x   : A ,   x * x = x ) ->  Commutative  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  (  h :  ∀  x   : A ,   x * x = x ) ->  Commutative  A",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x ^  2 = x ) ->  ∀  x y   : R ,   x * y =  y * x",
    " (  R :  Type* ) ->  [  CommRing  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  Commutative  R",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  Commutative  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 * x = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h :  ∀  a   : R ,   a ^  2 = a ) ->  CommRingₓ  R",
    " (  A :  Type* ) ->  [  Ring  A ] ->  (  h :  ∀  x   : A ,   x ^  2 = x ) ->  CommRing  A",
    " (  A :  Type* ) ->  [  Ring  A ] ->  (  h :  ∀  x   : A ,   x ^  2 = x ) ->  CommRingₓ  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  (  h :  ∀  x   : A ,   x ^  2 = x ) ->  CommRing  A",
    " (  A :  Type* ) ->  [  Ringₓ  A ] ->  (  h :  ∀  x   : A ,   x ^  2 = x ) ->  CommRingₓ  A",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h_idem :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ring  R ] ->  (  h_idem :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_idem :  ∀  x   : R ,   x ^  2 = x ) ->  CommRing  R",
    " (  R :  Type* ) ->  [  Ringₓ  R ] ->  (  h_idem :  ∀  x   : R ,   x ^  2 = x ) ->  CommRingₓ  R"]},
  {"theorem":
   "∀ (p q : ℕ), Prime p → Prime q → q - p = 2 → ∃ r s, Prime r ∧ Prime s ∧ r - s = 2 ∧ (p ≠ r ∨ q ≠ s)",
   "some-correct": null,
   "round-trip":
   "If `p` and `q` are primes with `q - p = 2`, then there are primes `r, s` with `r - s = 2` and `p ≠ r` or `q ≠ s`. ",
   "prompt":
   "There are infinitely many pairs of primes that differ exactly by `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  p q :  ℕ ) ->  (  hp :  Prime  p ) ->  (  hq :  Prime  q ) ->  (  h :   q - p =  2 ) ->  ∃     r  s  :  ℕ ,   Prime  r ∧   Prime  s ∧    r - s =  2 ∧  (    p ≠ r ∨  q ≠ s  )",
    " (  h :  ∃     p  :  ℕ ,   Prime  p ∧  p >  2 ) ->  ∃     p  q  ,   Prime  p ∧   Prime  q ∧   p - q =  2",
    " ∃     p₁  p₂  :  ℕ ,    p₁ +  2 = p₂ ∧   Prime  p₁ ∧  Prime  p₂",
    " ∀  n   :  ℕ ,  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧    q - p =  2 ∧  p > n",
    " ∃     p  :  ℕ ,  ∃     q  ,   p ≠ q ∧   Prime  p ∧   Prime  q ∧  q =  p +  2",
    " ∀  n   :  ℕ ,  ∃     p  :  ℕ ,   Prime  p ∧  ∃     q  :  ℕ ,   Prime  q ∧  q =  p +  2",
    " ∀  n   :  ℕ ,  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   (   p ≠ q  ) ∧  (    p - q =  2  )",
    " ∃     p  :  ℕ ,  ∃     q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p +  2 = q",
    " (  n :  ℕ ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p ≠ q ∧   q - p =  2"]},
  {"theorem":
   "∀ (D : Type ?u.896132) [inst : DivisionRing D] [inst_1 : Fintype D], IsField D",
   "some-correct": null,
   "round-trip": " A `DivisionRing` is a `Field` if it is a `Fintype`. ",
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  HD :  Fintype  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD_fin :  Finite  D ) ->  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [ Fin :  Fintype  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [ Finₓ :  Fintype  R ] ->  Field  R"]},
  {"theorem":
   "∀ (x : Type ?u.897943) (y : Type ?u.897946) (f : x → y),\n  Function.Injective f → ∀ (g : y → x), Function.Injective g → Function.bijective f",
   "some-correct": null,
   "round-trip":
   " **The Schröder-Bernstein Theorem**: Given injections `α → β` and `β → α`, we can get a bijection `α → β`. ",
   "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":
   [" (  x y :  Type* ) ->  (  f :  x → y ) ->  (  f_inj :  Function.Injective  f ) ->  (  g :  y → x ) ->  (  g_inj :  Function.Injective  g ) ->  Function.bijective  f",
    " (  X Y :  Type* ) ->  (  a :  X → Y ) ->  (  b :  Y → X ) ->  (  h1 :  ∀  x y   : X ,    a  x =  a  y →  x = y ) ->  (  h2 :  ∀  x y   : Y ,    b  x =  b  y →  x = y ) ->  Function.bijective  a",
    " (  X Y :  Type* ) ->  (  f :  X → Y ) ->  (  g :  Y → X ) ->  (  hf :  ∀  x₁ x₂   : X ,    f  x₁ =  f  x₂ →  x₁ = x₂ ) ->  (  hg :  ∀  y₁ y₂   : Y ,    g  y₁ =  g  y₂ →  y₁ = y₂ ) ->  Function.bijective  f",
    " (  α :  Type* ) ->  (  β :  Type* ) ->  [  Inhabited  β ] ->  (  f :  α → β ) ->  (  g :  β → α ) ->  (  h :  ∀  x  ,   f   (   g  x  ) = x ) ->  (  h' :  ∀  x  ,   g   (   f  x  ) = x ) ->  Function.bijective  f"]},
  {"theorem":
   "∀ (L : Type ?u.951407) [inst : Fintype L] [inst : DecidableEq L] (E : L → L → Prop),\n  Symmetric E → (∀ (x y : L), ∃ z, E z x ∧ E z y ∧ ∀ (z' : L), E z' x ∧ E z' y → z' = z) → ∃ z, ∀ (x : L), E z x",
   "some-correct": null,
   "round-trip": " The existence of a unique element satisfying a property. ",
   "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":
   [" (  L :  Type* ) ->  [  Fintype  L ] ->  [  DecidableEq  L ] ->  (  E :  L →  L →  Prop ) ->  (  H :  Symmetric  E ) ->  (  h :  ∀  x y   : L ,  ∃     z  ,   E  z x ∧   E  z y ∧  (   ∀  z'   : L ,    E  z' x ∧  E  z' y →  z' = z  ) ) ->  ∃     z  : L ,  ∀  x   : L ,  E  z x",
    " (  V :  Type* ) ->  (  E :  V →  V →  Prop ) ->  (  Fin :  ∀  x   : V ,  { y  //   (   x ≠ y  ) ∧  E  x y } ) ->  (  Unique :  ∀  x y z  ,    E  x y ∧  E  x z →  y = z ) ->  (  comm :  ∀  x y z   : V ,    E  x y ∧  E  y z →  E  x z ) ->  ∃     v  : V ,  ∀  v'   : V ,  E  v v'",
    " (  V :  Type* ) ->  (  E :  V →  V →  Prop ) ->  (  Finₓ :  ∀  x   : V ,  { y  //   (   x ≠ y  ) ∧  E  x y } ) ->  (  Unique :  ∀  x y z  ,    E  x y ∧  E  x z →  y = z ) ->  (  comm :  ∀  x y z   : V ,    E  x y ∧  E  y z →  E  x z ) ->  ∃     v  : V ,  ∀  v'   : V ,  E  v v'"]},
  {"theorem":
   "∀ (X : Type ?u.1532314) [inst : PartialOrder X],\n  (∀ {r : X → X → Prop}, Transitive r → Reflexive r → ∃ x, ∀ (y : X), r x y → y = x) →\n    Nonempty X → ∃ x, ∀ (y : X), x ≤ y → y = x",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every non-empty poset in which every chain has an upper bound contains a maximal element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type* ) ->  [  PartialOrder  α ] ->  (  a : α ) ->  (  h :  ∀  r  ,  ∃     u  ,  r ≤ u ) ->  ∃     m  ,   a ≤ m ∧  (   ∀  b   : α ,   a ≤ b →   m ≤ b →  b = m  )",
    " (  α :  Type* ) ->  [  PartialOrderₓ  α ] ->  (  a : α ) ->  (  h :  ∀  r  ,  ∃     u  ,  r ≤ u ) ->  ∃     m  ,   a ≤ m ∧  (   ∀  b   : α ,   a ≤ b →   m ≤ b →  b = m  )",
    " (  X :  Type* ) ->  [  PartialOrder  X ] ->  (  hchain :  ∀   {  r  :  X →  X →  Prop }  (  htrans  :  Transitive  r  )  (  hrefl  :  Reflexive  r  )  ,  ∃     x  : X ,  ∀  y  ,   r  x y →  y = x ) ->  (  Nonempty :  Nonempty  X ) ->  ∃     x  : X ,  ∀  y  ,   x ≤ y →  y = x",
    " (  X :  Type* ) ->  [  PartialOrderₓ  X ] ->  (  hchain :  ∀   {  r  :  X →  X →  Prop }  (  htrans  :  Transitive  r  )  (  hrefl  :  Reflexive  r  )  ,  ∃     x  : X ,  ∀  y  ,   r  x y →  y = x ) ->  (  Nonempty :  Nonempty  X ) ->  ∃     x  : X ,  ∀  y  ,   x ≤ y →  y = x",
    " (  P :  Type* ) ->  [  PartialOrder  P ] ->  (  h :  ∀  x   : P ,  ∃     y  : P ,  x ≤ y ) ->  ∃     z  : P ,  ∀  y   : P ,   z ≤ y →  y = z",
    " (  P :  Type* ) ->  [  PartialOrderₓ  P ] ->  (  h :  ∀  x   : P ,  ∃     y  : P ,  x ≤ y ) ->  ∃     z  : P ,  ∀  y   : P ,   z ≤ y →  y = z"]},
  {"theorem":
   "∀ (X : Type ?u.2944144) (Y : Type ?u.2944147) (Z : Type ?u.2944150) [inst : UniformSpace X] [inst_1 : UniformSpace Y]\n  [inst_2 : UniformSpace Z] (f : X → Y) (g : Y → Z),\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  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 ) ->  (  g :  Y → Z ) ->  (  hfg :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  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  )"]},
  {"theorem":
   "∀ (X : Type ?u.3253029) (Y : Type ?u.3253032) (Z : Type ?u.3253035) [inst : UniformSpace X] [inst_1 : UniformSpace Y]\n  [inst_2 : UniformSpace Z] (f : X → Y) (g : Y → Z),\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "round-trip":
   " The composition of two uniformly continuous maps is uniformly continuous. ",
   "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 ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  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 ) ->  (  g :  Y → Z ) ->  (  hfg :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " (  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  )"]},
  {"theorem":
   "∀ (G : Type ?u.7921826) [inst : Group G] (h : ∀ (g : G), g * g = 1) (g h : G), g * h = h * g",
   "some-correct": null,
   "round-trip":
   "If every element of a group squares to 1, then the group is abelian. ",
   "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 h  : G  )  ,   g * h =  h * g",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀   (  g  : G  )  ,   (   g * g  ) =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " (  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 ] ->  (  hG :  ∀  x   : G ,  ∃     n  ,    2 ∣ n ∧   x ^ n =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  ∀  x   : G ,  ∃     n  ,    2 ∣ n ∧   x ^ n =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  hG :  ∀  x   : G ,   x * x =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  hG :  ∀  x   : G ,   x * x =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " (  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 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀  x   : G ,   x ⁻¹ = x ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  H :  ∀   (  x  : G  )  ,   x ≠  1 →   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  ∀   (  x  : G  )  ,   x ≠  1 →   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " (  G :  Type* ) ->  [  Group  G ] ->  (  o2 :  ∀  x   : G ,   x ≠  1 ∧   x ^  2 =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  o2 :  ∀  x   : G ,   x ≠  1 ∧   x ^  2 =  1 ) ->  ∀  x y   : G ,   x * y =  y * x"]},
  {"theorem": "∀ (n : ℕ), (n + 1) * n % 2 = 0",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  k :  ℕ ) ->  Even   (   k *  (   k +  1  )  )",
    " (  n :  ℕ ) ->     (   n +  1  ) * n %  2 =  0",
    " (  m n :  ℕ ) ->  (  h :  m = n.succ ) ->  Even   (   m * n  )",
    " (  m :  ℕ ) ->   2 ∣   (   m +  1  ) * m",
    " (  n :  ℕ ) ->    n *  (   n +  1  ) %  2 =  0",
    " (  n :  ℕ ) ->  Even   (   n *  (   n +  1  )  )",
    " (  m :  ℕ ) ->  (  h1 :  m ≥  2 ) ->   2 ∣  m *  (   m -  1  )",
    " (  n :  ℕ ) ->   2 ∣  n *  (   n +  1  )",
    " (  m n :  ℕ ) ->  (  h :   m =  (   n +  1  ) ∨  n =  (   m +  1  ) ) ->   2 ∣  (   m * n  )",
    " (  n :  ℕ ) ->  Even   (   n *  (   n +  1  )  )",
    " (  n :  ℕ ) ->     (   n +  1  ) * n %  2 =  0",
    " (  m n :  ℕ ) ->  (  h :   m +  1 = n ) ->  (    2 ∣  m * n  )"]},
  {"theorem":
   "∀ (G : Type ?u.8891559) [inst : Groupₓ G] (H : Set G), (∀ (x : G), x ∈ H → x * x⁻¹ ∈ H) → IsSubgroup H",
   "some-correct": null,
   "round-trip": "**Subgroups** ",
   "prompt": "Every index 2 subgroup of a group is normal.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  hH :  ∀  x  ,   x ∈ H →   x *  x ⁻¹ ∈ H ) ->  IsSubgroup  H",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Subgroup  G ) ->  (  hH :  ∀  h   : H ,   h ^  2 =  1 ) ->  IsNormalSubgroup  H",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  (  H :  Set  G ) ->  (  H_contains_id :   1 ∈ H ) ->  (  H_inverse :  ∀  h  ∈ H ,   h ⁻¹ ∈ H ) ->  IsSubgroup  H"]},
  {"theorem": "∀ (n : ℕ), n > 1 → ∃ p, Nat.Prime p ∧ p ∣ n",
   "some-correct": null,
   "round-trip":
   "If `n` is greater than 1 then there is a prime number dividing it. ",
   "prompt":
   "Every natural number greater than `1` is divisible by a prime number. ",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  :  ℕ ,   Nat.Prime  p ∧  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  ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃     n'  :  ℕ ,   Prime  n' ∧  n' ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  :  ℕ ,   Prime  p ∧  p ∣ n"]},
  {"theorem":
   "∀ (G : Type ?u.18740466) [inst : Group G] [inst_1 : Fintype G], (∀ (x : G), x ≠ 1 → x = 1) → ∃ x, x ≠ 1 → x = 1",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "A finite torsion-free group is trivial",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  G :  Type* ) ->  [  Group  G ] ->  [  Fintype  G ] ->  (  h :  ∀  x   : G ,   x ≠  1 →  x =  1 ) ->  ∃     x  : G ,   x ≠  1 →  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  ∀  x   : G ,   x ≠  1 →  x =  1 ) ->  ∃     x  : G ,   x ≠  1 →  x =  1",
    " (  G :  Type* ) ->  [  Group  G ] ->  [  Fintype  G ] ->  (  hG :  ∀  g  ,   g ≠  1 →  ∀  n  ,   g ^ n ≠  1 ) ->  ∀  x  ,  x =  1",
    " (  G :  Type* ) ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hG :  ∀  g  ,   g ≠  1 →  ∀  n  ,   g ^ n ≠  1 ) ->  ∀  x  ,  x =  1"]},
  {"theorem":
   "∀ (D : Type ?u.18789876) [inst : DivisionRing D] [inst_1 : Fintype D], IsField D",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  HD :  Fintype  D ) ->  Field  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  (  hD_fin :  Finite  D ) ->  IsField  D",
    " (  D :  Type* ) ->  [  DivisionRing  D ] ->  [  Fintype  D ] ->  Field  D",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [ Fin :  Fintype  R ] ->  Field  R",
    " (  R :  Type* ) ->  [  DivisionRing  R ] ->  [ Finₓ :  Fintype  R ] ->  Field  R"]},
  {"theorem":
   "∀ (X : Type ?u.19089068) [inst : TopologicalSpace X], Finite X → CompactSpace X",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every finite topological space is compact",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_finite :  Finite  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_finite :  Fintype  X ) ->  (  hX_open :  ∀  s   :  Set  X ,   IsOpen  s →   s ≠  ∅ →  ∃     x  : X ,  x ∈ s ) ->  ∀  s   :  Set  X ,   IsOpen  s →  ∃     y  : X ,  y ∈ s",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_finite :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  (  U :  Set  X ) ->  (  hU :  IsOpen  U ) ->  ∃     V  :  Set  X ,   IsOpen  V ∧  V ⊆ U",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX :  Finite  X ) ->  (  U :  Set  X ) ->  (  hU :  IsOpen  U ) ->  ∃      _  :  Set  X ,   IsOpen   _ ∧   _ ⊆ U",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  [  Fintype  X ] ->  (  hX :  ∀  U   :  Set  X ,   IsOpen  U →  ∃     V  :  Set  X ,   IsOpen  V ∧  V ⊆ U ) ->  CompactSpace  X",
    " {  X :  Type* } ->  [  TopologicalSpace  X ] ->  (  hXf :  Fintype  X ) ->  CompactSpace  X",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  hX_fin :  Fintype  X ) ->  CompactSpace  X"]},
  {"theorem": "∀ (n : ℕ), 0 < n → 2 ∣ n → ∃ p q, Prime p ∧ Prime q ∧ n = p + q",
   "some-correct": null,
   "round-trip":
   "Every natural number `n` greater than `0` is the sum of two primes. ",
   "prompt":
   "Every positive even integer can be written as the sum of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  hn :  n ≠  0 ) ->  (  h2 :   0 ≤  n %  2 ) ->  (  hn2 :   n %  2 ≤  1 ) ->  (  h :   4 ∣ n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  hn0 :   0 < n ) ->  (  heven :   (   2   :  ℕ ) ∣ n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  h :    0 < n ∧  Even  n ) ->  ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧  n =  a + b",
    " (  n :  ℕ ) ->  (  h :    0 < n ∧  Even  n ) ->  ∃     x  y  :  ℕ ,   Prime  x ∧   Prime  y ∧   x + y = n",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧   n %  2 =  0 ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->    2 ≤ n →  ∃     p  q  :  ℕ ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  hn :   0 <  n + n ) ->  (  h :  ∀  k   :  ℕ ,    2 ≤ k →  ∃     i  j  :  ℕ ,   Prime  i ∧   Prime  j ∧   i + j = k ) ->  ∃     i  j  :  ℕ ,   Prime  i ∧   Prime  j ∧   i + j =  n + n",
    " (  p :  ℕ ) ->  (  h :   p ≥  2 ∧  ∀  n   :  ℕ ,   n ∣ p →   n =  1 ∨  n = p ) ->  (  h2 :  ∃    (   m  k :  ℕ )  (   hm :   m ≥  2 ∧   k ≥  2 ∧  ∀  n   :  ℕ ,   n ∣ m →   n =  1 ∨  n = m )  (   hk :   k ≥  2 ∧  ∀  n   :  ℕ ,   n ∣ k →   n =  1 ∨  n = k ) ,  p =  m + k ) ->  ∃    (   m  k :  ℕ ) ,  p =  m + k",
    " (  n :  ℕ ) ->  (  h :    0 < n ∧  Even  n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hn :   n ≥  2 ∧   2 ∣ n ) ->  ∃     p  q  :  ℕ ,   Prime  p ∧   Prime  q ∧  n =  p + q",
    " (  n :  ℕ ) ->  (  hn :   0 <   2 * n ) ->  (  hpn :  ∀  p m   :  ℕ ,     0 < p ∧  p ≤   2 * n →  ∀  m  < p ,   ¬  Prime  p ↔   m * m ≤ p ) ->  ∃     p  q  :  ℕ ,    0 < p ∧   p ≤ n ∧    0 < q ∧   q ≤ n ∧   Prime  p ∧  Prime  q"]},
  {"theorem": "∀ (n : ℕ), Even (n * n) → Even n",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "If the square of a number is even, the number itself is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h2dvd :   2 ∣  n ^  2 ) ->   2 ∣ n",
    " (  n :  ℕ ) ->  (  h2m :   2 ∣  n ^  2 ) ->   2 ∣ n",
    " (  n :  ℕ ) ->  (  hn :  Even   (   n * n  ) ) ->  Even  n",
    " (  n :  ℕ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  n :  ℤ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  n :  ℤ ) ->  (  h :    n ^  2 %  2 =  0 ) ->   n %  2 =  0",
    " (  a :  ℤ ) ->  (  h :    a ^  2 %  2 =  0 ) ->   a %  2 =  0",
    " (  n :  ℕ ) ->  (  hn2 :    n ^  2 %  2 =  0 ) ->   n %  2 =  0",
    " (  n :  ℕ ) ->  (  hn_even :  Even   (   n ^  2  ) ) ->  Even  n",
    " (  x :  ℤ ) ->  ∃     n  :  ℕ ,   x =   2 * n →  ∃     m  :  ℕ ,  x =   2 * m",
    " (  n :  ℤ ) ->     n ^  2 %  2 =  0 →   n %  2 =  0",
    " (  n :  ℕ ) ->   Even   (   n * n  ) →  Even  n",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,     2 * m =  n ^  2 →  ∃     k  :  ℕ ,    2 * k = n",
    " (  n :  ℕ ) ->  ∃     m  :  ℕ ,   n * n =   2 * m",
    " (  n :  ℕ ) ->  (  hn2 :   2 ∣  n ^  2 ) ->   2 ∣ n"]},
  {"theorem":
   "∀ (X : Type ?u.21345453) [inst : TopologicalSpace X] (A : Set X), (∀ (x : X), x ∈ A → ∃ U, IsOpen U ∧ x ∈ U) → IsOpen A",
   "some-correct": null,
   "round-trip":
   " If every point of a set `A` is contained in an open set, then `A` is open. ",
   "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 ] ->  (  K :  Set  X ) ->  (  hK :  ∀  x  ∈ K ,  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  K",
    " (  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  : X  )  ,   x ∈ A →  ∃     U  :  Set  X ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A",
    " (  X :  Type* ) ->  [  TopologicalSpace  X ] ->  (  A :  Set  X ) ->  (  hA :  ∀  x  ,   x ∈ A →  ∃     U  ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  A"]},
  {"theorem":
   "∀ (a b : ℕ), a > 0 → b > 0 → gcd a b = 1 → ∀ (n : ℕ), ∃ x y, n = a * x + b * y",
   "some-correct": null,
   "round-trip":
   "If `a` and `b` are positive and coprime, then every natural number `n` can be written as `a * x + b * y` for some `x` and `y`. ",
   "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 >  0 ) ->  (  h₂ :  b >  0 ) ->  (  hab :   gcd  a b =  1 ) ->  ∀  n   :  ℕ ,  ∃     x  y  :  ℕ ,  n =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :  a.coprime  b ) ->  (  N :  ℕ ) ->  (  hN :  N ≥  1 ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :  a.coprime  b ) ->  (  N :  ℕ ) ->  (  hN :  N ≥ a ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :   gcd  a b =  1 ) ->  (  N :  ℕ ) ->  ∃    (   x  y :  ℕ ) ,   x + y = N",
    " (  a b :  ℕ ) ->  (  h :  a.coprime  b ) ->  (  N :  ℕ ) ->  (  hn :   (  N   :  ℤ ) ≥  a * b ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :   gcd  a b =  1 ) ->  (  N :  ℕ ) ->  (  hnN :   a * N > b ) ->  ∃     x  y  :  ℕ ,  N =   a * x +  b * y"]},
  {"theorem": "(F : Type ?u.24335175) → [inst : Field F] → CommRing F",
   "some-correct": null,
   "round-trip": " `Field` is a subtype of `CommRing`. ",
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  F :  Type* ) ->  [  Field  F ] ->  CommRing  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  CommRingₓ  F",
    " (  K :  Type* ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type* ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type* ) ->  [  Field  F ] ->  Ringₓ  F",
    " (  𝕜 :  Type* ) ->  [  Field  𝕜 ] ->  Ring  𝕜",
    " (  𝕜 :  Type* ) ->  [  Field  𝕜 ] ->  Ringₓ  𝕜",
    " (  R :  Type* ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type* ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  α :  Type* ) ->  [  Field  α ] ->  Ring  α",
    " (  α :  Type* ) ->  [  Field  α ] ->  Ringₓ  α",
    " (  K :  Type* ) ->  [  Field  K ] ->  CommRing  K",
    " (  K :  Type* ) ->  [  Field  K ] ->  CommRingₓ  K"]},
  {"theorem": "(R : Type ?u.24628005) → [inst : Ringₓ R] → Group (Units R)",
   "some-correct": null,
   "round-trip": "The group of units of a ring is a group. ",
   "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 ] ->  Group   (   Units  R  )",
    " {  R :  Type* } ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type* ) ->  [  CommRingₓ  R ] ->  Groupₓ   (   Units  R  )"]},
  {"theorem": "∀ (n : ℕ), 0 < n → ∃ m k, m ^ 2 + k ^ 2 = n",
   "some-correct": null,
   "round-trip":
   "Every natural number `n` greater than zero is the sum of two squares. ",
   "prompt": "There are infinitely many Pythagorean triples.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h :   0 < n ) ->  ∃     m  :  ℕ ,  ∃     k  :  ℕ ,    m ^  2 +  k ^  2 = n",
    " (  n :  ℕ ) ->  ∃     a  b  c  :  ℕ ,     a ^  2 +  b ^  2 =  c ^  2 ∧    a + b + c =   3 * n",
    " Nonempty   (    ℕ →   ℕ →  ℕ  )",
    " ∃     a  b  c  :  ℕ ,    a ^  2 +  b ^  2 =  c ^  2",
    " ∀  n   :  ℕ ,  ∃     x  y  z  :  ℕ ,     x ^  2 +  y ^  2 =  z ^  2 ∧   x >  0 ∧   y >  0 ∧  z >  0",
    " ∃     xs  :  (    ℕ ×   ℕ ×  ℕ  ) ,  ∀  ys   :  (    ℕ ×   ℕ ×  ℕ  ) ,   xs ≠ ys →  ¬  (   ∃     x  y  z  :  ℕ ,   ys =  (  x   ,  y , z ) ∧    x ^  2 +  y ^  2 =  z ^  2  )",
    " Nonempty   (   Finset   (    ℕ ×   ℕ ×  ℕ  )  )",
    " ∀  a b c   :  ℕ ,     a ^  2 +  b ^  2 =  c ^  2 →  ∃     a'  b'  c'  :  ℕ ,   a' ≠ a ∧   b' ≠ b ∧   c' ≠ c ∧     a' ^  2 +  b' ^  2 =  c' ^  2 ∧   a' ≤ a ∧   b' ≤ b ∧  c' ≤ c",
    " ∃    (   x  y  z :  ℤ ) ,     x ^  2 +  y ^  2 =  z ^  2 ∧   x ≠  0 ∧   y ≠  0 ∧  x ≠ y",
    " Nonempty   (   Set   (    ℕ ×   ℕ ×  ℕ  )  )"]}],
 "elaborated": 25}