{"total-prompts": 40,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["If every proper closed set of a topological space is compact, then the space itself is compact.",
  "A finite graph in which every pair of vertices have precisely one common neighbour contains a vertex that is adjacent to all other vertices.",
  "The number of partitions with odd parts is equal to the number of partitions with distinct parts.",
  "A group whose automorphism group is cyclic is Abelian.",
  "A topological space is normal if and only if any two disjoint closed subsets can be separated by a continuous function.",
  "The complement of the union of two sets is the intersection of their complements.",
  "Every 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.",
  "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."],
 "elaborated-prompts":
 [{"theorem":
   "∀ {p : ℕ} [inst : Fact (Nat.Prime p)], p % 4 = 1 % 4 → ∃ a b, a ^ 2 + b ^ 2 = p",
   "some-correct": null,
   "round-trip": "If `p % 4 = 1`, then `p` 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 :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =   1 %  4 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp0 :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  n :  ℕ } ->  (  hn :   1 < n ) ->  (  hn0 :   n %  4 =  0 ) ->  (  h1 :  Nat.Prime   (   n +  1  ) ) ->  ∃    (   x  y :  ℕ ) ,    x ^  2 +  y ^  2 =  n +  1",
    " {  p :  ℕ } ->  (  h1 :    (   p -  1  ) %  4 =  0 ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp_mod_4 :    (   p -  1  ) %  4 =  0 ) ->  ∃     x  y  :  ℤ ,     x ^  2 +  y ^  2 =  ↑ p ∧   x ≠  0 ∧  y ≠  0",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " (  p : Nat ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h0 :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  3 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp4 :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  (  hp1 :   p %  4 =  1 ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p"]},
  {"theorem":
   "∀ {a b c d : ℤ},\n  a = a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2 →\n    b = a ^ 2 + b ^ 2 + c ^ 2 + d ^ 2 → a * b = (a * c) ^ 2 + (b * d) ^ 2 + (a * d - b * c) ^ 2 + (a * b) ^ 2",
   "some-correct": null,
   "round-trip":
   "Given four integers `a`, `b`, `c`, `d`, if `a` and `b` are equal to `a^2 + b^2 + c^2 + d^2`, then `a * b` is equal to `(a * c)^2 + (b * d)^2 + (a * d - b * c)^2 + (a * b)^2`. ",
   "prompt":
   "The product of two numbers, each of which is the sum of four squares, is itself a sum of four squares.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  a b c d :  ℤ } ->  (  ha :  a =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->  (  hb :  b =     a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 ) ->   a * b =      (   a * c  ) ^  2 +   (   b * d  ) ^  2 +   (    a * d -  b * c  ) ^  2 +   (   a * b  ) ^  2",
    " {  a b c d a' b' c' d' :  ℕ } ->  (  ha :      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =     a' ^  2 +  b' ^  2 +  c' ^  2 +  d' ^  2 ) ->  ∃     x  y  z  w  :  ℕ ,      a * a' +  b * b' +  c * c' +  d * d' =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2",
    " {  x y :  ℕ } ->  (  Hx :  ∃     a  b  c  d  :  ℕ ,      a * a +  b * b +  c * c +  d * d = x ) ->  (  Hy :  ∃     e  f  g  h  :  ℕ ,      e * e +  f * f +  g * g +  h * h = y ) ->  ∃     a  b  c  d  :  ℕ ,      a * a +  b * b +  c * c +  d * d =  x * y",
    " {  a b :  ℤ } ->  (  ha :  a =      (    (    a %  2 +  2  ) /  2  ) ^  2 +   (    (    a %  4 +  4  ) /  4  ) ^  2 +   (    (    a %  8 +  8  ) /  8  ) ^  2 +   (    (    a %  16 +  16  ) /  16  ) ^  2 ) ->  (  hb :  b =      (    (    b %  2 +  2  ) /  2  ) ^  2 +   (    (    b %  4 +  4  ) /  4  ) ^  2 +   (    (    b %  8 +  8  ) /  8  ) ^  2 +   (    (    b %  16 +  16  ) /  16  ) ^  2 ) ->  ∃     x  y  z  w  :  ℤ ,   a * b =   x ^  2 +  y ^  2",
    " {  a b c d :  ℤ } ->       a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =  0 →    (    a ^  2 +  b ^  2  ) *  (    c ^  2 +  d ^  2  ) =      (    a * c +  b * d  ) ^  2 +   (    a * d -  b * c  ) ^  2 +   (    a * c -  b * d  ) ^  2 +   (    a * d +  b * c  ) ^  2",
    " {  a b :  ℤ } ->  (  h :  ∃     x  y  z  w  ,  a =     x * x +  y * y +  z * z +  w * w ) ->  (  h' :  ∃     x  y  z  w  ,  b =     x * x +  y * y +  z * z +  w * w ) ->  ∃     x  y  z  w  ,   a * b =     x * x +  y * y +  z * z +  w * w",
    " {  a b c d e f :  ℕ } ->  (  hac :      a ^  2 +  c ^  2 +  b ^  2 +  d ^  2 =   e ^  2 +  f ^  2 ) ->  (  hbc :      a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =   e ^  2 +  f ^  2 ) ->      a * c +  b * d +  b * c +  d * a =   e * f +  f * e"]},
  {"theorem":
   "∀ {α : Type u} [inst : MulOneClass α] [inst_1 : HasDistribNeg α] [inst_2 : DecidableEq α] [inst_3 : Zero α] (a b : α),\n  (∀ (x : α), x * x = x) → a * b = b * a",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  MulOneClass  α ] ->  [  HasDistribNeg  α ] ->  [  DecidableEq  α ] ->  [  Zero  α ] ->  (  a b : α ) ->  (  h :  ∀  x   : α ,   x * x = x ) ->   a * b =  b * a",
    " {  α :  Type  u } ->  [  MulOneClassₓ  α ] ->  [  HasDistribNeg  α ] ->  [  DecidableEq  α ] ->  [  Zero  α ] ->  (  a b : α ) ->  (  h :  ∀  x   : α ,   x * x = x ) ->   a * b =  b * a",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClass  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClass  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClassₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClassₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀   (  x  : α  )  ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClass  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClass  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClassₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClassₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  (  h :  ∀   (  a  : α  )  ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ring  α ] ->  (  h :  ∀  x  ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ring  α ] ->  (  h :  ∀  x  ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  ∀  x  ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  ∀  x  ,   x * x = x ) ->  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_1 } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α"]},
  {"theorem": "∀ (n : ℕ), ∃ p q, n ≤ p ∧ Prime p ∧ Prime q ∧ p + 2 = q",
   "some-correct": null,
   "round-trip":
   "For every natural number `n`, there exist two primes `p` and `q` such that `n ≤ p`, `p` and `q` are prime, and `p + 2 = q`. ",
   "prompt":
   "There are infinitely many pairs of primes that differ exactly by `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃    (   a  b :  ℕ ) ,   a < b ∧   Prime  a ∧   Prime  b ∧   b - a =  2",
    " ∀   (  n  :  ℕ  )  ,  ∃     p  q  :  ℕ ,   n ≤ p ∧   Prime  p ∧   Prime  q ∧   p +  2 = q",
    " ∃    (   x  y :  ℕ ) ,   x ≠ y ∧   Prime  x ∧   Prime  y ∧  (    x - y =  2  )",
    " (  N :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,    p %  2 =  1 ∧    q %  2 =  0 ∧    p +  2 = q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " ∃    (   p  q :  ℕ ) ,    p %  2 =  1 ∧    q %  2 =  1 ∧  (    q =  p +  2 ∨  p =  q +  2  )",
    " ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p +  2 = q",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p  p' :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  p' ∧  p =  p' +  2",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  q =  p +  2",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (  p.succ.succ  )",
    " (  n :  ℕ ) ->  ∃    (   p₁  p₂ :  ℕ ) ,   p₁ = n ∧   p₂ =  n +  2 ∧   Nat.Prime  p₁ ∧  Nat.Prime  p₂",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,    p +  2 = q ∧  p ≠ q"]},
  {"theorem":
   "∀ {K : Type u} [inst : Fintype K] [inst : DivisionRing K], IsField K",
   "some-correct": null,
   "round-trip": "A `fintype` with a `division_ring` structure is a `field`. ",
   "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 ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " {  F :  Type  u_1 } ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  IsField  F",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  F :  Type  u ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  Field  F",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  R :  Type  u ) ->  [  Fintype  R ] ->  [  DivisionRing  R ] ->  IsField  R",
    " (  k :  Type  u_1 ) ->  [  DivisionRing  k ] ->  [  Fintype  k ] ->  IsField  k"]},
  {"theorem":
   "∀ {α : Sort u_1} {β : Sort u_2} {f : α → β} {g : β → α},\n  Function.Injective f → Function.Injective g → ∃ h, Function.bijective h",
   "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":
   [" {  α :  Sort  u_1 } ->  {  β :  Sort  u_2 } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Sort  u_1 } ->  {  β :  Sort  u_2 } ->  (  f :  α → β ) ->  (  g :  β → α ) ->  (  Hf :  Function.Injective  f ) ->  (  Hg :  Function.Injective  g ) ->   Function.bijective  f ∧  Function.bijective  g",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Sort  u } ->  {  β :  Sort  v } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  Hf :  Function.Injective  f ) ->  (  Hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h"]},
  {"theorem":
   "∀ {α : Type u_1} {r : α → α → Prop},\n  (∀ (c : Set α) (a : IsChain r c), ∃ ub, ∀ (a : α), a ∈ c → r a ub) →\n    (∀ {a b c : α}, r a b → r b c → r a c) → ∃ m, ∀ (a : α), r m a → r a m",
   "some-correct": null,
   "round-trip": "**Zorn's Lemma** ",
   "prompt":
   "Every non-empty poset in which every chain has an upper bound contains a maximal element.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  (  Trans :  ∀   {  a b c  : α }  ,   r  a b →   r  b c →  r  a c ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  s :  Nonempty  α ) ->  [  SemilatticeSup  α ] ->  (  hc :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  (  Trans :  ∀   {  a b c  : α }  ,   r  a b →   r  b c →  r  a c ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  (  Trans :  ∀   {  a b c  : α }  ,   r  a b →   r  b c →  r  a c ) ->  (  hs :  Nonempty  α ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m"]},
  {"theorem":
   "∀ {α : Type ?u.1535326} {β : Type ?u.1535330} [inst : UniformSpace α] [inst_1 : UniformSpace β] {f : α → β} {g : β → α},\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "round-trip":
   " If `f : α → β` and `g : β → α` are uniformly continuous, then so is `g ∘ f`. ",
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type* } ->  {  β :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  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 :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )"]},
  {"theorem":
   "∀ {α : Type ?u.1886866} {β : Type ?u.1886870} [inst : UniformSpace α] [inst_1 : UniformSpace β] {f : α → β} {g : β → α},\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":
   [" {  α :  Type* } ->  {  β :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  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 :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  β → γ } ->  {  g :  α → β } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )"]},
  {"theorem":
   "∀ {f : Unit → Unit} {x : Unit}, Function.IsPeriodicPt f 3 x → ∀ (n : ℕ), n > 0 → Function.IsPeriodicPt f n x",
   "some-correct": null,
   "round-trip":
   "If `x` is a periodic point of `f` of period 3, then it is a periodic point of `f` of any period greater than 0. ",
   "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":
   [" {  f :  Unit → Unit } ->  {  x : Unit } ->  (  h :  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  >  0 ,  Function.IsPeriodicPt  f n x",
    " {  f :   ℤ →  ℤ } ->  (  hf :  Function.IsPeriodicPt  f  3  (   0   :  ℤ ) ) ->  (  hone :   0 <  1 ) ->  ∀   (  n  :  ℕ  )  ,    0 < n →  Function.IsPeriodicPt  f n  (   0   :  ℤ )",
    " {  α :  Type  u_1 } ->  [  OrderedAddCommMonoid  α ] ->  [  LinearOrder  α ] ->  (  f :  α → α ) ->  (  x : α ) ->  (  hf :  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  >  0 ,  ∃     y  ,  Function.IsPeriodicPt  f n y",
    " {  α :  Type  u_1 } ->  [  OrderedAddCommMonoid  α ] ->  [  LinearOrderₓ  α ] ->  (  f :  α → α ) ->  (  x : α ) ->  (  hf :  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  >  0 ,  ∃     y  ,  Function.IsPeriodicPt  f n y",
    " {  f :   ℤ →  ℤ } ->  (  h :  Function.IsPeriodicPt  f  3  0 ) ->  ∃     x  t  ,  Function.IsPeriodicPt  f t x",
    " (  f :  Unit → Unit ) ->  (  x : Unit ) ->  (  h :  Function.IsPeriodicPt  f  3 x ) ->  ∃    (   n :  ℕ ) ,   n >  0 ∧  Function.IsPeriodicPt  f n x"]},
  {"theorem":
   "∀ {C : Type u₁} [inst : CategoryTheory.Category C] [inst_1 : CategoryTheory.Limits.HasTerminal C] {T T' : C},\n  CategoryTheory.Limits.IsTerminal T →\n    CategoryTheory.Limits.IsTerminal T' → CategoryTheory.IsIso (CategoryTheory.Limits.terminal.from T')",
   "some-correct": null,
   "round-trip":
   "If `T` and `T'` are both terminal objects, then the unique morphism from `T'` to `T` is an isomorphism. ",
   "prompt":
   "A terminal object in a category is unique up to unique isomorphism.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  C :  Type  u₁ } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T T' : C } ->  (  hT :  CategoryTheory.Limits.IsTerminal  T ) ->  (  hT' :  CategoryTheory.Limits.IsTerminal  T' ) ->  CategoryTheory.IsIso   (   CategoryTheory.Limits.terminal.from  T'  )",
    " {  C :  Type  u } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  A : C } ->  (  hA :  CategoryTheory.Limits.IsTerminal  A ) ->  {  B : C } ->  (  hB :  CategoryTheory.Limits.IsTerminal  B ) ->  CategoryTheory.IsIso   (   hB.from  A  )",
    " {  C :  Type  u } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T T' : C } ->  (  hT :  CategoryTheory.Limits.IsTerminal  T ) ->  (  hT' :  CategoryTheory.Limits.IsTerminal  T' ) ->  CategoryTheory.IsIso   (   hT.from  T'  )",
    " {  C :  Type  u } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T₁ T₂ : C } ->  (  hT₁ :  CategoryTheory.Limits.IsTerminal  T₁ ) ->  (  hT₂ :  CategoryTheory.Limits.IsTerminal  T₂ ) ->  CategoryTheory.IsIso   (   CategoryTheory.Limits.terminal.from  T₂  )"]},
  {"theorem": "∀ {x y z : ℕ}, (x + y) ^ 3 = z ^ 3 → x = 0 ∧ y = 0 ∧ z = 0",
   "some-correct": null,
   "round-trip":
   " If `(x + y) ^ 3 = z ^ 3`, then `x = 0`, `y = 0` and `z = 0`. ",
   "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 :  ℕ } ->  (  h :    (   x + y  ) ^  3 =  z ^  3 ) ->   x =  0 ∧   y =  0 ∧  z =  0",
    " (  x y z :  ℤ ) ->  (  h₁ :   0 < x ) ->  (  h₂ :   0 < y ) ->  (  h₃ :   0 < z ) ->  ¬    x ^  3 +  y ^  3 =  z ^  3"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Group G], (∀ (a : G), a * a = 1) → ∀ (a b : G), a * b = b * a",
   "some-correct": null,
   "round-trip": "If every element 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  u_1 } ->  [  Group  G ] ->  {  a b : G } ->  (  h :  ∀   (  g  : G  )  ,   g =  1 ∨  g =  -  1 ) ->   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  {  a b : G } ->  (  h :  ∀   (  g  : G  )  ,   g =  1 ∨  g =  -  1 ) ->   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀  a   : G ,   a * a =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀  a   : G ,   a * a =  1 ) ->  ∀   (  a b  : G  )  ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  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 ) ->  (  a b : G ) ->   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀  g   : G ,   g * g =  1 ) ->  (  a b : G ) ->   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀  a   : G ,   a * a =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀  a   : G ,   a * a =  1 ) ->  ∀  a b   : G ,   a * b =  b * a",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  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  )"]},
  {"theorem": "∀ {n : ℕ}, Even (n * (n + 1))",
   "some-correct": null,
   "round-trip": " If `n` is a natural number, then `n * (n + 1)` is even. ",
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " {  m :  ℕ } ->  (  h :  m ≠  0 ) ->  Even   (   m *  (   m +  1  )  )",
    " {  m :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " (  m :  ℕ ) ->  Even   (   m *  (   m +  1  )  )"]},
  {"theorem":
   "∀ {α : Type u} {s : Set α} [inst : Groupₓ α], (∃ x, x ^ 2 = 1) → (s ∩ s⁻¹ = ∅ → IsSubgroup s) → IsNormalSubgroup s",
   "some-correct": null,
   "round-trip": "**Normal Subgroups** ",
   "prompt": "Every index 2 subgroup of a group is normal.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  {  s :  Set  α } ->  [  Groupₓ  α ] ->  (  h₁ :  ∃     x  : α ,   x ^  2 =  1 ) ->  (  h₂ :    s ∩  s ⁻¹ =  ∅ →  IsSubgroup  s ) ->  IsNormalSubgroup  s"]},
  {"theorem": "∀ {α : Type u_1}, Monoidₓ.IsTorsionFree (FreeGroup α)",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every free group is torsion free.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u_1 ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->   @ Monoidₓ.IsTorsionFree   (   FreeGroup  α  )  _",
    " {  α :  Type* } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u ) ->  [  DecidableEq  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  X :  Type  u ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  X  )",
    " {  α :  Type  u_1 } ->  [  Group  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u_1 } ->  [  Groupₓ  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )"]},
  {"theorem": "∀ (n : ℕ), 1 < n → ∃ p, Nat.Prime p ∧ p ∣ n",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every natural number greater than `1` is divisible by a prime number. ",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ )  (   hp :  Nat.Prime  p ) ,  p ∣ n",
    " {  n :  ℕ } ->  (  h :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  hn :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃     p  ,   p ∣ n ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃    (   q :  ℕ ) ,   Nat.Prime  q ∧  q ∣ n"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Groupₓ G] [inst_1 : Fintype G], Monoidₓ.IsTorsionFree G → Fintype.card G = 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  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->   Monoidₓ.IsTorsionFree  G →  G =  1",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  tfG :  Monoidₓ.IsTorsionFree  G ) ->   ¬  Monoidₓ.IsTorsion  G →  G =  1",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  hG :  Monoidₓ.IsTorsionFree  G ) ->    @ Fintype.card  G  _ =  1"]},
  {"theorem":
   "∀ {K : Type u} [inst : Fintype K] [inst : DivisionRing K], IsField K",
   "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":
   [" {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " {  F :  Type  u_1 } ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  IsField  F",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  F :  Type  u ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  Field  F",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  R :  Type  u ) ->  [  Fintype  R ] ->  [  DivisionRing  R ] ->  IsField  R",
    " (  k :  Type  u_1 ) ->  [  DivisionRing  k ] ->  [  Fintype  k ] ->  IsField  k"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] [inst_1 : Fintype α], IsCompact Set.Univ",
   "some-correct": null,
   "round-trip": "The space `α` is compact if it is finite. ",
   "prompt": "Every finite topological space is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hf :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hfin :  Finite  α ) ->  IsCompact  α"]},
  {"theorem":
   "∀ {n : ℕ}, 0 < n → n % 2 = 0 → ∃ a b, Nat.Prime a ∧ Nat.Prime b ∧ n = a + b",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every positive even integer can be written as the sum of two primes.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  hn :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a + b",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  hev :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a + b",
    " (  n :  ℕ ) ->  (  hpos :   0 <   2 * n ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b =   2 * n",
    " {  n :  ℕ } ->  (  h :    2 ≤ n ∧   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " {  n :  ℕ } ->  (  h :    0 < n ∧  Even  n ) ->  ∃    (   a  b :  ℕ ) ,   a >  1 ∧   b >  1 ∧    a + b = n ∧   Nat.Prime  a ∧  Nat.Prime  b",
    " ∀   (  n  :  ℕ  )  ,   n >  0 →    n %  2 =  0 →  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p + q",
    " {  n :  ℕ } ->  (  hn :   0 < n ) ->  (  even_n :   2 ∣ n ) ->  ∃    (   p₁  p₂ :  ℕ ) ,   Nat.Prime  p₁ ∧   Nat.Prime  p₂ ∧   p₁ + p₂ = n",
    " (  n :  ℕ ) ->  (  h0 :  n ≠  0 ) ->  (  he :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n"]},
  {"theorem":
   "∀ {R : Type u} {n : Type v} [inst : CommRingₓ R] [inst_1 : DecidableEq n] [inst_2 : Fintype n] (M : Matrix n n R),\n  AlgHom.toFun (Polynomial.aeval M) (Matrix.charpoly M) = 0",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every matrix satisfies its own characteristic polynomial.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u } ->  {  n :  Type  v } ->  [  CommRingₓ  R ] ->  [  DecidableEq  n ] ->  [  Fintype  n ] ->  (  M :  Matrix  n n R ) ->   Polynomial.aeval  M M.charpoly =  0"]},
  {"theorem": "∀ {n : ℕ}, n ^ 2 % 2 = 0 → n % 2 = 0",
   "some-correct": null,
   "round-trip":
   "If the square of a natural number is even, then the number is even. ",
   "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",
    " {  n :  ℕ } ->   Even   (   n * n  ) →  Even  n",
    " {  n :  ℕ } ->   Even   (   n ^  2  ) →  Even  n",
    " {  α :  Type  u } ->  [  Ring  α ] ->  {  x : α } ->  (  hx :  Even   (   x * x  ) ) ->  Even  x",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  {  x : α } ->  (  hx :  Even   (   x * x  ) ) ->  Even  x",
    " {  α :  Type  u } ->  [  Field  α ] ->  (  a : α ) ->  (  h :    a * a %  2 =  0 ) ->   a %  2 =  0",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a : α } ->  (  h :  Even   (   a * a  ) ) ->  Even  a",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a : α } ->  (  h :  Even   (   a * a  ) ) ->  Even  a",
    " {  n :  ℕ } ->  ∀   {  n  :  ℕ }  ,   Even   (   n * n  ) →  Even  n",
    " {  R :  Type  u } ->  [  LinearOrderedRing  R ] ->  {  a : R } ->   Even   (   a * a  ) →  Even  a",
    " {  α :  Type  u } ->  [  Ring  α ] ->  {  a : α } ->  (  h :  Even   (   a * a  ) ) ->  Even  a",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  {  a : α } ->  (  h :  Even   (   a * a  ) ) ->  Even  a",
    " {  m m' :  ℕ } ->  (  hmm' :   m ^  2 =  m' *  2 ) ->    Even  m ∧  Even  m' →  Even   (   m + m'  )"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α} {t : Set α},\n  (∀ (x : α), x ∈ t → ∃ u, x ∈ u ∧ IsOpen u) → s ⊂ t → IsOpen s",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  hts :  ∀   (  x  : α  )  ,   x ∈ t →  ∃    (   u :  Set  α ) ,   x ∈ u ∧  IsOpen  u ) ->   (   s ⊆ t  ) →  (   IsOpen  s  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  u v :  Set  α } ->  (  hu :  ∀   (  x  : α  )  ,   x ∈ u →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  (  hv :  u ⊆ v ) ->  IsOpen  v",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     u  ,   IsOpen  u ∧  x ∈ u ) ->  IsOpen  s",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃    (   u :  Set  α ) ,   x ∈ u ∧  IsOpen  u ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   {  x  }  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   x ∈ t ∧  IsOpen  t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  S :  Set  α } ->  (  hS :  ∀  x  ∈ S ,  ∃     U  :  Set  α ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  S",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  :  Set  α ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s"]},
  {"theorem": "∀ {α : Type u} (g : FreeGroup α), g ≠ 1 → ¬IsOfFinOrder g",
   "some-correct": null,
   "round-trip":
   " If a free group element is not trivial, then it is not of finite order. ",
   "prompt": "Every non-identity element of a free group is of infinite order.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->  (  h :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  (  x :  FreeGroup  α ) ->  (  H :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->  (  hg :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  (  x :  FreeGroup  α ) ->  (  H :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  {  x :  FreeGroup  α } ->  (  H :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  {  x :  FreeGroup  α } ->   x ≠  1 →  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->  (  h :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  {  x :  FreeGroup  α } ->  ¬  IsOfFinOrder  x"]},
  {"theorem":
   "∀ {a b N : ℕ}, Nat.gcd a b = 1 → N > a * b → ∃ x y, N = a * x + b * y",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 N :  ℕ } ->  (  h :   a.gcd  b =  1 ) ->  (  hN :  N >  a * b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b N :  ℕ } ->  (  h1 :    ↑ a.gcd  b =  1 ) ->  (  h2 :  N >  0 ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  h1 :  a.coprime  b ) ->  (  h2 :  a >  0 ) ->  (  h3 :  b >  0 ) ->  {  N :  ℕ } ->  (  h4 :  N ≥  a + b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  h :   a.gcd  b =  1 ) ->  (  N :  ℕ ) ->  (  hN :  N ≥  a + b ) ->  ∃    (   x  y :  ℕ ) ,    a * x +  b * y = N",
    " {  a b :  ℤ } ->  (  hab :   a.gcd  b =  1 ) ->  (  N :  ℕ ) ->  ∃    (   x :  ℕ )  (   y :  ℕ ) ,   ↑ N =    ↑  a *  x +   ↑  b *  y",
    " {  a b :  ℕ } ->  (  h :   a.gcd  b =  1 ) ->  ∀   (  N  :  ℕ  )  ,  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  hab :   gcd  a b =  1 ) ->  (  N :  ℕ ) ->  ∃    (   x  y :  ℕ ) ,   ↑ N =   x *  ↑ a +  y *  ↑ b"]},
  {"theorem": "(R : Type u) → [inst : Field R] → Ring R",
   "some-correct": null,
   "round-trip": "A field is a ring. ",
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ringₓ  F",
    " (  F :  Type  u₁ ) ->  [  Field  F ] ->  [  Ring  F ] ->  Ring  F",
    " (  F :  Type  u₁ ) ->  [  Field  F ] ->  [  Ring  F ] ->  Ringₓ  F",
    " (  F :  Type  u₁ ) ->  [  Field  F ] ->  [  Ringₓ  F ] ->  Ring  F",
    " (  F :  Type  u₁ ) ->  [  Field  F ] ->  [  Ringₓ  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",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type  u ) ->  [  Field  F ] ->  Ringₓ  F",
    " {  F :  Type  u } ->  [  Field  F ] ->  (  x y : F ) ->    x * y -  0 =  x * y",
    " (  K :  Type  u₁ ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u₁ ) ->  [  Field  K ] ->  Ringₓ  K",
    " {  α :  Type  u } ->  [  Field  α ] ->  Ring  α",
    " {  α :  Type  u } ->  [  Field  α ] ->  Ringₓ  α",
    " {  R :  Type  v } ->  [  Field  R ] ->  Ring  R",
    " {  R :  Type  v } ->  [  Field  R ] ->  Ringₓ  R"]},
  {"theorem":
   "{α : Type u} → [inst : Ringₓ α] → [inst_1 : Semiring (Units α)] → GroupWithZero (Units α)",
   "some-correct": null,
   "round-trip": "The type of units of a ring is a group with zero. ",
   "prompt": "The set of units in a ring forms a group.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Semiring   (   Units  α  ) ] ->  GroupWithZero   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Semiring   (   Units  α  ) ] ->  GroupWithZeroₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Semiringₓ   (   Units  α  ) ] ->  GroupWithZero   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Semiringₓ   (   Units  α  ) ] ->  GroupWithZeroₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  Inv  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  [  Inv  R ] ->  Groupₓ   (   Units  R  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  GroupWithZero   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  GroupWithZeroₓ   (   Units  α  )",
    " {  R :  Type* } ->  [  CommRingₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type* } ->  [  CommRingₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  [  Inv  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Monoidₓ  α ] ->  [  Inv  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )"]},
  {"theorem":
   "∀ {G G₁ : Type u_1} [inst : Groupₓ G] [inst_1 : Groupₓ G₁],\n  Monoidₓ.IsTorsionFree (G × G₁) → Monoidₓ.IsTorsionFree G ∧ Monoidₓ.IsTorsionFree G₁",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 G₁ :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  G₁ ] ->   Monoidₓ.IsTorsionFree   (   G × G₁  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  G₁",
    " {  G :  Type  u_1 } ->  {  H :  Type  u_2 } ->  [  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  ) ] ->  (  tfGs :  ∀   (  i  : η  )  ,  Monoidₓ.IsTorsionFree   (   Gs  i  ) ) ->  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  )",
    " {  G :  Type  u_1 } ->  {  H :  Type  u_2 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  [  Fintype  G ] ->  [  Fintype  H ] ->  (  g : G ) ->  (  h : H ) ->   (   Monoidₓ.IsTorsionFree   (   G × H  )  ) →  (    Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H  )",
    " (  G H :  Type  u_1 ) ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  (  tfGH :  Monoidₓ.IsTorsionFree   (   G × H  ) ) ->   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  H :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  G H :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  (  tfGH :  Monoidₓ.IsTorsionFree   (   G × H  ) ) ->   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  G H :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->   Monoidₓ.IsTorsionFree   (   G × H  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H"]}],
 "elaborated": 29}