{"total-prompts": 42,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 10,
 "number-keyword-sentences": 4,
 "include-fixed": false,
 "failures":
 ["A finite graph in which every pair of vertices have precisely one common neighbour contains a vertex that is adjacent to all other vertices.",
  "The number of partitions with odd parts is equal to the number of partitions with distinct parts.",
  "A topological space is normal if and only if any two disjoint closed subsets can be separated by a continuous function.",
  "A finitely-presented group containing a torsion element is finite.",
  "The complement of the union of two sets is the intersection of their complements.",
  "Every index 2 subgroup of a group is normal.",
  "The square root of an irrational number is irrational.",
  "In a finite commutative ring, all prime ideals are maximal.",
  "An element of a discrete valuation ring is a unit if and only if it has a valuation of zero."],
 "elaborated-prompts":
 [{"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] (h : ∀ (s : Set α), IsClosed s → IsCompact s → IsCompact s),\n  IsCompact (?m.52413 h)",
   "some-correct": null,
   "round-trip":
   " If every closed subset of a topological space is compact, then the space is compact. ",
   "prompt":
   "If every proper closed set of a topological space is compact, then the space itself is compact.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  s  :  Set  α  )  ,   IsClosed  s →   IsCompact  s →  IsCompact  s ) ->  IsCompact  α",
    " {  X :  Type* } ->  [  TopologicalSpace  X ] ->  (  H :  ∀  K  ,   IsClosed  K →   K ≠ X →  IsCompact  K ) ->  IsCompact  X",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  T2Space  α ] ->  (  hα :  ∀   (  S  :  Set  α  )  ,   IsClosed  S →  IsCompact  S ) ->  IsCompact  α"]},
  {"theorem": "∀ {p : ℕ}, p % 4 = 1 → Prime p → ∃ a b, a ^ 2 + b ^ 2 = p",
   "some-correct": null,
   "round-trip":
   "If `p` is a prime congruent to 1 mod 4, then it 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": true,
   "comments": "",
   "all-elabs":
   [" {  p :  ℕ } ->  (  hp :   p %  4 =  1 ) ->  (  h :  Prime  p ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   (     p %  2 =  1 ∧   p %  4 =  1  ) ∨  (     p %  2 =  1 ∧   p %  4 =  3  ) ) ->  ∃    (   x  y :  ℕ ) ,    x ^  2 +  y ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  [ hp :  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  (  h1 :   p %  4 =  1 ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  {  x :  ℕ } ->  (  hx :  p =    4 * x +  1 ) ->  ∃     a  b  :  ℕ ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  ∃     a  b  :  ℕ ,     (   a ^  2  ) +  (   b ^  2  ) = p ↔   p %  4 =  1",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :   p %  4 =  (   1   :  ℕ ) ) ->  ∃    (   a  b :  ℤ ) ,    a ^  2 +  b ^  2 =  ↑ p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->    p %  4 =  1 →  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp4 :   p %  4 =  3 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p"]},
  {"theorem":
   "∀ {a b : ℤ},\n  ∃ x y z w,\n    a = x ^ 2 + y ^ 2 + z ^ 2 + w ^ 2 ∧ b = x ^ 2 + y ^ 2 + z ^ 2 + w ^ 2 →\n      ∃ 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 squares, then `a * b` is also a sum of squares. ",
   "prompt":
   "The product of two numbers, each of which is the sum of four squares, is itself a sum of four squares.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  a b :  ℤ } ->  ∃    (   x  y  z  w :  ℤ ) ,    a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ∧  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 →  ∃    (   x  y  z  w :  ℤ ) ,   a * b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2",
    " {  x y :  ℤ } ->   (   ∃    (   a  b  c  d :  ℤ ) ,      a * a +  b * b +  c * c +  d * d = x  ) →   (   ∃    (   a  b  c  d :  ℤ ) ,      a * a +  b * b +  c * c +  d * d = y  ) →  ∃    (   a  b  c  d :  ℤ ) ,      a * a +  b * b +  c * c +  d * d =  x * y",
    " {  a b c d e f :  ℕ } ->  (  ha₁ :      a * a +  b * b +  c * c +  d * d =   e * e +  f * f ) ->      a * a +  b * b +  c * c +  d * d =   e * e +  f * f",
    " {  n m :  ℕ } ->  (  h1n :  ∃    (   a  b  c  d :  ℕ ) ,      a * a +  b * b +  c * c +  d * d = n ) ->  (  h1m :  ∃    (   a  b  c  d :  ℕ ) ,      a * a +  b * b +  c * c +  d * d = m ) ->  ∃    (   a  b  c  d  e  f  g  h :  ℕ ) ,          a * a +  b * b +  c * c +  d * d +  e * e +  f * f +  g * g +  h * h =  m * n",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  a b : α } ->  (  h :   (   ∃     x  y  z  w  : α ,      x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 = a  ) ∧  (   ∃     x  y  z  w  : α ,      x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 = b  ) ) ->  (   ∃     x  y  z  w  : α ,      x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 =  a * b  )"]},
  {"theorem":
   "{R : Type u} → [inst : CommRing R] → (∀ (x : R), x * x = x) → CommRing R",
   "some-correct": null,
   "round-trip":
   "If `R` is a commutative ring and `∀ (x : R), x * x = x`, then `R` is a commutative ring. ",
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u } ->  [  CommRing  R ] ->  (  H :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  CommRing  R ] ->  (  H :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  (  H :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  (  H :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  Nontrivial  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  Commutative  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Nontrivial  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  Commutative  α",
    " {  R :  Type  u } ->  [  NonAssocRing  R ] ->  [  Fintype  R ] ->  (  x : R ) ->  (  hx :  ∀  y  ,   y * y = y ) ->  AddCommute  x x",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClass  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  ∀  x y   : α ,   x * y =  y * x",
    " {  α :  Type  u } ->  [  Ring  α ] ->  [  MulOneClassₓ  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  ∀  x y   : α ,   x * y =  y * x",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  ∀  x y   : α ,   x * y =  y * x",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  (  h :  ∀  x   : α ,   x ^  2 = x ) ->  ∀  x y   : α ,   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",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  x  ,   x ^  2 = x ) ->  CommRingₓ  α",
    " (  R :  Type  u ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type  u ) ->  [  Ring  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRing  R",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  h :  ∀  x   : R ,   x * x = x ) ->  CommRingₓ  R",
    " {  G :  Type  u } ->  [  Ring  G ] ->  [  MulOneClass  G ] ->  (  x y : G ) ->  (  h :  ∀  z  ,   z * z = z ) ->   x * y =  y * x",
    " {  G :  Type  u } ->  [  Ring  G ] ->  [  MulOneClassₓ  G ] ->  (  x y : G ) ->  (  h :  ∀  z  ,   z * z = z ) ->   x * y =  y * x",
    " {  G :  Type  u } ->  [  Ringₓ  G ] ->  [  MulOneClass  G ] ->  (  x y : G ) ->  (  h :  ∀  z  ,   z * z = z ) ->   x * y =  y * x",
    " {  G :  Type  u } ->  [  Ringₓ  G ] ->  [  MulOneClassₓ  G ] ->  (  x y : G ) ->  (  h :  ∀  z  ,   z * z = z ) ->   x * y =  y * x",
    " {  R :  Type  u } ->  [  Ring  R ] ->  (  e :  ∀   (  a  : R  )  ,   a * a = a ) ->  AddCommute   1  1",
    " {  R :  Type  u } ->  [  Ringₓ  R ] ->  (  e :  ∀   (  a  : R  )  ,   a * a = a ) ->  AddCommute   1  1",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRingₓ  α"]},
  {"theorem":
   "∀ (n : ℕ), ∃ p₁ p₂, Nat.Prime p₁ ∧ Nat.Prime p₂ ∧ p₁ + 2 = p₂ ∧ 2 * n < p₂",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "There are infinitely many pairs of primes that differ exactly by `2`.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" ¬  BddAbove   {   p   :  ℕ |  ∃    (   q  r :  ℕ ) ,   r =  q +  2 ∧   Nat.Prime  q ∧  Nat.Prime  r }",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,   (   Nat.Prime  p  ) ∧   (   Nat.Prime  q  ) ∧  (    q - p =  2  )",
    " ∃    (   n :  ℕ ) ,   Nat.Prime   (     2 * n +  1  ) ∧  Nat.Prime   (     2 * n -  1  )",
    " ∀  n  ,  ∃     p₁  p₂  ,   Nat.Prime  p₁ ∧   Nat.Prime  p₂ ∧    p₁ +  2 = p₂ ∧    2 * n < p₂",
    " ∃    (   p  q :  ℕ ) ,   p ≠ q ∧   Nat.Prime  p ∧   Nat.Prime  q ∧   q - p =  2",
    " ∃    (   p :  ℕ ) ,   Nat.Prime   (    2 + p  ) ∧  Nat.Prime   (  p  )",
    " ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∀   {  p  :  ℕ }  ,   Nat.Prime  p →  ∃    (   q :  ℕ ) ,   Nat.Prime  q ∧  q =  p +  2",
    " ∃    (   p :  ℕ ) ,  ∀   (  q  :  ℕ  )  ,    q ≠ p →  q =  p +  2 ↔  ∃    (   p :  ℕ ) ,  ∀   (  q  :  ℕ  )  ,   q ≠ p →   q =  p +  2 ∧  Nat.Prime  p",
    " ∃    (   a :  ℕ ) ,  ∀   (  x  :  ℕ  )  ,  ∃    (   y :  ℕ ) ,   Nat.Prime  x ∧   Nat.Prime  y ∧   x =  y + a ∧  a ∈  {   2 ,  4 }"]},
  {"theorem": "(K : Type u) → [inst : DivisionRing K] → Fintype K → Field K",
   "some-correct": null,
   "round-trip": "A `DivisionRing` is a `Field` if it is finite. ",
   "prompt": "Every finite division ring is a field.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->  (  h :  Fintype  K ) ->  Field  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  K :  Type  u_1 } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  F :  Type  u ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  IsField  F",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  α :  Type  u_1 } ->  [  DivisionRing  α ] ->  [  Fintype  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  DivisionRing  α ] ->  Field  α",
    " {  K :  Type  u_1 } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  NonAssocRing  K ] ->  [  DivisionRing  K ] ->  IsField  K"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type 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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  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 } ->  {  β :  Type  v } ->  (  hα :  ∃    (   f :  α → β ) ,  Function.Injective  f ) ->  (  hβ :  ∃    (   g :  β → α ) ,  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h"]},
  {"theorem":
   "∀ {α : Type u_1} {r : α → α → Prop} [inst : Preorder α],\n  (∀ (c : Set α) (a : IsChain r c), ∃ ub, ∀ (a : α), a ∈ c → r a ub) →\n    ∀ [inst : Nonempty α], ∃ 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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  [  Preorder  α ] ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  [  Nonempty  α ] ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  [  Preorderₓ  α ] ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  [  Nonempty  α ] ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u } ->  {  r :  α →  α →  Prop } ->  [  Preorder  α ] ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->   Nonempty  α →  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u } ->  {  r :  α →  α →  Prop } ->  [  Preorderₓ  α ] ->  (  h :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->   Nonempty  α →  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m"]},
  {"theorem":
   "∀ {α : Type u} [inst : MulZeroClass α] [inst_1 : Groupₓ α], IsCyclic α → IsLieAbelian α",
   "some-correct": false,
   "round-trip": " A cyclic group is abelian. ",
   "prompt": "A group whose automorphism group is cyclic is Abelian.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  MulZeroClass  α ] ->  [  Groupₓ  α ] ->  (  haut :  IsCyclic  α ) ->  IsLieAbelian  α",
    " {  α :  Type  u } ->  [  MulZeroClassₓ  α ] ->  [  Groupₓ  α ] ->  (  haut :  IsCyclic  α ) ->  IsLieAbelian  α"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} {γ : Type u_3} [inst : UniformSpace α] [inst_1 : UniformSpace β]\n  [inst_2 : UniformSpace γ] {f : α → β} {g : β → γ},\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  {  h :  α → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuousOn  g  (   Set.Range  f  ) ) ->  (  h' :  ∀  x  ,   h  x =  g   (   f  x  ) ) ->  UniformContinuous  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ   ( a : α ) ,  g   (   f  a  )  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  γ → α } ->  {  g :  β → γ } ->  (  hg :  UniformContinuous  g ) ->  (  hf :  UniformContinuous  f ) ->  UniformContinuous   (   λ   ( x : β ) ,  f   (   g  x  )  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hg :  UniformContinuous  g ) ->  (  hf :  UniformContinuous  f ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  (  hf :  UniformContinuous  f ) ->  {  g :  β → γ } ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} {γ : Type u_3} [inst : UniformSpace α] [inst_1 : UniformSpace β]\n  [inst_2 : UniformSpace γ] {f : α → β} {g : β → γ},\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  {  γ :  Type  w } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  {  h :  α → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuousOn  g  (   Set.Range  f  ) ) ->  (  h' :  ∀  x  ,   h  x =  g   (   f  x  ) ) ->  UniformContinuous  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  {  f :  α → β } ->  {  g :  β → γ } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ   ( a : α ) ,  g   (   f  a  )  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  γ → α } ->  {  g :  β → γ } ->  (  hg :  UniformContinuous  g ) ->  (  hf :  UniformContinuous  f ) ->  UniformContinuous   (   λ   ( x : β ) ,  f   (   g  x  )  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hg :  UniformContinuous  g ) ->  (  hf :  UniformContinuous  f ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  (  hf :  UniformContinuous  f ) ->  {  g :  β → γ } ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ {f : ℤ → ℤ}, (∃ x, Function.IsPeriodicPt f 3 x) → ∀ (n : ℕ), ∃ x, Function.IsPeriodicPt f n x",
   "some-correct": null,
   "round-trip":
   "If a function is periodic with period 3, then it is periodic with any period. ",
   "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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type* } ->  [  LinearOrderedCommRing  α ] ->  [  Archimedean  α ] ->  {  f :  α → α } ->  (  h :  Function.IsPeriodicPt  f  3  (    (   0   : α ) +  1  ) ) ->  ∀   (  n  :  ℕ  )  ,   n >  0 →  Function.IsPeriodicPt  f n  (    (   0   : α ) +  1  )",
    " {  f :   ℤ →  ℤ } ->  (  hf :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  ,  ∃     x  ,  Function.IsPeriodicPt  f n x",
    " {  f :   ℕ →  ℕ } ->  {  x :  ℕ } ->  (  h :  Function.IsPeriodicPt  f  3 x ) ->  ∀   (  n  :  ℕ  )  ,    0 < n →  ∃    (   x :  ℕ ) ,  Function.IsPeriodicPt  f n x",
    " {  f :  Unit → Unit } ->  (  h :  ∃     x  : Unit ,  Function.IsPeriodicPt  f  3 x ) ->  ∀  n   :  ℕ ,  ∃     x  : Unit ,  Function.IsPeriodicPt  f n x",
    " {  f :  Unit → Unit } ->  {  x : Unit } ->  (  hf :  Function.IsPeriodicPt  f  3 x ) ->  ∀  m  ,   m >  0 →  Function.IsPeriodicPt  f m x",
    " {  f :  Unit → Unit } ->  (  h :  ∃    (   a : Unit ) ,  Function.IsPeriodicPt  f  3 a ) ->  ∀   (  m  :  ℕ  )  ,  ∃    (   a : Unit ) ,  Function.IsPeriodicPt  f m a"]},
  {"theorem":
   "∀ {C : Type u₁} [inst : CategoryTheory.Category C] [inst_1 : CategoryTheory.Limits.HasTerminal C] {T T' : C}\n  (t : CategoryTheory.Limits.IsTerminal T),\n  CategoryTheory.Limits.IsTerminal T' → CategoryTheory.IsIso (CategoryTheory.Limits.IsTerminal.from t T')",
   "some-correct": null,
   "round-trip":
   "If `T` and `T'` are both terminal objects, then there is an isomorphism between them. ",
   "prompt":
   "A terminal object in a category is unique up to unique isomorphism.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  C :  Type  u₁ } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T T' : C } ->  (  t :  CategoryTheory.Limits.IsTerminal  T ) ->  (  t' :  CategoryTheory.Limits.IsTerminal  T' ) ->  CategoryTheory.IsIso   (   t.from  T'  )",
    " {  C :  Type  u₁ } ->  [  CategoryTheory.Category  C ] ->  {  T₁ T₂ : C } ->  (  hT₁ :  CategoryTheory.Limits.IsTerminal  T₁ ) ->  (  hT₂ :  CategoryTheory.Limits.IsTerminal  T₂ ) ->  CategoryTheory.IsIso   (   hT₁.from  T₂  )",
    " {  C :  Type  u } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  T T' : C } ->  (  hT :  CategoryTheory.Limits.IsTerminal  T ) ->  (  hT' :  CategoryTheory.Limits.IsTerminal  T' ) ->  CategoryTheory.IsIso   (   hT'.from  T  )"]},
  {"theorem": "∀ (a b c : ℤ), a ^ 3 + b ^ 3 ≠ c ^ 3",
   "some-correct": null,
   "round-trip": "The sum of two cubes is never a cube. ",
   "prompt":
   "The sum of the cubes of two positive integers is never equal to the cube of a third integer.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" (  a b c :  ℤ ) ->   (    a ^  3 +  b ^  3  ) ≠  c ^  3",
    " {  a b c :  ℕ } ->  (     a ^  3 +  b ^  3 ≠  c ^  3  )"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Group G], (∀ (x : G), x ^ 2 = 1) → ∀ {x y : G}, Commute x y",
   "some-correct": null,
   "round-trip":
   "If every element has order 2, then every element commutes with every other element. ",
   "prompt":
   "If every element of a group `G` has order `2`, then every pair of elements of `G` commutes.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [  Group  G ] ->  (  H :  ∀   (  x  : G  )  ,   x ^  2 =  1 ) ->  ∀   {  x y  : G }  ,  Commute  x y",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  x  : G  )  ,   x ^  2 =  1 ) ->  ∀   {  x y  : G }  ,  Commute  x y",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,  Commute  x y",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀   (  x y  : G  )  ,  Commute  x y",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  ∀   (  x  : G  )  ,   orderOf  x =  2 ) ->  ∀   (  x  : G  )  ,  ∀   (  y  : G  )  ,  Commute  x y"]},
  {"theorem": "∀ {p q : ℕ}, p = q + 1 → Even (p * q)",
   "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": true,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->   Even  n →   n ≠  0 →  Even   (   n *  (   n +  1  )  )",
    " {  m :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " {  p q :  ℕ } ->  (  h_consecutive :  p =  q +  1 ) ->  Even   (   p * q  )",
    " ∀   (  n  :  ℕ  )  ,  Even   (   n *  (   n +  1  )  )",
    " {  x :  ℕ } ->  (  hx :   0 < x ) ->  ∃    (   a :  ℕ ) ,   x *  (   x -  1  ) =   2 * a"]},
  {"theorem": "∀ (α : Type u), 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": true,
   "comments": "",
   "all-elabs":
   [" (  α :  Type  u ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u_1 } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u_1 ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type* } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  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": true,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  h :   2 ≤ n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  a :  ℤ ) ->  (  hn :   n ≠  0 ∧  n ≠  1 ) ->  ∃    (   p :  ℕ ) ,   Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  hn1 :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->   n >  1 →  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  hn :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  hn :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  h1 :   1 < n ) ->  ∃    (   p :  ℕ ) ,    1 < p ∧   Nat.Prime  p ∧  p ∣ n",
    " (  p :  ℕ ) ->  (  hp :   1 < p ) ->  ∃    (   q :  ℕ ) ,   Nat.Prime  q ∧  q ∣ p"]},
  {"theorem":
   "∀ {G : Type u} [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": true,
   "comments": "",
   "all-elabs":
   [" {  G :  Type  u_1 } ->  [ hG :  Groupₓ  G ] ->  [ hf :  Fintype  G ] ->  (  tfG :  Monoidₓ.IsTorsionFree  G ) ->  G =  1",
    " {  G :  Type  u } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->  (  h :  Monoidₓ.IsTorsionFree  G ) ->   Fintype.card  G =  1"]},
  {"theorem": "(K : Type u) → [inst : DivisionRing K] → Fintype K → Field K",
   "some-correct": null,
   "round-trip": "A `DivisionRing` is a `Field` if it is finite. ",
   "prompt": "Every finite division ring is a field.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  DivisionRing  K ] ->  (  h :  Fintype  K ) ->  Field  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  K :  Type  u_1 } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  F :  Type  u ) ->  [  DivisionRing  F ] ->  [  Fintype  F ] ->  IsField  F",
    " {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " {  α :  Type  u_1 } ->  [  DivisionRing  α ] ->  [  Fintype  α ] ->  Field  α",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  DivisionRing  α ] ->  Field  α",
    " {  K :  Type  u_1 } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  NonAssocRing  K ] ->  [  DivisionRing  K ] ->  IsField  K"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] [inst_1 : Fintype α], IsCompact Set.Univ",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every finite topological space is compact",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  ha :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  IsCompact  α",
    " {  α :  Type* } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  CompactSpace  α",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  Fintype  α ] ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact   (   Set  α  )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  [  DecidableEq  α ] ->  [  Fintype  α ] ->  IsCompact  Set.Univ",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Finite  α ) ->  IsCompact  α"]},
  {"theorem":
   "∀ {α : Type u_1} {β : Type u_2} [inst : Groupₓ α] [inst_1 : Groupₓ β] [inst_2 : Fintype α] [inst_3 : Fintype β]\n  {f : α → β}, IsGroupHom f → Function.Surjective f → Function.Injective f",
   "some-correct": false,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "Every surjective homomorphism from a finitely generated free group to itself is injective",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  Groupₓ  α ] ->  [  Groupₓ  β ] ->  [  Fintype  α ] ->  [  Fintype  β ] ->  {  f :  α → β } ->  (  hf :  IsGroupHom  f ) ->  (  hf' :  Function.Surjective  f ) ->  Function.Injective  f"]},
  {"theorem":
   "∀ {n : ℕ}, 0 < n → Even n → ∃ p q, Nat.Prime p ∧ Nat.Prime q ∧ p + q = n",
   "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": true,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :   0 < n ) ->  (  heven :  Even  n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :  Even  n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧  n =  p + q",
    " {  x :  ℕ } ->  (  hx0 :  x >  0 ) ->  (  heven :  ∃    (   p :  ℕ ) ,   p %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  x =  a + b",
    " {  n :  ℕ } ->  (  hpos :   0 < n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧    2 * n =  p + q",
    " (  n :  ℕ ) ->    n >  0 ∧  Even  n →  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->  (  hn :   0 <   2 * n ) ->  ∃    (   a  b :  ℕ ) ,   a ≠ b ∧   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b =   2 * n",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧  Even  n ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a + b",
    " {  n :  ℕ } ->  (  hn :   0 <   2 * n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q =   2 * n",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧  Even  n ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hn :   2 ≤ n ) ->  ∃    (   p  q :  ℕ ) ,   Prime  p ∧   Prime  q ∧   p + q = n"]},
  {"theorem":
   "∀ {R : Type u} [inst : CommRingₓ R] [inst_1 : Nontrivial R] {n : Type w} [inst_2 : DecidableEq n] [inst_3 : Fintype n]\n  (M : Matrix n n R), AlgHom.toFun (Polynomial.aeval M) (Matrix.charpoly M) = 0",
   "some-correct": null,
   "round-trip": " The **Characteristic polynomial theorem**. ",
   "prompt": "Every matrix satisfies its own characteristic polynomial.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  R :  Type  u } ->  [  CommRingₓ  R ] ->  [  Nontrivial  R ] ->  {  n :  Type  w } ->  [  DecidableEq  n ] ->  [  Fintype  n ] ->  (  M :  Matrix  n n R ) ->  ⇑    (   Polynomial.aeval  M  )  M.charpoly =  0",
    " {  R :  Type  u } ->  [  CommRingₓ  R ] ->  {  n :  Type  v } ->  [  Fintype  n ] ->  [  DecidableEq  n ] ->  (  M :  Matrix  n n R ) ->  ⇑    (   Polynomial.aeval  M  )  M.charpoly =  0",
    " {  R :  Type  u } ->  {  n :  Type  v } ->  [  CommRingₓ  R ] ->  [  Fintype  n ] ->  [  DecidableEq  n ] ->  (  M :  Matrix  n n R ) ->  ⇑    (   Polynomial.aeval  M  )  M.charpoly =  0",
    " {  R :  Type  u } ->  {  n :  Type  w } ->  [  CommRingₓ  R ] ->  [  DecidableEq  n ] ->  [  Fintype  n ] ->  (  A :  Matrix  n n R ) ->  ⇑    (   Polynomial.aeval  A  )  A.charpoly =  0"]},
  {"theorem":
   "∀ {M : Type u} [inst : Semiring M] [inst_1 : DecidableEq M] (a : M), Even (a * a) → Even a",
   "some-correct": null,
   "round-trip":
   "If `a` is a natural number, then `a*a` is even if and only if `a` is even. ",
   "prompt": "If the square of a number is even, the number itself is even.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ring  α ] ->  {  a : α } ->   Even   (   a ^  2  ) →  Even  a",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  {  a : α } ->   Even   (   a ^  2  ) →  Even  a",
    " {  M :  Type  u } ->  [  Semiring  M ] ->  [  DecidableEq  M ] ->  (  a : M ) ->  (  h :  Even   (   a * a  ) ) ->  Even  a",
    " {  M :  Type  u } ->  [  Semiringₓ  M ] ->  [  DecidableEq  M ] ->  (  a : M ) ->  (  h :  Even   (   a * a  ) ) ->  Even  a",
    " {  α :  Type  u } ->  [  Ring  α ] ->  {  a : α } ->   Even   (   a * a  ) →  Even  a",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  {  a : α } ->   Even   (   a * a  ) →  Even  a",
    " {  M :  Type  u_2 } ->  [  CommRing  M ] ->  {  a : M } ->   Even   (   a * a  ) →  Even  a",
    " {  M :  Type  u_2 } ->  [  CommRingₓ  M ] ->  {  a : M } ->   Even   (   a * a  ) →  Even  a",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  a : α } ->   Even   (   a * a  ) →  Even  a",
    " {  M :  Type  u_1 } ->  [  CommSemiring  M ] ->  (  a : M ) ->   Even   (   a * a  ) →  Even  a",
    " {  M :  Type  u_1 } ->  [  CommSemiringₓ  M ] ->  (  a : M ) ->   Even   (   a * a  ) →  Even  a",
    " {  M :  Type  u } ->  [  CommSemiring  M ] ->  (  a : M ) ->   Even   (   a * a  ) →  Even  a",
    " {  M :  Type  u } ->  [  CommSemiringₓ  M ] ->  (  a : M ) ->   Even   (   a * a  ) →  Even  a",
    " {  m :  ℕ } ->  (  hM :   2 ∣  m ^  2 ) ->   2 ∣ m",
    " {  m :  ℕ } ->   Even   (   m ^  2  ) ↔  Even  m",
    " {  n :  ℕ } ->   Even   (   n ^  2  ) →  Even  n",
    " {  m :  ℕ } ->   Even   (   m * m  ) →  Even  m"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α], T2Space α ↔ IsClosed fun x => ?m.7811889 x",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt":
   "A topological space $X$ is Hausdorff if and only if the diagonal is a closed set in $X × X$.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->   T2Space  α ↔  IsClosed   (   λ   ( p :  α × α ) ,  p.fst = p.snd  )"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α] {s : Set α}, (∀ (x : α), x ∈ s → ∃ t, IsOpen t ∧ x ∈ 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": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  H :  ∀  x  ∈ s ,  ∃     U  ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h :  ∀  x  ∈ t ,  ∃     U  ,   IsOpen  U ∧  x ∈ U ) ->  (  hs :  s ⊆ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  :  Set  α ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  {  s :  Set  α } ->  [  TopologicalSpace  α ] ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   u :  Set  α ) ,   IsOpen  u ∧  x ∈ u ) ->  IsOpen  s",
    " {  α :  Type  u_1 } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     t  ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀   ⦃  x  : α ⦄  ,   x ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  {  s :  Set  α } ->  [  TopologicalSpace  α ] ->  (  h :  ∀  x  ∈ s ,  ∃    (   U :  Set  α ) ,   IsOpen  U ∧  x ∈ U ) ->  IsOpen  s",
    " {  α :  Type  u } ->  {  s :  Set  α } ->  [ t :  TopologicalSpace  α ] ->  (  h :  ∀  x  ∈ s ,  ∃     t  ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s"]},
  {"theorem":
   "∀ {α : Type u} [inst : DecidableEq α] {x : FreeGroup α}, x ≠ 1 → ¬IsOfFinOrder x",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every non-identity element of a free group is of infinite order.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  DecidableEq  α ] ->  {  x :  FreeGroup  α } ->   x ≠  1 →  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  (  x :  FreeGroup  α ) ->   ¬  IsOfFinOrder  x ↔  x ≠  1",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  {  g :  FreeGroup  α } ->  (  h :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->  (  H :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  ∀   (  g  :  FreeGroup  α  )  (  h  :  g ≠  1  )  ,  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  ∀   (  f  :  FreeGroup  α  )  ,  ¬  IsOfFinOrder  f",
    " {  α :  Type  u_1 } ->  {  g :  FreeGroup  α } ->  [ hN :  Nontrivial   (   FreeGroup  α  ) ] ->  (  h1 :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  H :  FreeGroup  G ) ->  (  g : G ) ->   ¬  IsOfFinOrder  g ∧  g ≠  1",
    " (  α :  Type  u_1 ) ->  ∀   (  g  :  FreeGroup  α  )  ,   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  {  f :  FreeGroup  α } ->  (  hf :  f ≠  1 ) ->  ¬  IsOfFinOrder  f",
    " {  α :  Type  u_1 } ->  {  g :  FreeGroup  α } ->  (  hg :  g ≠  1 ) ->  ¬  IsOfFinOrder  g"]},
  {"theorem":
   "∀ {m n : ℕ}, 0 < m → 0 < n → Nat.gcd m n = 1 → ∀ (N : ℕ), N > m * n → ∃ x y, N = m * x + n * y",
   "some-correct": null,
   "round-trip":
   " **Euclid's lemma**: if `m` and `n` are positive natural numbers with `gcd m n = 1`, then for any natural number `N` greater than `m * n`, there exist natural numbers `x` and `y` such that `N = m * x + n * 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": true,
   "comments": "",
   "all-elabs":
   [" Set.SurjOn   (   λ   ( g :  Matrix.SpecialLinearGroup   (   Fin   2  )  ℤ ) ,   ↑ g   1  ) Set.Univ Set.Univ",
    " Set.SurjOn   (   λ   ( g :  Matrix.SpecialLinearGroup   (   Finₓ   2  )  ℤ ) ,   ↑ g   1  ) Set.Univ Set.Univ",
    " {  m n :  ℕ } ->  (  hm :   0 < m ) ->  (  hn :   0 < n ) ->  (  hmn :   m.gcd  n =  1 ) ->  (  N :  ℕ ) ->  (  hN :  N >  m * n ) ->  ∃    (   x  y :  ℕ ) ,  N =   m * x +  n * y",
    " {  a b :  ℤ } ->  (  h :  IsCoprime  a b ) ->  {  N :  ℕ } ->  (  hN :   0 < N ) ->  ∃    (   x  y :  ℕ ) ,   ↑ N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  ha :  a ≠  0 ) ->  (  hb :  b ≠  0 ) ->  (  hab :   a.gcd  b =  1 ) ->  (  N :  ℕ ) ->  (  hn :  N >  a * b ) ->  ∃    (   x  y :  ℕ ) ,   ↑ N =   a * x +  b * y",
    " {  a b N :  ℕ } ->  (  h_coprime :   a.gcd  b =  1 ) ->  (  h_N :  N > b ) ->  ∃    (   x  y :  ℕ ) ,   ↑ N =   a * x +  b * y"]},
  {"theorem": "{α : Type u_1} → [inst : Field α] → Ring α",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every field is a ring.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  Field  α ] ->  Ring  α",
    " {  α :  Type  u_1 } ->  [  Field  α ] ->  Ringₓ  α",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  (  hf :  IsField  R ) ->  NonAssocRing  R",
    " (  K :  Type  u ) ->  [  Field  K ] ->  NonAssocRing  K",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  α :  Type  u ) ->  [  Field  α ] ->  Ring  α",
    " (  α :  Type  u ) ->  [  Field  α ] ->  Ringₓ  α",
    " {  R :  Type  u } ->  [  Field  R ] ->  Ring  R",
    " {  R :  Type  u } ->  [  Field  R ] ->  Ringₓ  R",
    " {  R :  Type* } ->  [  Field  R ] ->  Ring  R",
    " {  R :  Type* } ->  [  Field  R ] ->  Ringₓ  R"]},
  {"theorem": "(R : Type u_1) → [inst : Ringₓ R] → AddGroup (Units R)",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "The set of units in a ring forms a group.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  AddGroup   (   Units  R  )",
    " (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  AddGroupₓ   (   Units  R  )",
    " (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type  u_1 ) ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  CommGroup   (   Units  R  )",
    " (  R :  Type  u ) ->  [  Ringₓ  R ] ->  CommGroupₓ   (   Units  R  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  AddGroup   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  AddGroupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  MonoidWithZeroₓ  α ] ->  [  MulOneClass  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  MonoidWithZeroₓ  α ] ->  [  MulOneClass  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  MonoidWithZeroₓ  α ] ->  [  MulOneClassₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  MonoidWithZeroₓ  α ] ->  [  MulOneClassₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " (  R :  Type  u_1 ) ->  [  CommRingₓ  R ] ->  Group   (   Units  R  )",
    " (  R :  Type  u_1 ) ->  [  CommRingₓ  R ] ->  Groupₓ   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  Group   (   Units  R  )",
    " {  R :  Type  u_1 } ->  [  Ringₓ  R ] ->  Groupₓ   (   Units  R  )"]},
  {"theorem":
   "∀ {η : Type u_1} (G : Type u_2) [inst : Groupₓ G] {Γ : Type u_3} [inst_1 : Groupₓ Γ],\n  Monoidₓ.IsTorsionFree (G × Γ) → Monoidₓ.IsTorsionFree G ∧ Monoidₓ.IsTorsionFree Γ",
   "some-correct": null,
   "round-trip":
   "If the direct product of two groups is torsion-free, then both groups are torsion-free. ",
   "prompt":
   "If the direct product of two groups is torsion free then each of the groups is torsion free.",
   "correct": true,
   "comments": "",
   "all-elabs":
   [" {  η :  Type  u_1 } ->  (  G :  Type  u_2 ) ->  [  Groupₓ  G ] ->  {  Γ :  Type  u_3 } ->  [  Groupₓ  Γ ] ->   Monoidₓ.IsTorsionFree   (   G × Γ  ) →   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  Γ",
    " {  η :  Type  u_1 } ->  [  Fintype  η ] ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  h :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  h :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  {  i : η } ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  tfGs :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )"]},
  {"theorem": "∀ {n : ℕ}, ∃ x y z, x ^ 2 + y ^ 2 = z ^ 2",
   "some-correct": false,
   "round-trip": "There exists a Pythagorean triple for every natural number. ",
   "prompt": "There are infinitely many Pythagorean triples.",
   "correct": false,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  ∃    (   x  y  z :  ℕ ) ,    x ^  2 +  y ^  2 =  z ^  2",
    " ∀   (  x y z  :  ℕ  )  ,  ∃    (   w  v  u :  ℕ ) ,    w ^  2 +  u ^  2 =  v ^  2",
    " ∃    (   x  y  z :  ℕ ) ,   PythagoreanTriple  x y z ∧  (    x ≠  0 ∨  y ≠  0  )",
    " ∀   (  h  :  ℕ  )  ,  ∃    (   x  y  z :  ℕ ) ,  PythagoreanTriple  x y z",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   x  y  z :  ℕ ) ,  PythagoreanTriple  x y z",
    " ∀   {  x y z  :  ℤ }  ,   PythagoreanTriple  x y z →  ∃    (   x'  y'  z' :  ℤ ) ,   PythagoreanTriple  x' y' z' ∧   (  x'   ,  y' , z' ) ≠  (  x   ,  y , z )",
    " ∀   (  x y z  :  ℕ  )  ,  ∃     m  :  ℕ ,  ∃     k  :  ℕ ,  PythagoreanTriple   (   m * x  )  (   m * y  )  (    (   m * k  ) * z  )",
    " ∀   (  z  :  ℕ  )  ,  ∃    (   x  y :  ℕ ) ,  PythagoreanTriple  x y z",
    " ∀  n   :  ℕ ,  ∃    (   x  y  z :  ℕ ) ,   PythagoreanTriple  x y z ∧  x < n",
    " ∀   (  x y z  :  ℤ  )  ,  ∃    (   k :  ℤ ) ,  PythagoreanTriple   (   k * x  )  (   k * y  )  (   k * z  )",
    " ∃    (   x  y  z :  ℤ ) ,  PythagoreanTriple  x y z",
    " ∃    (   f :   ℕ →  ℕ ) ,  ∀   (  n  :  ℕ  )  ,  PythagoreanTriple   (   f  n  )  (   f   (   n +  1  )  )  (   f   (   n +  2  )  )"]}],
 "elaborated": 33}