{"total-prompts": 42,
 "temperature": 0.8,
 "query-number": 15,
 "number-similar-sentences": 4,
 "number-keyword-sentences": 0,
 "include-fixed": false,
 "failures":
 ["A finite graph in which every pair of vertices have precisely one common neighbour contains a vertex that is adjacent to all other vertices.",
  "The number of partitions with odd parts is equal to the number of partitions with distinct parts.",
  "A group whose automorphism group is cyclic is Abelian.",
  "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 surjective homomorphism from a finitely generated free group to itself is injective",
  "Every matrix satisfies its own characteristic polynomial.",
  "The square root of an irrational number is irrational.",
  "In a finite commutative ring, all prime ideals are maximal.",
  "A topological space $X$ is Hausdorff if and only if the diagonal is a closed set in $X × X$.",
  "An element of a discrete valuation ring is a unit if and only if it has a valuation of zero."],
 "elaborated-prompts":
 [{"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α],\n  (∀ (s : Set α), IsClosed s → IsCompact s) → ∀ {s : Set α}, IsCompact s → IsCompact s",
   "some-correct": null,
   "round-trip": " Every compact set is closed. ",
   "prompt":
   "If every proper closed set of a topological space is compact, then the space itself is compact.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  ∀  s   :  Set  α ,   IsClosed  s →  IsCompact  s ) ->  {  s :  Set  α } ->   IsCompact  s →  IsCompact  s"]},
  {"theorem":
   "∀ {p : ℕ} [inst : Fact (Nat.Prime p)], p % 4 = 1 → ∃ 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 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  h :  ¬  Nat.Prime  p ) ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  ℕ ) ,    a ^  2 +  b ^  2 = p",
    " {  p :  ℕ } ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  p4 :   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",
    " (  p :  ℕ ) ->  [  Fact   (   Nat.Prime  p  ) ] ->  (  hp :   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  ) ] ->  (  hp :   p %  4 =  1 ) ->  ∃    (   a  b :  Zmod  p ) ,     (  a   :  Zmod  p ) ^  2 +   (  b   :  Zmod  p ) ^  2 =  1"]},
  {"theorem":
   "∀ {a b : ℤ},\n  (∃ u v w x y, a = u * u + v * v + w * w + x * x ∧ b = y * y + v * v + w * w + x * x) →\n    ∃ u v w x, a * b = u * u + v * v + w * w + x * x",
   "some-correct": null,
   "round-trip":
   "If `a` and `b` are sums of squares, then `a * b` is 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": null,
   "comments": "",
   "all-elabs":
   [" {  a b :  ℤ } ->  (  ha :  ∃    (   u  v  w  x  y :  ℤ ) ,   a =     u * u +  v * v +  w * w +  x * x ∧  b =     y * y +  v * v +  w * w +  x * x ) ->  ∃    (   u  v  w  x :  ℤ ) ,   a * b =     u * u +  v * v +  w * w +  x * x",
    " {  a b x y z w :  ℕ } ->  ∃    (   c  d  e  f :  ℕ ) ,    a =     x * x +  y * y +  z * z +  w * w ∧  b =     c * c +  d * d +  e * e +  f * f →  ∃    (   g  h  i  j :  ℕ ) ,   a * b =     g * g +  h * h +  i * i +  j * j",
    " {  a b :  ℤ } ->  (  h :  ∃     x  y  z  w  :  ℤ ,  a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  ∃     x  y  z  w  :  ℤ ,  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2",
    " {  a b c d :  ℕ } ->       a ^  2 +  b ^  2 +  c ^  2 +  d ^  2 =  0 →  ∃    (   a'  b'  c'  d' :  ℕ ) ,      a' ^  2 +  b' ^  2 +  c' ^  2 +  d' ^  2 =  a * b",
    " {  x y :  ℤ } ->  (  hx :  ∃     a  b  c  d  ,  x =     a * a +  b * b +  c * c +  d * d ) ->  (  hy :  ∃     a  b  c  d  ,  y =     a * a +  b * b +  c * c +  d * d ) ->  ∃     a  b  c  d  ,   x * y =     a * a +  b * b +  c * c +  d * d",
    " {  a b :  ℕ } ->  (  ha :  ∃    (   x  y  z  w :  ℕ ) ,  a =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  (  hb :  ∃    (   x  y  z  w :  ℕ ) ,  b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2 ) ->  ∃    (   x  y  z  w :  ℕ ) ,   a * b =     x ^  2 +  y ^  2 +  z ^  2 +  w ^  2"]},
  {"theorem":
   "{α : Type u_1} → [inst : CommMonoid α] → (∀ (x : α), x * x = x) → CommRing α",
   "some-correct": null,
   "round-trip":
   "A commutative monoid with a square root is a commutative ring. ",
   "prompt": "A ring with all elements idempotent is commutative.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  CommMonoid  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  CommMonoid  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  CommMonoidₓ  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  CommMonoidₓ  α ] ->  (  h :  ∀  x   : α ,   x * x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ring  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀  x   : α ,   x + x = x ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ring  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀  x   : α ,   x + x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀  x   : α ,   x + x = x ) ->  CommRing  α",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  (  h :  ∀  x   : α ,   x + x = x ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ring  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRing  α",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  CommRingₓ  α",
    " {  α :  Type  u_1 } ->  [  Ring  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  (  a b : α ) ->   a * b =  b * a",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  (  h :  ∀  a   : α ,   a * a = a ) ->  (  a b : α ) ->   a * b =  b * a",
    " {  α :  Type  u } ->  [  Semiring  α ] ->  (  h1 :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommSemiring  α",
    " {  α :  Type  u } ->  [  Semiring  α ] ->  (  h1 :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommSemiringₓ  α",
    " {  α :  Type  u } ->  [  Semiringₓ  α ] ->  (  h1 :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommSemiring  α",
    " {  α :  Type  u } ->  [  Semiringₓ  α ] ->  (  h1 :  ∀   (  a  : α  )  ,   a ^  2 = a ) ->  CommSemiringₓ  α"]},
  {"theorem":
   "∀ (n : ℕ), ∃ p, n ≤ p ∧ Nat.Prime p ∧ ∃ p', p + 2 = p' ∧ Nat.Prime p'",
   "some-correct": null,
   "round-trip":
   " There is a prime `p` such that `n ≤ p` and `p + 2` is also prime. ",
   "prompt":
   "There are infinitely many pairs of primes that differ exactly by `2`.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∃     a  b  :  ℕ ,   Prime  a ∧   Prime  b ∧   a +  2 = b",
    " ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p +  2 = q",
    " ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  Nat.Prime   (   p +  2  )",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   p :  ℕ ) ,   n ≤ p ∧   Nat.Prime  p ∧  ∃    (   p' :  ℕ ) ,    p +  2 = p' ∧  Nat.Prime  p'",
    " ∃    (   x  y :  ℕ ) ,   Nat.Prime  x ∧   Nat.Prime  y ∧   y - x =  2",
    " ∃    (   p  q :  ℕ ) ,   q =  p +  2 ∧  (    Prime  p ∧  Prime  q  )",
    " ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,    p %  2 =  1 ∧    q %  2 =  1 ∧   p +  2 = q",
    " ∀   {  n  :  ℕ }  ,  ∃    (   p :  ℕ ) ,  ∃    (   q :  ℕ ) ,    p %  2 =  1 ∧    q %  2 =  1 ∧   p ≠ q ∧    p +  2 = q ∧  p ≥ n",
    " ∃     p  q  :  ℕ ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p +  2 = q",
    " (  n :  ℕ ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p +  2 = q"]},
  {"theorem":
   "∀ {K : Type u} [inst : DivisionRing K] [inst_1 : Fintype K], IsField K",
   "some-correct": null,
   "round-trip": "A `DivisionRing` is a `Field`. ",
   "prompt": "Every finite division ring is a field.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  K :  Type  u } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " (  K :  Type* ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " {  α :  Type  u_1 } ->  [  Fintype  α ] ->  [  DivisionRing  α ] ->  Field  α",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K"]},
  {"theorem":
   "∀ {α : Type ?u.479892} {β : Type ?u.479896},\n  (∃ f, Function.Injective f) → (∃ f, Function.Injective f) → Nonempty (α ≃ β)",
   "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":
   [" {  α :  Type* } ->  {  β :  Type* } ->  (  hαβ :  ∃     f  :  α → β ,  Function.Injective  f ) ->  (  hβα :  ∃     f  :  β → α ,  Function.Injective  f ) ->  Nonempty   (   Equiv  α β  )",
    " {  α :  Type* } ->  {  β :  Type* } ->  (  hαβ :  ∃     f  :  α → β ,  Function.Injective  f ) ->  (  hβα :  ∃     f  :  β → α ,  Function.Injective  f ) ->  Nonempty   (   Equivₓ  α β  )",
    " {  α :  Type  u } ->  {  β :  Type  v } ->  (  f :  α → β ) ->  (  g :  β → α ) ->  (  Hf :  Function.Injective  f ) ->  (  Hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  (  h₁ :  ∃    (   f :  α → β ) ,  Function.Injective  f ) ->  (  h₂ :  ∃    (   g :  β → α ) ,  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",
    " {  α β :  Sort  u } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  (  hf :  ∃    (   f :  α → β ) ,  Function.Injective  f ) ->  (  hg :  ∃    (   g :  α → β ) ,  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  (  hα :  Nonempty  β ) ->  (  hβ :  Nonempty  α ) ->  ∃     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 } ->  {  f :  α → β } ->  {  g :  β → α } ->  (  hf :  Function.Injective  f ) ->  (  hg :  Function.Injective  g ) ->  ∃    (   h :  α → β ) ,  Function.bijective  h",
    " {  α :  Sort  u } ->  {  β :  Sort  v } ->  {  f :  α → β } ->  (  hf :  Function.Injective  f ) ->  {  g :  β → α } ->  (  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) → ∃ 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 } ->  (  hb :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  ∃    (   m : α ) ,  ∀   (  a  : α  )  ,   r  m a →  r  a m",
    " {  α :  Type  u_1 } ->  {  r :  α →  α →  Prop } ->  (  hc :  ∀   (  c  :  Set  α  )  ,   IsChain  r c →  (   ∃    (   ub : α ) ,  ∀   (  a  : α  )  ,   a ∈ c →  r  a ub  ) ) ->  (  h :  Nonempty  α ) ->  ∃    (   ub : α ) ,   r  ub ub ∧  ∀   (  a  : α  )  ,  ¬  r  a ub",
    " {  α :  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  a m →  r  m a"]},
  {"theorem":
   "∀ {α : Type ?u.1279221} {β : Type ?u.1279224} {γ : Type ?u.1279227} [inst : UniformSpace α] [inst_1 : UniformSpace β]\n  [inst_2 : UniformSpace γ] {f : α → β} {g : β → γ},\n  UniformContinuous f → UniformContinuous g → UniformContinuous (g ∘ f)",
   "some-correct": null,
   "round-trip":
   " Composition of uniformly continuous maps is uniformly continuous. ",
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α β γ :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  γ :  Type  u_3 } ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ x ,  g   (   f  x  )  )",
    " {  α :  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_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  γ → β } ->  {  g :  α → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )",
    " {  α β γ :  Type* } ->  (  hα :  UniformSpace  α ) ->  (  hβ :  UniformSpace  β ) ->  (  hγ :  UniformSpace  γ ) ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ {α : Type ?u.1424401} {β : Type ?u.1424404} {γ : Type ?u.1424407} [inst : UniformSpace α] [inst_1 : UniformSpace β]\n  [inst_2 : 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 their composition. ",
   "prompt":
   "A uniformly continuous function of a uniformly continuous function is uniformly continuous.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α β γ :  Type* } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )",
    " {  α :  Type  u_1 } ->  {  β :  Type  u_2 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  {  γ :  Type  u_3 } ->  [  UniformSpace  γ ] ->  {  f :  α → β } ->  {  g :  β → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   λ x ,  g   (   f  x  )  )",
    " {  α :  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_1 } ->  {  β :  Type  u_2 } ->  {  γ :  Type  u_3 } ->  [  UniformSpace  α ] ->  [  UniformSpace  β ] ->  [  UniformSpace  γ ] ->  {  f :  γ → β } ->  {  g :  α → γ } ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   f ∘ g  )",
    " {  α β γ :  Type* } ->  (  hα :  UniformSpace  α ) ->  (  hβ :  UniformSpace  β ) ->  (  hγ :  UniformSpace  γ ) ->  (  f :  α → β ) ->  (  g :  β → γ ) ->  (  hf :  UniformContinuous  f ) ->  (  hg :  UniformContinuous  g ) ->  UniformContinuous   (   g ∘ f  )"]},
  {"theorem":
   "∀ {f : ℕ → ℕ}, Function.Periodic f 3 → (∀ (x : ℕ), 3 ≤ x → f x = f 0) → ∀ (x : ℕ), 0 < x → Function.IsPeriodicPt f x 0",
   "some-correct": null,
   "round-trip":
   "If a function is periodic with period `3`, and if it is constant on the interval `[3, ∞)`, then it is periodic with period `1`. ",
   "prompt":
   "If a function from the unit interval to itself has a point of period three, then it has points of all positive periods.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u_1 } ->  [  OrderedRing  α ] ->  {  f :  α → α } ->  {  x : α } ->  (  hf :  Function.IsPeriodicPt  f  3 x ) ->  ∀  n   :  ℕ ,   n >  0 →  Function.IsPeriodicPt  f  (    3 * n  ) x",
    " {  f :   ℕ →  ℕ } ->  (  hf :  Function.Periodic  f  3 ) ->  (  hx :  ∀   (  x  :  ℕ  )  ,    3 ≤ x →   f  x =  f   0 ) ->  ∀   (  x  :  ℕ  )  ,    0 < x →  Function.IsPeriodicPt  f x  0",
    " {  f :  Unit → Unit } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  ,   n >  0 →  ∃     x  ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  [  LinearOrder  α ] ->  {  f :  α → α } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  ,  ∃     x  ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  [  LinearOrderₓ  α ] ->  {  f :  α → α } ->  (  h :  ∃     x  ,  Function.IsPeriodicPt  f  3 x ) ->  ∀  n  ,  ∃     x  ,  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  {  f :  α → α } ->  {  x : α } ->  [  LinearOrder  α ] ->  (  hx :  Function.IsPeriodicPt  f  3 x ) ->  ∃     n  :  ℕ ,   n >  0 ∧  Function.IsPeriodicPt  f n x",
    " {  α :  Type  u_1 } ->  {  f :  α → α } ->  {  x : α } ->  [  LinearOrderₓ  α ] ->  (  hx :  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] {A B : C}\n  (hA : CategoryTheory.Limits.IsTerminal A),\n  CategoryTheory.Limits.IsTerminal B → CategoryTheory.IsIso (CategoryTheory.Limits.IsTerminal.from hA B)",
   "some-correct": null,
   "round-trip":
   "Given two terminal objects, there is an isomorphism between them. ",
   "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 ] ->  {  A B : C } ->  (  hA :  CategoryTheory.Limits.IsTerminal  A ) ->  (  hB :  CategoryTheory.Limits.IsTerminal  B ) ->  CategoryTheory.IsIso   (   hA.from  B  )",
    " {  C :  Type  u₁ } ->  [  CategoryTheory.Category  C ] ->  [  CategoryTheory.Limits.HasTerminal  C ] ->  {  Z Z' : C } ->  (  t :  CategoryTheory.Limits.IsTerminal  Z ) ->  (  t' :  CategoryTheory.Limits.IsTerminal  Z' ) ->  CategoryTheory.IsIso   (   t.from  Z'  )",
    " {  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 ] ->  {  X Y : C } ->  (  hX :  CategoryTheory.Limits.IsTerminal  X ) ->  (  hY :  CategoryTheory.Limits.IsTerminal  Y ) ->  CategoryTheory.IsIso   (   CategoryTheory.Limits.terminal.from  X  )",
    " {  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": "query for translation failed: index out of bounds: 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":
   [" {  a b c :  ℤ } ->  ¬    a ^  3 +  b ^  3 =  c ^  3",
    " {  x y z :  ℕ } ->  (  hx :  x >  0 ) ->  (  hy :  y >  0 ) ->  (  hz :  z >  0 ) ->  ¬  (     x ^  3 +  y ^  3 =  z ^  3  )",
    " {  x y z :  ℤ } ->   (    x ^  3 +  y ^  3  ) ≠  z ^  3",
    " {  a b t :  ℕ } ->    a ^  3 +  b ^  3 ≠  t ^  3",
    " {  x y z :  ℕ } ->  (  hx :  x >  0 ) ->  (  hy :  y >  0 ) ->  (  hz :  z >  0 ) ->  ¬    x ^  3 +  y ^  3 =  z ^  3",
    " {  a b :  ℤ } ->  (  h1 :  a >  0 ) ->  (  h2 :  b >  0 ) ->  ∀   {  c  :  ℤ }  ,    a ^  3 +  b ^  3 ≠  c ^  3",
    " {  x y z :  ℤ } ->  (  hx :   0 < x ) ->  (  hy :   0 < y ) ->  (  hz :   0 < z ) ->    x ^  3 +  y ^  3 ≠  z ^  3",
    " {  a b c :  ℕ } ->  (  h1 :   0 < a ) ->  (  h2 :   0 < b ) ->    a ^  3 +  b ^  3 ≠  c ^  3"]},
  {"theorem":
   "∀ {G : Type u_1} [inst : Group G] {x y : G}, (∀ (g : G), g = g⁻¹) → x * y = y * x",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "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 ] ->  {  x y : G } ->  (  h :  ∀   (  g  : G  )  ,  g =  g ⁻¹ ) ->   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  {  x y : G } ->  (  h :  ∀   (  g  : G  )  ,  g =  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 :  ∀   (  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 ] ->  {  g : G } ->  (  hg :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  {  g : G } ->  (  hg :  ∀   (  x  : G  )  ,   x * x =  1 ) ->  ∀  x y   : G ,   x * y =  y * x",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  (  h :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  h :  ∀   (  g  : G  )  ,   g * g =  1 ) ->  ∀   (  g h  : G  )  ,   g * h =  h * g",
    " {  G :  Type  u_1 } ->  [  Group  G ] ->  {  o :  G →  ℕ } ->  (  h :  ∀   (  g  : G  )  ,   o  g =  2 ) ->  ∀   (  g₁ g₂  : G  )  ,   g₁ * g₂ =  g₂ * g₁",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  {  o :  G →  ℕ } ->  (  h :  ∀   (  g  : G  )  ,   o  g =  2 ) ->  ∀   (  g₁ g₂  : G  )  ,   g₁ * g₂ =  g₂ * g₁"]},
  {"theorem": "∀ {m n : ℕ}, n = m + 1 → Even ((m + 1) * m)",
   "some-correct": null,
   "round-trip": "If `n = m + 1`, then `(m + 1) * m` is even. ",
   "prompt": "The product of two consecutive natural numbers is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  m n :  ℕ } ->  (  h :  n =  m +  1 ) ->  Even   (    (   m +  1  ) * m  )",
    " {  n :  ℕ } ->  Even   (   n *  (   n +  1  )  )",
    " {  m :  ℕ } ->  (  h :  m ≠  0 ) ->  Even   (   m *  (   m +  1  )  )",
    " {  m :  ℕ } ->  Even   (   m *  (   m +  1  )  )",
    " {  n :  ℕ } ->  Even   (    (   n +  1  ) * n  )",
    " {  m n :  ℕ } ->   Even  n →   n ≠  m +  1 →  Even   (   m *  (   m +  1  )  )",
    " {  n :  ℕ } ->  (  h :   0 < n ) ->  Even   (   n *  (   n +  1  )  )",
    " {  n :  ℕ } ->  Even   (    (   n +  1  ) * n  )"]},
  {"theorem":
   "∀ {α : Type u} [inst : Groupₓ α] {H : Subgroup α} (hs : Subgroup.index H ≤ 2), IsNormalSubgroup (?m.2828491 hs)",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "Every index 2 subgroup of a group is normal.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Groupₓ  α ] ->  {  H :  Subgroup  α } ->  (  hs :  H.index ≤  2 ) ->  IsNormalSubgroup  H"]},
  {"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": null,
   "comments": "",
   "all-elabs":
   [" (  α :  Type  u ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u_1 } ->  [  DecidableEq  α ] ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " (  α :  Type  u ) ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )",
    " {  α :  Type  u_1 } ->  Monoidₓ.IsTorsionFree   (   FreeGroup  α  )"]},
  {"theorem": "∀ (n : ℕ), 1 < n → ∃ p, Nat.Prime p ∧ p ∣ n",
   "some-correct": null,
   "round-trip":
   " If `n` is greater than 1, then there is a prime `p` dividing `n`. ",
   "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 :  ℕ } ->  (  n1 :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   p ∣ n ∧  Nat.Prime  p",
    " (  n :  ℕ ) ->  (  hn :   1 < n ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " (  n :  ℕ ) ->  (  h :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  a :  ℕ } ->  (  h :  a >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ a",
    " (  n :  ℕ ) ->  (  h :   1 < n ) ->  ∃    (   p :  ℕ ) ,   p ∣ n ∧  Nat.Prime  p",
    " {  n :  ℕ } ->  (  hn :  n >  1 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ n",
    " {  n :  ℕ } ->  (  hn :  n ≥  2 ) ->  ∃    (   p :  ℕ ) ,   Nat.Prime  p ∧  p ∣ 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 ] ->  (  hT :  Monoidₓ.IsTorsionFree  G ) ->   Fintype.card  G =  1",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [ hN :  Nontrivial  G ] ->  [  Fintype  G ] ->   Monoidₓ.IsTorsionFree  G →  FreeGroup  G",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->   Monoidₓ.IsTorsionFree  G →   Fintype.card  G =  1",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Fintype  G ] ->   Monoidₓ.IsTorsionFree  G →  ¬  Nontrivial  G"]},
  {"theorem":
   "∀ {K : Type u} [inst : DivisionRing K] [inst_1 : Fintype 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 } ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  IsField  K",
    " (  K :  Type  u ) ->  [  DivisionRing  K ] ->  [  Fintype  K ] ->  Field  K",
    " (  K :  Type* ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K",
    " (  K :  Type  u ) ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  IsField  K",
    " {  α :  Type  u_1 } ->  [  Fintype  α ] ->  [  DivisionRing  α ] ->  Field  α",
    " {  K :  Type  u } ->  [  Fintype  K ] ->  [  DivisionRing  K ] ->  Field  K"]},
  {"theorem":
   "∀ {α : Type u} [inst : TopologicalSpace α], Fintype α → IsCompact Set.Univ",
   "some-correct": null,
   "round-trip": "If `α` is a finite type, then `univ` is compact. ",
   "prompt": "Every finite topological space is compact",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Fintype  α ) ->  IsCompact   (  Set.Univ   :  Set  α )",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  h :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hf :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  Nontrivial  α ] ->  [  TopologicalSpace  α ] ->  IsCompact  Set.Univ",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  (  hα :  Finite  α ) ->  IsCompact  α",
    " {  α :  Type  u } ->  [  Fintype  α ] ->  [  TopologicalSpace  α ] ->  IsCompact   (  Set.Univ   :  Set  α )"]},
  {"theorem":
   "∀ {n : ℕ}, 0 < n → n % 2 = 0 → ∃ p q, Prime p ∧ 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": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  h :   0 < n ) ->  (  h2 :   n %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   Prime  p ∧   Prime  q ∧   p + q = n",
    " {  n :  ℕ } ->  (  h :    0 < n ∧   n %  2 =  0 ) ->  ∃     a₁  a₂  :  ℕ ,   Nat.Prime  a₁ ∧   Nat.Prime  a₂ ∧   a₁ + a₂ = n",
    " (  n :  ℕ ) ->  (  hn :   0 < n ) ->  ∃    (   m  p :  ℕ ) ,   Nat.Prime  m ∧   Nat.Prime  p ∧  n =  m +  (   p +  1  )",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  hev :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " ∀   (  n  :  ℕ  )  ,    n >  0 ∧  Even  n →  ∃    (   p  q :  ℕ ) ,   n =  p + q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " {  n :  ℕ } ->  (  h :   0 < n ) ->  (  h2 :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " ∀  n  ,   n >  0 →    n %  2 =  0 →  ∃    (   p  q :  ℕ ) ,   n =  p + q ∧   Nat.Prime  p ∧  Nat.Prime  q",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧   a + b = n",
    " (  n :  ℕ ) ->  (  hpos :   0 < n ) ->  (  heven :  Even  n ) ->  ∃    (   a  b :  ℕ ) ,   Nat.Prime  a ∧   Nat.Prime  b ∧  n =  a + b",
    " {  n :  ℕ } ->  (  h_pos :   0 < n ) ->  (  h_even :   n %  2 =  0 ) ->  ∃    (   p  q :  ℕ ) ,   Nat.Prime  p ∧   Nat.Prime  q ∧   p + q = n",
    " (  n :  ℕ ) ->  (  hn :    0 < n ∧   n %  2 =  0 ) ->  ∃    (   a  b :  ℕ ) ,   n =  (   a + b  ) ∧   Nat.Prime  a ∧  Nat.Prime  b"]},
  {"theorem": "∀ {n : ℕ}, n ^ 2 % 2 = 0 → n % 2 = 0",
   "some-correct": null,
   "round-trip": "query for translation failed: index out of bounds: 0",
   "prompt": "If the square of a number is even, the number itself is even.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" {  n :  ℕ } ->  (  hn2 :    n ^  2 %  2 =  0 ) ->   n %  2 =  0",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  a : α } ->   Even   (   a * a  ) →  Even  a",
    " {  a :  ℕ } ->   Even   (   a * a  ) →  Even  a",
    " {  n :  ℕ } ->  (  hn :    n ^  2 %  2 =  0 ) ->   n %  2 =  0",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  (  x : α ) ->  IsSquare   (    2 *  x ^  2  )",
    " {  n :  ℕ } ->  (  h :  Even   (   n ^  2  ) ) ->  Even  n",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  ∀   (  a  : α  )  ,     a * a %  2 =  0 →   a %  2 =  0",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  ∀   (  a  : α  )  ,     a * a %  2 =  0 →   a %  2 =  0",
    " {  n :  ℕ } ->  ∀   (  n  :  ℕ  )  ,     (    n * n +  2  ) %  4 =  0 →   n %  2 =  0",
    " {  α :  Type  u } ->  [  CommRing  α ] ->  {  a : α } ->  (  ha :    a * a %  2 =  0 ) ->   a %  2 =  0",
    " {  α :  Type  u } ->  [  CommRingₓ  α ] ->  {  a : α } ->  (  ha :    a * a %  2 =  0 ) ->   a %  2 =  0",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  {  x : α } ->  (  hx :  Even   (   x * x  ) ) ->  Even  x",
    " {  α :  Type  u_1 } ->  [  LinearOrderedCommRing  α ] ->  {  a : α } ->  (  hab :    a * a %  2 =  0 ) ->   a %  2 =  0",
    " {  n :  ℕ } ->   Even   (   n * n  ) →  Even  n",
    " {  α :  Type  u } ->  [  LinearOrderedRing  α ] ->  (  x : α ) ->   Even   (   x * x  ) →  Even  x"]},
  {"theorem":
   "∀ {α : Type u} [t : TopologicalSpace α] {s : Set α}, (∀ (x : α), x ∈ s → ∃ U, x ∈ U ∧ IsOpen U) → 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 } ->  [ t :  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  x  : α  )  ,   x ∈ s →  ∃     U  :  Set  α ,   x ∈ U ∧  IsOpen  U ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃    (   V :  Set  α ) ,   x ∈ V ∧  IsOpen  V ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  a  ∈ s ,  ∃     u  ,   IsOpen  u ∧  a ∈ u ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ,   x ∈ s →  ∃     t  ,   IsOpen  t ∧  x ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀   (  a  : α  )  ,   a ∈ s →  ∃    (   t :  Set  α ) ,   IsOpen  t ∧  a ∈ t ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  hs :  ∀  a  ∈ s ,  ∃    (   u :  Set  α ) ,   a ∈ u ∧  IsOpen  u ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     V  ,   IsOpen  V ∧  x ∈ V ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     u  :  Set  α ,   IsOpen  u ∧  x ∈ u ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s :  Set  α } ->  (  h :  ∀  x  ∈ s ,  ∃     u  ,   x ∈ u ∧   IsOpen  u ∧  u ⊆ s ) ->  IsOpen  s",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  u :  Set  α } ->  (  hu :  ∀   (  x  : α  )  ,   x ∈ u →  ∃    (   v :  Set  α )  (   hv :  IsOpen  v ) ,  x ∈ v ) ->  IsOpen  u",
    " {  α :  Type  u } ->  [  TopologicalSpace  α ] ->  {  s t :  Set  α } ->  (  h_s :  ∀   (  x  : α  )  ,   x ∈ s →  ∃    (   u :  Set  α ) ,   x ∈ u ∧  IsOpen  u ) ->   s ⊆ t →  ∀  x  ,   x ∈ t →  ∃    (   u :  Set  α ) ,   x ∈ u ∧  IsOpen  u"]},
  {"theorem":
   "∀ {α : Type u}, Nontrivial (FreeGroup α) → Monoidₓ.IsTorsionFree (FreeGroup α)",
   "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": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  ∀   (  hN  :  Nontrivial   (   FreeGroup  α  )  )  ,  Monoidₓ.IsTorsionFree $  FreeGroup  α",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   ¬  (   g =  1  ) →  ¬  IsOfFinOrder  g",
    " {  G :  Type  u_1 } ->  [  Groupₓ  G ] ->  (  g : G ) ->  (  h :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  [  Nontrivial  α ] ->  (  x :  FreeGroup  α ) ->  (  H :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  (  L :  List   (   α × Bool  ) ) ->  [  DecidableEq  α ] ->  (  H :  L ≠  [  ] ) ->  ¬  IsOfFinOrder   (   FreeGroup.mk  L  )",
    " (  α :  Type  u ) ->  (  g :  FreeGroup  α ) ->  (  h :  g ≠  1 ) ->  ∀   (  n  :  ℕ  )  ,  ¬   orderOf  g = n",
    " {  α :  Type  u } ->  {  g :  FreeGroup  α } ->  (  hg :  g ≠  1 ) ->  ¬  IsOfFinOrder  g",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  (  a :  FreeGroup  α ) ->   a ≠  1 →  ¬  IsOfFinOrder  a",
    " {  α :  Type  u } ->  (  x :  FreeGroup  α ) ->  (  hx :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  [  DecidableEq  α ] ->  ∀   (  x  :  FreeGroup  α  )  (  h  :  x ≠  1  )  ,  ¬  IsOfFinOrder  x",
    " {  α :  Type  u } ->  {  x :  FreeGroup  α } ->  (  h :  x ≠  1 ) ->  ¬  IsOfFinOrder  x",
    " (  α :  Type  u ) ->  ∀   (  x  :  FreeGroup  α  )  ,    FreeGroup.of  x ≠  1 →  ∀  n   :  ℕ ,  n ≠  orderOf  x",
    " {  α :  Type  u } ->  (  g :  FreeGroup  α ) ->   g ≠  1 →  ¬  IsOfFinOrder  g",
    " {  α :  Type  u_1 } ->  [  Fintype  α ] ->  (  hα :  Nonempty  α ) ->  ∃    (   x :  FreeGroup  α ) ,   x ≠  1 ∧  ¬  IsOfFinOrder  x"]},
  {"theorem": "∀ {a b N : ℕ}, Nat.gcd a b = 1 → ∃ m n, N = a * m + b * n",
   "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 ) ->  ∃     m  n  :  ℕ ,  N =   a * m +  b * n",
    " {  a b N :  ℤ } ->  (  hab :   a.gcd  b =  1 ) ->  (  hN :   0 < N ) ->  ∃    (   x  y :  ℤ ) ,    0 ≤ x ∧   x < b ∧    0 ≤ y ∧   y < a ∧  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  hab :   gcd  a b =  1 ) ->  {  N :  ℕ } ->  (  hN :  N ≥  a + b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " (  a b :  ℕ ) ->  (  hab :   a.gcd  b =  1 ) ->  {  N :  ℕ } ->  (  hN :  N ≥  a * b ) ->  ∃    (   x  y :  ℕ ) ,  N =   a * x +  b * y",
    " {  a b :  ℕ } ->  (  hab :   a.gcd  b =  1 ) ->  (  h :   (  b   :  ℤ ) >  0 ) ->  ∃    (   x  y :  ℕ ) ,  ∀   {  N  :  ℕ }  ,   N ≥ b →  ∃    (   n  m :  ℕ ) ,  N =   n * a +  m * b"]},
  {"theorem": "(K : Type u) → [inst : Field K] → CommRing K",
   "some-correct": null,
   "round-trip": "A `Field` is a `CommRing`. ",
   "prompt": "Every field is a ring.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" (  K :  Type  u ) ->  [  Field  K ] ->  CommRing  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  CommRingₓ  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",
    " (  F :  Type  u₁ ) ->  [  Field  F ] ->  Ring  F",
    " (  F :  Type  u₁ ) ->  [  Field  F ] ->  Ringₓ  F",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Semiring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Semiringₓ  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ring  R",
    " (  R :  Type  u ) ->  [  Field  R ] ->  Ringₓ  R",
    " (  F :  Type  u ) ->  [  Field  F ] ->  IsSubring  F",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ring  K",
    " (  K :  Type  u ) ->  [  Field  K ] ->  Ringₓ  K"]},
  {"theorem": "{α : Type u} → [inst : Ringₓ α] → Group (Units α)",
   "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": null,
   "comments": "",
   "all-elabs":
   [" {  α :  Type  u } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u_1 } ->  [  Ringₓ  α ] ->  [  DecidableEq  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClass  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  MulOneClassₓ  α ] ->  Groupₓ   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Fintype  α ] ->  [  DecidableEq  α ] ->  Group   (   Units  α  )",
    " {  α :  Type  u } ->  [  Ringₓ  α ] ->  [  Fintype  α ] ->  [  DecidableEq  α ] ->  Groupₓ   (   Units  α  )"]},
  {"theorem":
   "∀ {G G₁ G₂ : Type u_1} [inst : Groupₓ G₁] [inst_1 : Groupₓ G₂],\n  Monoidₓ.IsTorsionFree (G₁ × 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 :  Type  u_1 } ->  {  G₁ G₂ :  Type  u_1 } ->  [  Groupₓ  G₁ ] ->  [  Groupₓ  G₂ ] ->  (  H₁ :  Monoidₓ.IsTorsionFree   (   G₁ × G₂  ) ) ->  (  H₂ :  Monoidₓ.IsTorsionFree   (   G₁ × G₂  ) ) ->   Monoidₓ.IsTorsionFree  G₁ ∧  Monoidₓ.IsTorsionFree  G₂",
    " {  G H :  Type  u_1 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  (  w :  Monoidₓ.IsTorsionFree   (   G × H  ) ) ->   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  {  tf :  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",
    " {  η :  Type  u_1 } ->  {  Gs :  η →  Type  u_2 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  (  h :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,  Gs  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )",
    " {  G :  Type  u_1 } ->  {  H :  Type  u_2 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  (  tfprod :  Monoidₓ.IsTorsionFree   (   G × H  ) ) ->   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  G1 G2 :  Type  u_1 } ->  [  Groupₓ  G1 ] ->  [  Groupₓ  G2 ] ->   Monoidₓ.IsTorsionFree   (   G1 × G2  ) →   Monoidₓ.IsTorsionFree  G1 ∧  Monoidₓ.IsTorsionFree  G2",
    " {  G :  Type  u_1 } ->  {  H :  Type  u_2 } ->  [  Groupₓ  G ] ->  [  Groupₓ  H ] ->  (  tf :  Monoidₓ.IsTorsionFree   (   G × H  ) ) ->   Monoidₓ.IsTorsionFree  G ∧  Monoidₓ.IsTorsionFree  H",
    " {  η :  Type  u_1 } ->  {  η' :  Type  u_2 } ->  {  Gs' :  η' →  Type  u_3 } ->  {  Gs :  η →  Type  u_4 } ->  [  Π ( i : η ) ,  Groupₓ   (   Gs  i  ) ] ->  [  Π ( i : η' ) ,  Groupₓ   (   Gs'  i  ) ] ->  (  tf :  Monoidₓ.IsTorsionFree   (   Π ( i : η ) ,   Gs  i ×  Π ( i : η' ) ,  Gs'  i  ) ) ->  (  i : η ) ->  Monoidₓ.IsTorsionFree   (   Gs  i  )"]},
  {"theorem": "ℕ → ∃ x y z, z * z = x * x + y * y ∧ z > 2 ∧ y > 1 ∧ x ≥ y",
   "some-correct": null,
   "round-trip":
   "For any natural number n, there exist natural numbers x, y, and z such that z^2 = x^2 + y^2, z > 2, y > 1, and x ≥ y. ",
   "prompt": "There are infinitely many Pythagorean triples.",
   "correct": null,
   "comments": "",
   "all-elabs":
   [" ∀   (  n  :  ℕ  )  ,  ∃    (   x  y  z :  ℕ ) ,    z * z =   x * x +  y * y ∧   z >  2 ∧   y >  1 ∧  x ≥ y",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   x  y  z :  ℕ ) ,    gcd  x y =  1 ∧  PythagoreanTriple  x y z",
    " ∃    (   xs :   ℕ →  ℕ ) ,  ∀  t  ,  PythagoreanTriple   (   xs  t  ) t  (   xs   (   t +  1  )  )",
    " ∀   (  k  :  ℕ  )  ,  ∃    (   x  y  z :  ℕ ) ,   k ≠  0 ∧  PythagoreanTriple  x y z",
    " ∀   (  z  :  ℤ  )  ,  ∃     x  y  :  ℤ ,  PythagoreanTriple  x y z",
    " ∀   (  n  :  ℕ  )  ,  ∃    (   x  y  z :  ℕ ) ,   PythagoreanTriple  x y z ∧  z > n",
    " ∀   (  z  :  ℕ  )  ,  ∃    (   x  y :  ℕ ) ,  PythagoreanTriple  x y z",
    " {  x y z :  ℕ } ->  ∃    (   hk :  ℕ )  (   hx :  ℕ )  (   hy :  ℕ ) ,    hk * hk =   x * x +  y * y ∧    hx * hx =   hk * hk +  z * z ∧   hy * hy =   hx * hx +  hk * hk",
    " ∀   (  k  :  ℕ  )  ,  ∃    (   x  y  z :  ℤ ) ,   PythagoreanTriple  x y z ∧  x >  0",
    " ∀  z   :  ℤ ,  ∃     x  y  :  ℤ ,  PythagoreanTriple  x y z",
    " ∀   (  a b c  :  ℕ  )  ,  ∃    (   a'  b'  c' :  ℕ ) ,   (     a' * a' +  b' * b' =  c' * c'  ) ∧   a' > a ∧   b' > b ∧  c' > c"]}],
 "elaborated": 30}