normalized_state,count,families,files,example_theorems
goal=s.encard ≠ <num> context=α : type u_1 ; <var> : set α ; <var> : s.encard = <num>,4,rw:4,MathlibSubset/Mathlib/Data/Set/Card.lean:4,Set.encard_eq_one;Set.encard_eq_two;Set.encard_eq_three;Set.encard_eq_four
goal=<num> ≠ <num> context=α : type u_1 ; <var> : set α ; <var> : s.encard = <num>,4,simp:4,MathlibSubset/Mathlib/Data/Set/Card.lean:4,Set.encard_eq_one;Set.encard_eq_two;Set.encard_eq_three;Set.encard_eq_four
goal=s.encard.tonat = <num> ↔ s.encard = <num> context=α : type u_1 ; <var> : set α,3,simp:3,MathlibSubset/Mathlib/Data/Set/Card.lean:3,Set.ncard_eq_two;Set.ncard_eq_three;Set.ncard_eq_four
goal=nat.card αˣ = nat.card α - <num> context=α : type u_1 ; inst✝ : groupwithzero α,2,classical:1;rw:1,MathlibSubset/Mathlib/Data/Fintype/Units.lean:2,Nat.card_units;Nat.card_units
goal=nat.card ({ a // a = <num> } ⊕ { a // ¬a = <num> }) - <num> = nat.card { a // a ≠ <num> } context=case inr ; α : type u_1 ; inst✝ : groupwithzero α ; h✝ : infinite { a // a ≠ <num> },2,rw:2,MathlibSubset/Mathlib/Data/Fintype/Units.lean:2,Nat.card_units;Nat.card_units
"goal=∃ t a, ∃ (<var> : a ∉ t), ∃ b, ∃ (<var> : b ∉ t) (<var> : ¬a = b), cons a (cons b t hb) ⋯ = s context=α : type u_1 ; <var> : finset α ; <var> : s.nontrivial",2,classical:1;obtain:1,MathlibSubset/Mathlib/Data/Finset/Basic.lean:2,Finset.Nontrivial.exists_cons_eq;Finset.Nontrivial.exists_cons_eq
"goal=∃ s₁ s₂, s₁ ∪ s₂ = s ∧ ↑s₁ ⊆ t₁ ∧ ↑s₂ ⊆ t₂ \ t₁ context=α : type u_1 ; inst✝ : decidableeq α ; <var> : finset α ; t₁ t₂ : set α ; <var> : ↑s ⊆ t₁ ∪ t₂",2,classical:1;refine:1,MathlibSubset/Mathlib/Data/Finset/Basic.lean:2,Finset.subset_union_elim;Finset.subset_union_elim
goal=↑(filter (fun x => x ∉ t₁) s) ⊆ t₂ \ t₁ context=case refine_3 ; α : type u_1 ; inst✝ : decidableeq α ; <var> : finset α ; t₁ t₂ : set α ; <var> : ↑s ⊆ t₁ ∪ t₂,2,intro:2,MathlibSubset/Mathlib/Data/Finset/Basic.lean:2,Finset.subset_union_elim;Finset.subset_union_elim
"goal=(∃ p, prime p ∧ p ∣ m ∧ p ∣ n !) → m.minfac ≤ n context=case mpr ; m <var> : ℕ ; <var> : m ≠ <num>",2,rintro:2,MathlibSubset/Mathlib/Data/Nat/Prime/Factorial.lean:2,Nat.coprime_factorial_iff;Nat.coprime_factorial_iff
goal=sqrt x = <num> ↔ x = <num> context=<var> : ℝ≥<num>,2,simp:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.sqrt_eq_zero;NNReal.sqrt_eq_one
goal=sqrt <num> = <num> context=,2,simp:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.sqrt_zero;NNReal.sqrt_one
goal=y * y = x ∧ <num> ≤ y ∨ x < <num> ∧ y = <num> → √x = y context=case mpr ; x <var> : ℝ,2,rintro:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.Real.sqrt_eq_cases;NNReal.Real.sqrt_eq_cases
goal=√x * √x = x ∧ <num> ≤ √x ∨ x < <num> ∧ √x = <num> context=case mp.inr ; <var> : ℝ ; <var> : x < <num>,2,exact:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.Real.sqrt_eq_cases;NNReal.Real.sqrt_eq_cases
goal=√<num> = <num> context=,2,simp:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.Real.sqrt_zero;NNReal.Real.sqrt_one
goal=-√y ≤ x ∧ x ≤ √y → x ^ <num> ≤ y context=case mpr ; x <var> : ℝ ; <var> : <num> ≤ y,2,rw:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.Real.sq_le;NNReal.Real.sq_le
goal=√x ≤ √y ↔ x ≤ y context=case inr ; x <var> : ℝ ; <var> : <num> < x ; <var> : <num> ≤ y,2,exact:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.Real.sqrt_le_sqrt_iff';NNReal.Real.sqrt_le_sqrt_iff'
goal=<num> ≤ a.sqrt + <num> context=<var> : ℕ,2,exact:2,MathlibSubset/Mathlib/Data/Real/Sqrt.lean:2,NNReal.Real.Mathlib.Meta.Positivity.Real.real_sqrt_lt_nat_sqrt_succ;NNReal.Real.Mathlib.Meta.Positivity.Real.real_sqrt_lt_nat_sqrt_succ
goal=a ≡ b [mod n] → a ≡ b [pmod n] context=case mpr ; a b <var> : ℕ,2,rw:2,MathlibSubset/Mathlib/Data/Nat/ModEq.lean:2,AddCommGroup.modEq_iff_natModEq;AddCommGroup.modEq_iff_natModEq
goal=c * a ≡ c * b [mod c * n] context=n a b <var> : ℕ ; <var> : a ≡ b [mod n],2,unfold:1;exact:1,MathlibSubset/Mathlib/Data/Nat/ModEq.lean:2,AddCommGroup.Nat.ModEq.ModEq.mul_left';AddCommGroup.Nat.ModEq.ModEq.mul_right'
goal=(↑m / ↑d).gcd (↑c / ↑d) = <num> context=case refine_2 ; m a b <var> : ℕ ; <var> : <num> < m ; <var> : c * a ≡ c * b [mod m] ; <var> : ℕ := m.gcd c ; <var> : m.gcd c ∣ <var> := gcd_dvd_left m c ; <var> : m.gcd c ∣ <var> := gcd_dvd_right,2,show:1;simp:1,MathlibSubset/Mathlib/Data/Nat/ModEq.lean:2,AddCommGroup.Nat.ModEq.ModEq.ModEq.cancel_left_div_gcd;AddCommGroup.Nat.ModEq.ModEq.ModEq.cancel_left_div_gcd
goal=(a % c + b % c) % c + <num> = a % c + b % c context=case neg ; a b <var> : ℕ ; <var> : (a + b) % c = (a % c + b % c) % <var> := modeq.symm (modeq.add (mod_modeq a c) (mod_modeq b c)) ; <var> : ¬c = <num> ; <var> : ¬c ≤ a % c + b % c,2,rw:2,MathlibSubset/Mathlib/Data/Nat/ModEq.lean:2,AddCommGroup.Nat.ModEq.ModEq.ModEq.add_mod_add_ite;AddCommGroup.Nat.ModEq.ModEq.ModEq.add_mod_add_ite
goal=n % <num> = <num> → n % <num> = <num> context=<var> : ℕ,2,simpa:2,MathlibSubset/Mathlib/Data/Nat/ModEq.lean:2,AddCommGroup.Nat.ModEq.ModEq.ModEq.odd_of_mod_four_eq_one;AddCommGroup.Nat.ModEq.ModEq.ModEq.odd_of_mod_four_eq_three
goal=sqrt ↑n = ↑n.sqrt context=<var> : ℕ,2,rw:2,MathlibSubset/Mathlib/Data/Rat/Sqrt.lean:1;MathlibSubset/Mathlib/Data/Int/Sqrt.lean:1,Rat.sqrt_natCast;Int.sqrt_natCast
goal=a * (b / c) ≤ a * b / c context=case inr ; <var> : int ; <var> : <num> ≤ a ; b <var> : int ; <var> : <num> ≤ c ; <var> : <num> < c,2,rw:2,MathlibSubset/Mathlib/Data/Int/DivMod.lean:2,Int.mul_ediv_le_mul_ediv_assoc;Int.mul_ediv_le_mul_ediv_assoc
goal=z ⊔ y \ x ≤ y context=case a ; α : type u ; x y <var> : α ; inst✝ : generalizedbooleanalgebra α ; <var> : z ≤ y ; <var> : x ≤ y ; h : x ≤ z,2,grw:2,MathlibSubset/Mathlib/Order/BooleanAlgebra/Basic.lean:2,le_iff_eq_sup_sdiff;le_iff_eq_sup_sdiff
goal=x ⊓ y \ z ⊓ (z ⊓ x ⊔ x \ y) = ⊥ context=case i ; α : type u ; x y <var> : α ; inst✝ : generalizedbooleanalgebra α,2,calc:2,MathlibSubset/Mathlib/Order/BooleanAlgebra/Basic.lean:2,sdiff_sdiff_right;sdiff_sdiff_right
goal=<num> ≤ a ∧ <num> ≤ b ∨ a ≤ <num> ∧ b ≤ <num> context=case neg ; a <var> : ℤ ; <var> : <num> ≤ a * b ; <var> : a < <num> ; <var> : b < <num>,2,exact:2,MathlibSubset/Mathlib/Data/Int/Order/Basic.lean:2,Int.nonneg_or_nonpos_of_mul_nonneg;Int.nonneg_or_nonpos_of_mul_nonneg
"goal=motive (finset.cons a t ha) hs context=case cons.inr ; α : type u_3 ; <var> : (<var> : finset α) → s.nonempty → prop ; <var> : ∀ (<var> : α), motive {a} ⋯ ; <var> : ∀ (<var> : α) (<var> : finset α) (<var> : a ∉ s) (<var> : s.nonempty),",2,exact:2,MathlibSubset/Mathlib/Data/Finset/Insert.lean:2,Finset.Nonempty.cons_induction;Finset.Nonempty.cons_induction
goal=l.rotate <num> = l context=α : type u ; <var> : list α,2,simp:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_zero;List.IsRotated.refl
goal=(l ++ l').rotate l.length = l' ++ l context=α : type u ; l <var> : list α,2,rw:1;simp:1,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_append_length_eq;List.isRotated_append
"goal=(head✝ :: tail✝ ++ l').rotate' (head✝ :: tail✝).length = l' ++ head✝ :: tail✝ context=case cons ; α : type u ; head✝ : α ; tail✝ : list α ; tail_ih✝ : ∀ (<var> : list α), (tail✝ ++ l').rotate' tail✝.length = l' ++ tail✝ ; <var> : list ",2,simp_all:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_append_length_eq;List.rotate_append_length_eq
"goal=(<var> :: tl).rotate' (n + <num>) ~ <var> :: tl context=case succ.cons ; α : type u ; <var> : ℕ ; <var> : ∀ (<var> : list α), l.rotate' n ~ l ; <var> : α ; <var> : list α",2,rw:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_perm;List.rotate_perm
"goal=(<var> :: tl).rotate (n + <num>) = [] ↔ <var> :: tl = [] context=case succ.cons ; α : type u ; <var> : ℕ ; <var> : ∀ {<var> : list α}, l.rotate n = [] ↔ l = [] ; <var> : α ; <var> : list α",2,simp:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_eq_nil_iff;List.rotate_eq_nil_iff
goal=(drop (n % l.length) l ++ take (n % l.length) l)[m]? = l[(m + n) % l.length]? context=case inr ; α : type u ; <var> : list α ; n <var> : ℕ ; <var> : m < l.length ; <var> : (drop (n % l.length) l).length ≤ m,2,have:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.getElem?_rotate;List.getElem?_rotate
goal=m - (drop (n % l.length) l).length < n % l.length context=case inr ; α : type u ; <var> : list α ; n <var> : ℕ ; <var> : m < l.length ; <var> : (drop (n % l.length) l).length ≤ m ; <var> : n % l.length < l.<var> := mod_lt n (le.le.tran,2,rwa:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.getElem?_rotate;List.getElem?_rotate
goal=l.rotate n = l' ↔ l.rotate n = l'.rotate (((l'.length - n % l'.length) % l'.length + n % l'.length) % l'.length) context=case inr ; α : type u ; l <var> : list α ; <var> : ℕ ; <var> : <num> < l'.length,2,rcases:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_eq_iff;List.rotate_eq_iff
goal=l.rotate n = l' ↔ l.rotate n = l'.rotate (((l'.length - n % l'.length) % l'.length + n % l'.length) % l'.length) context=case inr.inr ; α : type u ; l <var> : list α ; <var> : ℕ ; <var> : <num> < l'.length ; <var> : <num> < n % l'.leng,2,rw:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_eq_iff;List.rotate_eq_iff
"goal=((<var> :: tl).rotate (n + <num>)).reverse.rotate (n + <num>) = (<var> :: tl).reverse context=case succ.cons ; α : type u ; <var> : ℕ ; <var> : ∀ (<var> : list α), (l.rotate n).reverse.rotate n = l.reverse ; <var> : α ; <var> : list α",2,rw:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.reverse_rotate;List.reverse_rotate
goal=l.reverse = l.reverse.rotate (l.reverse.length - (l.reverse.length - n % l.reverse.length) % l.reverse.length + (l.reverse.length - n % l.reverse.length)) context=case succ ; α : type u ; <var> : list α ; <var> : ℕ ; <var> : ℕ := n % l,2,rcases:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_reverse;List.rotate_reverse
goal=(<var> :: l).reverse = (<var> :: l).reverse.rotate ((<var> :: l).reverse.length - ((<var> :: l).reverse.length - n % (<var> :: l).reverse.length) % (<var> :: l).reverse.length + ((<var> :: l).reverse.length - n % (<var> :: l).reverse.l,2,rw:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_reverse;List.rotate_reverse
goal=(<var> :: l).reverse.length - n % (<var> :: l).reverse.length < (<var> :: l).reverse.length context=case succ.cons ; α : type u ; n <var> : ℕ ; <var> : α ; <var> : list α ; <var> : ℕ := n % (<var> :: l).reverse.length ; <var> : k = k' ,2,exact:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.rotate_reverse;List.rotate_reverse
"goal=map f ((<var> :: tl).rotate (n + <num>)) = (map f (<var> :: tl)).rotate (n + <num>) context=case succ.cons ; α : type u ; β : type u_1 ; <var> : α → β ; <var> : ℕ ; <var> : ∀ (<var> : list α), map f (l.rotate n) = (map f l).rotate n ; ",2,simp:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.map_rotate;List.map_rotate
goal=l.rotate i = l.rotate j ↔ i % l.length = j % l.length ∨ l = [] context=case inr ; α : type u ; <var> : list α ; <var> : l.nodup ; i <var> : ℕ ; <var> : l ≠ [],2,simp:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.Nodup.rotate_congr_iff;List.Nodup.rotate_congr_iff
goal=(<var> :: tl).rotate n ~r <var> :: tl context=case cons ; α : type u ; <var> : ℕ ; <var> : α ; <var> : list α,2,use:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.IsRotated.symm;List.IsRotated.symm
"goal=∃ n_1, n_1 ≤ (<var> :: tl).length ∧ (<var> :: tl).rotate n_1 = (<var> :: tl).rotate n context=case cons ; α : type u ; <var> : ℕ ; <var> : α ; <var> : list α",2,refine:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.isRotated_iff_mod;List.isRotated_iff_mod
goal=((head✝ :: tail✝).rotate k).cyclicpermutations.length = ((head✝ :: tail✝).cyclicpermutations.rotate k).length context=case cons ; α : type u ; <var> : ℕ ; head✝ : α ; tail✝ : list α,2,rw:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.cyclicPermutations_rotate;List.cyclicPermutations_rotate
goal=l ~r l' → l ∈ l'.cyclicpermutations context=case mpr ; α : type u ; l <var> : list α,2,rintro:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.mem_cyclicPermutations_iff;List.mem_cyclicPermutations_iff
goal=l.cyclicpermutations.nodup context=case inr ; α : type u ; <var> : list α ; <var> : l.nodup ; <var> : l ≠ [],2,rw:2,MathlibSubset/Mathlib/Data/List/Rotate.lean:2,List.Nodup.cyclicPermutations;List.Nodup.cyclicPermutations
goal=<num> * j = <num> context=case inr ; <var> : ℕ ; left✝ : prime j ; <var> : <num> ≠ <num> ; <var> : prime (<num> * j),2,exact:2,MathlibSubset/Mathlib/Data/Nat/Prime/Basic.lean:2,Nat.Prime.dvd_iff_eq;Nat.Prime.dvd_iff_eq
"goal=(∃ p, prime p ∧ p ∣ m ∧ p ∣ n) → ¬m.coprime n context=case mpr ; m <var> : ℕ",2,intro:2,MathlibSubset/Mathlib/Data/Nat/Prime/Basic.lean:2,Nat.Prime.not_coprime_iff_dvd;Nat.Prime.not_coprime_iff_dvd
goal=x = p ∧ y = p context=case inr ; x✝ y✝ <var> : ℕ ; <var> : prime p ; hx✝ : x✝ ≠ <num> ; hy✝ : y✝ ≠ <num> ; h✝ : x✝ * y✝ = p ^ <num> ; <var> : p ∣ x✝ * y✝ := ; eq.mpr (id (congrarg (fun _a => p ∣ _a) h✝)) ; (of_eq_true (eq.trans (congra,2,refine:2,MathlibSubset/Mathlib/Data/Nat/Prime/Basic.lean:2,Nat.Prime.mul_eq_prime_sq_iff;Nat.Prime.mul_eq_prime_sq_iff
"goal=<num> ≠ <num> ↔ ∃ p, prime p ∧ p ∣ <num> context=",2,simpa:1;simp:1,MathlibSubset/Mathlib/Data/Nat/Prime/Basic.lean:2,Nat.ne_one_iff_exists_prime_dvd;Nat.ne_one_iff_exists_prime_dvd
"goal=∏ x ∈ erasenone s, f x = ∏ x ∈ s, option.elim' <num> f x context=α : type u_1 ; m : type u_2 ; inst✝ : commmonoid m ; <var> : α → m ; <var> : finset (option α)",2,classical:1;calc:1,MathlibSubset/Mathlib/Algebra/BigOperators/Option.lean:2,Finset.prod_eraseNone;Finset.prod_eraseNone
goal=some val✝ = none ↔ m < n context=case some ; m n val✝ : ℕ ; <var> : m.psub n = some val✝,2,grind:2,MathlibSubset/Mathlib/Data/Nat/PSub.lean:2,Nat.psub_eq_none;Nat.psub_eq_none
goal=none = m.psub n context=case neg ; m <var> : ℕ ; <var> : ¬n ≤ m,2,exact:2,MathlibSubset/Mathlib/Data/Nat/PSub.lean:2,Nat.psub'_eq_psub;Nat.psub'_eq_psub
goal=(false = true) = false context=,2,simp:2,MathlibSubset/Mathlib/Data/Bool/Basic.lean:2,Bool.coe_false;Bool.coe_sort_false
goal=(true = true) = true context=,2,simp:2,MathlibSubset/Mathlib/Data/Bool/Basic.lean:2,Bool.coe_true;Bool.coe_sort_true
goal=c * a ≡ c * b [zmod c * n] context=n a b <var> : ℤ ; <var> : a ≡ b [zmod n],2,obtain:1;exact:1,MathlibSubset/Mathlib/Data/Int/ModEq.lean:2,AddCommGroup.Int.ModEq.ModEq.mul_left';AddCommGroup.Int.ModEq.ModEq.mul_right'
goal=c * a ≡ c * b [zmod c * n] context=case inr.inr ; n a b <var> : ℤ ; <var> : a ≡ b [zmod n] ; <var> : <num> < c,2,simp:2,MathlibSubset/Mathlib/Data/Int/ModEq.lean:2,AddCommGroup.Int.ModEq.ModEq.mul_left';AddCommGroup.Int.ModEq.ModEq.mul_left'
goal=(m / ↑(m.gcd c)).gcd (c / ↑d) = <num> context=case refine_2 ; m a b <var> : ℤ ; <var> : <num> < m ; <var> : m ∣ b * c - a * c ; <var> : ℕ := m.gcd c,2,rw:2,MathlibSubset/Mathlib/Data/Int/ModEq.lean:2,AddCommGroup.Int.ModEq.ModEq.cancel_right_div_gcd;AddCommGroup.Int.ModEq.ModEq.cancel_right_div_gcd
goal=false context=case right ; α : type u_1 ; inst✝¹ : linearorder α ; a₁ a₂ b₁ b₂ : α ; inst✝ : denselyordered α ; h₁ : a₁ < b₁ ; <var> : ioo a₁ b₁ ⊆ ioo a₂ b₂ ; <var> : α ; <var> : a₁ < x ; <var> : x < b₁ ; <var> : b₂ < b₁,2,have:2,MathlibSubset/Mathlib/Order/Interval/Set/LinearOrder.lean:2,Set.Ioo_subset_Ioo_iff;Set.Ioo_subset_Ioo_iff
goal=p * i + r ≠ <num> context=case refine_2 ; p r <var> : ℕ ; <var> : prime p ; <var> : r ≠ <num> ; <var> : p ∣ r,2,contrapose!:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.factorization_eq_zero_iff_remainder;Nat.factorization_eq_zero_iff_remainder
goal=n.factorization p < n context=case neg ; n <var> : ℕ ; <var> : n ≠ <num> ; <var> : ¬prime p,2,simpa:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.factorization_lt;Nat.factorization_lt
goal=(n / p ^ n.factorization p).factorization q = (finsupp.erase p n.factorization) q context=case h.inr ; n <var> : ℕ ; <var> : ¬n = <num> ; <var> : prime p ; <var> : ℕ ; <var> : q ≠ p,2,rw:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.factorization_ordCompl;Nat.factorization_ordCompl
"goal=∀ (<var> : ℕ), (p ^ k / p ^ (p ^ k).factorization p).factorization p_1 = (factorization <num>) p_1 context=case h ; p <var> : ℕ ; <var> : prime p",2,simp:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.ordCompl_self_pow;Nat.ordCompl_self_pow
goal=n = <num> ∨ ¬p ∣ n → n / p ^ n.factorization p = n context=case mpr ; n <var> : ℕ ; <var> : prime p,2,rintro:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.ordCompl_eq_self_iff_zero_or_not_dvd;Nat.ordCompl_eq_self_iff_zero_or_not_dvd
goal=n = <num> ∨ ¬p ∣ n context=case neg ; n <var> : ℕ ; <var> : prime p ; <var> : n / p ^ n.factorization p = n ; <var> : ¬n = <num>,2,right:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.ordCompl_eq_self_iff_zero_or_not_dvd;Nat.ordCompl_eq_self_iff_zero_or_not_dvd
goal=n / p ^ n.factorization p = n context=case mpr.inr ; n <var> : ℕ ; <var> : prime p ; <var> : ¬p ∣ n,2,simp:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.ordCompl_eq_self_iff_zero_or_not_dvd;Nat.ordCompl_eq_self_iff_zero_or_not_dvd
"goal=∏ p ∈ n.primefactors, p ∣ n context=case neg ; <var> : ℕ ; <var> : ¬n = <num>",2,simpa:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.prod_primeFactors_dvd;Nat.prod_primeFactors_dvd
"goal=∀ (<var> : ℕ), e ∣ a → e ∣ b → e ∣ d context=case hd ; a <var> : ℕ ; <var> : a ≠ <num> ; <var> : b ≠ <num> ; <var> : ℕ →₀ ℕ := a.factorization ⊓ b.factorization ; <var> : ℕ := dfac.prod fun x1 x2 => x1 ^ x2 ; <var> : ∀ p ∈ dfac.support",2,intro:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.factorization_gcd;Nat.factorization_gcd
goal=(m.gcd n).primefactors.prod f * (m * n).primefactors.prod f = m.primefactors.prod f * n.primefactors.prod f context=case inr.inr ; β : type u_1 ; inst✝ : commmonoid β ; m <var> : ℕ ; <var> : ℕ → β ; hm₀ : m ≠ <num> ; hn₀ : n ≠ <num>,2,rw:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.prod_primeFactors_gcd_mul_prod_primeFactors_mul;Nat.prod_primeFactors_gcd_mul_prod_primeFactors_mul
goal=i < b context=case h.succ ; n <var> : ℕ ; <var> : n ≠ <num> ; <var> : ℕ ; <var> : <num> ≤ i ; <var> : i < n ; <var> : ℕ ; <var> : prime (p + <num>) ; <var> : n < (p + <num>) ^ b ; <var> : (p + <num>) ^ i ∣ n,2,rw:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.Ico_pow_dvd_eq_Ico_of_lt;Nat.Ico_pow_dvd_eq_Ico_of_lt
"goal=(∀ (<var> : ℕ), prime p → padicvalnat p a = padicvalnat p b) → a = b context=case mpr ; a <var> : ℕ ; <var> : a ≠ <num> ; <var> : b ≠ <num>",2,intro:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.eq_iff_prime_padicValNat_eq;Nat.eq_iff_prime_padicValNat_eq
"goal=a.factorization p = b.factorization p context=case neg ; a <var> : ℕ ; <var> : a ≠ <num> ; <var> : b ≠ <num> ; <var> : ∀ (<var> : ℕ), prime p → padicvalnat p a = padicvalnat p b ; <var> : ℕ ; <var> : ¬prime p",2,simp:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.eq_iff_prime_padicValNat_eq;Nat.eq_iff_prime_padicValNat_eq
"goal=∀ x ∈ n.factorization.support, (fun x1 x2 => x1 ^ x2) x (n.factorization x) = x ^ padicvalnat x n context=case hfg ; <var> : ℕ ; <var> : n ≠ <num> ; <var> : ℕ ; <var> : n < m",2,intro:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.prod_pow_prime_padicValNat;Nat.prod_pow_prime_padicValNat
goal=prime ↑p2 context=case refine_2 ; <var> : ℕ ; p1 <var> : ↥n.primefactors ; <var> : p1 ≠ p2,2,exact:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.pairwise_coprime_pow_primeFactors_factorization;Nat.pairwise_coprime_pow_primeFactors_factorization
goal=#(if n + <num> ≠ <num> ∧ n ∣ n + <num> then insert (n + <num>) ({k ∈ finset.range (n + <num>) | k ≠ <num> ∧ n ∣ k}) else {k ∈ finset.range (n + <num>) | k ≠ <num> ∧ n ∣ k}) = (n + <num>) / n context=case neg ; n n : ℕ ; <var> : #({k ∈ ,2,simp:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.card_multiples';Nat.card_multiples'
"goal=∃ c, a = c ^ n ∧ b = c ^ m context=case neg ; a b m <var> : ℕ ; <var> : m.coprime n ; <var> : b ^ n = a ^ m ; <var> : a = <num> ; <var> : ¬m = <num>",2,use:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.exists_eq_pow_of_exponent_coprime_of_pow_eq_pow;Nat.exists_eq_pow_of_exponent_coprime_of_pow_eq_pow
goal=m'.coprime n' context=case inr ; a b m <var> : ℕ ; <var> : a ^ m = b ^ n ; <var> : ℕ := m.gcd n ; <var> : ℕ := m / m.gcd n ; <var> : ℕ := n / m.gcd n ; <var> : n ≠ <num>,2,exact:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.exists_eq_pow_of_pow_eq_pow;Nat.exists_eq_pow_of_pow_eq_pow
goal=g ≠ <num> context=case inr ; a b m <var> : ℕ ; <var> : ℕ := m.gcd n ; <var> : ℕ := m / m.gcd n ; <var> : ℕ := n / m.gcd n ; <var> : (a ^ m') ^ g = (b ^ n') ^ g ; <var> : m'.coprime n' ; <var> : n ≠ <num>,2,exact:2,MathlibSubset/Mathlib/Data/Nat/Factorization/Basic.lean:2,Nat.exists_eq_pow_of_pow_eq_pow;Nat.exists_eq_pow_of_pow_eq_pow
goal=s ×ˢ t₁ ○ t₂ ×ˢ u = s ×ˢ u context=case neg ; α : type u_1 ; β : type u_2 ; γ : type u_3 ; <var> : set α ; t₁ t₂ : set β ; <var> : set γ ; inst✝ : decidable (disjoint t₁ t₂) ; <var> : ¬disjoint t₁ t₂,2,rw:2,MathlibSubset/Mathlib/Data/Rel.lean:2,SetRel.prod_comp_prod;SetRel.prod_comp_prod
goal=r.preimage t = r.dom context=α : type u_1 ; β : type u_2 ; r : setrel α β ; <var> : set β ; <var> : r.cod ⊆ t,2,aesop:2,MathlibSubset/Mathlib/Data/Rel.lean:2,SetRel.image_eq_cod_of_dom_subset;SetRel.preimage_eq_dom_of_cod_subset
"goal=(a, b) ∈ r → (a, b) ∈ function.graph f context=case mpr.h.mpr ; α : type u_1 ; β : type u_2 ; r : setrel α β ; <var> : ∀ (<var> : α), ∃! b, (a, b) ∈ r ; <var> : α → β ; <var> : ∀ (<var> : α), (x, f x) ∈ r ; <var> : α ; <var> : β",2,exact:2,MathlibSubset/Mathlib/Data/Rel.lean:2,SetRel.Function.SetRel.exists_graph_eq_iff;SetRel.Function.SetRel.exists_graph_eq_iff
"goal=nat.card ↑(f ⁻¹' ↑s) = ∑ b ∈ s, nat.card { a // f a = b } context=ι : type u_1 ; m : type u_2 ; <var> : ι → m ; <var> : finset m ; <var> : ∀ b ∈ s, {a | f a = b}.finite",2,classical:1;let:1,MathlibSubset/Mathlib/Algebra/BigOperators/Ring/Nat.lean:2,Finset.card_preimage_eq_sum_card_image_eq;Finset.card_preimage_eq_sum_card_image_eq
"goal=#({a ∈ ht.tofinset | f a = m}) = nat.card ↑{a | f a = m} context=case refine_2 ; ι : type u_1 ; m : type u_2 ; <var> : ι → m ; <var> : finset m ; <var> : ∀ b ∈ s, {a | f a = b}.finite ; <var> : finset m := ⋯.tofinset ; <var> : (f ⁻¹' ↑",2,rw:2,MathlibSubset/Mathlib/Algebra/BigOperators/Ring/Nat.lean:2,Finset.card_preimage_eq_sum_card_image_eq;Finset.card_preimage_eq_sum_card_image_eq
"goal=(∃ a ⊆ s, ∃ b ⊆ t, a ∪ b = u) → u ⊆ s ∪ t context=case h.refine_2 ; α : type u_2 ; inst✝ : decidableeq α ; s t <var> : finset α",2,rintro:2,MathlibSubset/Mathlib/Data/Finset/Sups.lean:2,Finset.powerset_union;Finset.powerset_union
"goal=(∃ a ⊆ s, ∃ b ⊆ t, a ∩ b = u) → u ⊆ s ∩ t context=case h.refine_2 ; α : type u_2 ; inst✝ : decidableeq α ; s t <var> : finset α",2,rintro:2,MathlibSubset/Mathlib/Data/Finset/Sups.lean:2,Finset.powerset_inter;Finset.powerset_inter
goal=a = a + <num> - <num> context=case h.e'_3 ; α : type u_2 ; inst✝ : ring α ; <var> : α ; x✝ : even (a + <num>),2,rw:2,MathlibSubset/Mathlib/Algebra/Ring/Parity.lean:2,even_add_one;even_add_two
goal=a = a - <num> + <num> context=case h.e'_3 ; α : type u_2 ; inst✝ : ring α ; <var> : α ; x✝ : even (a - <num>),2,rw:2,MathlibSubset/Mathlib/Algebra/Ring/Parity.lean:2,even_sub_one;even_sub_two
goal=¬even (<num> * n + <num>) context=<var> : ℕ,2,simp:1;grind:1,MathlibSubset/Mathlib/Algebra/Ring/Parity.lean:2,Nat.not_even_bit1;Nat.not_even_two_mul_add_one
goal=↑n = <num> ∨ ↑n = <num> context=case inr ; r : type u_4 ; inst✝ : addmonoidwithone r ; <var> : ℕ ; <var> : <num> = <num> ; <var> : odd n,2,exact:2,MathlibSubset/Mathlib/Algebra/Ring/Parity.lean:2,Nat.Function.Involutive.natCast_eq_zero_or_one_of_two_eq_zero;Nat.Function.Involutive.natCast_eq_zero_or_one_of_two_eq_zero
goal=(s ∪ t).encard = s.encard + t.encard context=α : type u_1 ; s <var> : set α ; <var> : disjoint s t,2,classical:1;unfold:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.encard_union_eq;Set.encard_union_eq
goal=s.encard ≠ ⊤ ↔ s.finite context=α : type u_1 ; <var> : set α,2,rw:1;simp:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.encard_eq_top_iff;Set.encard_ne_top_iff
"goal=s.encard ≤ <num> ↔ ∀ (a <var> : α), a ∈ s → b ∈ s → a = b context=α : type u_1 ; <var> : set α",2,rw:1;exact:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.encard_le_one_iff;Set.one_lt_encard_iff
goal=s.encard ≤ <num> ↔ s.subsingleton context=α : type u_1 ; <var> : set α,2,rw:1;exact:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.encard_le_one_iff_subsingleton;Set.one_lt_encard_iff_nontrivial
goal=<num> = <num> + <num> context=α : type u_1 ; <var> : set α ; <var> : α ; <var> : (s \ {x}).encard + <num> = <num> ; <var> : x ∈ s,2,exact:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.encard_eq_three;Set.encard_eq_four
"goal=∃ f, s ⊆ f ⁻¹' t ∧ injon f s context=α : type u_1 ; β : type u_2 ; inst✝ : nonempty β ; <var> : set α ; <var> : set β ; <var> : s.finite ; <var> : s.encard ≤ t.encard",2,classical:1;obtain:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.Finite.exists_injOn_of_encard_le;Set.Finite.exists_injOn_of_encard_le
goal=f₀ x ∈ t context=case neg ; α : type u_1 ; β : type u_2 ; inst✝ : nonempty β ; <var> : set α ; <var> : set β ; <var> : s.finite ; <var> : s.encard ≤ t.encard ; <var> : α ; <var> : a ∈ s ; <var> : β ; <var> : b ∈ t ; <var> : (s \ {a}).e,2,exact:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.Finite.exists_injOn_of_encard_le;Set.Finite.exists_injOn_of_encard_le
goal={a}.ncard = <num> context=α : type u_1 ; <var> : α,2,simp:1;rw:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.ncard_singleton;Set.ncard_eq_one
goal=(insert a s).ncard = if a ∈ s then s.ncard else s.ncard + <num> context=case neg ; α : type u_1 ; <var> : set α ; <var> : α ; inst✝ : decidable (a ∈ s) ; <var> : s.finite ; <var> : a ∉ s,2,rw:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.ncard_insert_eq_ite;Set.ncard_insert_eq_ite
goal=s.ncard ≤ (insert a s).ncard context=α : type u_1 ; <var> : α ; <var> : set α,2,classical:1;refine:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.ncard_le_ncard_insert;Set.ncard_le_ncard_insert
goal=s.ncard ≤ (insert a s).ncard context=α : type u_1 ; <var> : α ; <var> : set α ; <var> : s.infinite,2,(rw:1;rw:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.ncard_le_ncard_insert;Set.ncard_le_ncard_insert
goal=(s \ {a}).ncard = s.ncard - <num> context=case inr ; α : type u_1 ; <var> : set α ; <var> : α ; <var> : a ∈ s ; <var> : s.finite,2,exact:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.ncard_diff_singleton_of_mem;Set.ncard_diff_singleton_of_mem
"goal=a₁ = a₂ context=α : type u_1 ; β : type u_2 ; <var> : set α ; <var> : set β ; <var> : (<var> : α) → a ∈ s → β ; <var> : ∀ (<var> : α) (<var> : a ∈ s), f a ha ∈ t ; <var> : ∀ b ∈ t, ∃ a, ∃ (<var> : a ∈ s), f a ha = b ; <var> : s.ncard ≤",2,classical:1;set:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.inj_on_of_surj_on_of_ncard_le;Set.inj_on_of_surj_on_of_ncard_le
goal=(t \ s).ncard = t.ncard - s.ncard context=case inr ; α : type u_1 ; s <var> : set α ; <var> : s ⊆ t ; <var> : s.finite ; <var> : t.infinite,2,rw:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.ncard_diff;Set.ncard_diff
goal=s ∪ t ≠ univ context=α : type u_1 ; s <var> : set α ; <var> : s.ncard + t.ncard < nat.card α,2,contrapose!:1;exact:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.union_ne_univ_of_ncard_add_ncard_lt;Set.nonempty_inter_compl_of_ncard_add_ncard_lt
"goal=∃ r, n < r.ncard ∧ (r ⊆ s ∨ r ⊆ t) context=α : type u_1 ; s <var> : set α ; <var> : ℕ ; <var> : <num> * n < (s ∪ t).ncard",2,classical:1;have:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.exists_subset_or_subset_of_two_mul_lt_ncard;Set.exists_subset_or_subset_of_two_mul_lt_ncard
"goal=(∃ a ∉ s, insert a s = t) ↔ s ⊆ t ∧ s.ncard + <num> = t.ncard context=α : type u_1 ; s <var> : set α ; <var> : s.finite",2,classical:1;rcases:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.exists_eq_insert_iff_ncard;Set.exists_eq_insert_iff_ncard
goal=<num> < s.ncard context=case refine_2 ; α : type u_1 ; <var> : set α ; x✝ : s.nontrivial ∧ s.finite ; <var> : s.nontrivial ; <var> : s.finite,2,rw:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.one_lt_ncard_iff_nontrivial_and_finite;Set.one_lt_ncard_iff_nontrivial_and_finite
"goal=∃ a t, a ∉ t ∧ insert a t = s ∧ t.ncard = n context=α : type u_1 ; <var> : set α ; <var> : ℕ ; <var> : s.ncard = n + <num>",2,classical:1;have:1,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.eq_insert_of_ncard_eq_succ;Set.eq_insert_of_ncard_eq_succ
goal=(↑t).ncard = t.card context=case refine_2 ; α : type u_1 ; <var> : set α ; <var> : s.finite := finite_of_ncard_pos (lt.lt.trans_eq (nat.zero_lt_succ _fvar.<num>) (eq.symm _fvar.<num>)) ; <var> : α ; <var> : finset α ; <var> : a ∉ t ; <,2,simp:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.eq_insert_of_ncard_eq_succ;Set.eq_insert_of_ncard_eq_succ
"goal=(set.range g)ᶜ.ncard ≤ <num> context=case inr.refine_2 ; α : type u_1 ; β : type u_2 ; inst✝ : finite α ; <var> : α → β ; hf✝ : surjective f ; h✝ : nonempty α ; <var> : β → α := surjinv hf✝ ; <var> : ∀ (<var> : β), f (g b) = <var> := s",2,rw:2,MathlibSubset/Mathlib/Data/Set/Card.lean:2,Set.Function.Surjective.card_le_card_add_one_iff;Set.Function.Surjective.card_le_card_add_one_iff
goal=toicomod hp a b = toicomod hp a c context=case refine_2 ; α : type u_1 ; inst✝² : addcommgroup α ; inst✝¹ : linearorder α ; inst✝ : isorderedaddmonoid α ; hα : archimedean α ; <var> : α ; <var> : <num> < p ; a b <var> : α ; <var> : ∃ n,2,rcases:2,MathlibSubset/Mathlib/Algebra/Order/ToIntervalMod.lean:2,toIcoMod_eq_toIcoMod;toIcoMod_eq_toIcoMod
goal=toiocmod hp a b = toiocmod hp a c context=case refine_2 ; α : type u_1 ; inst✝² : addcommgroup α ; inst✝¹ : linearorder α ; inst✝ : isorderedaddmonoid α ; hα : archimedean α ; <var> : α ; <var> : <num> < p ; a b <var> : α ; <var> : ∃ n,2,rcases:2,MathlibSubset/Mathlib/Algebra/Order/ToIntervalMod.lean:2,toIocMod_eq_toIocMod;toIocMod_eq_toIocMod
goal=b = a + (toiocdiv hp a b + <num>) • p context=case refine_2 ; α : type u_1 ; inst✝² : addcommgroup α ; inst✝¹ : linearorder α ; inst✝ : isorderedaddmonoid α ; hα : archimedean α ; <var> : α ; <var> : <num> < p ; a <var> : α ; <var> : t,2,rwa:2,MathlibSubset/Mathlib/Algebra/Order/ToIntervalMod.lean:2,AddCommGroup.modEq_iff_toIocMod_eq_right;AddCommGroup.modEq_iff_toIocMod_eq_right
"goal=∃ z, b = b + z • p context=α : type u_1 ; inst✝² : addcommgroup α ; inst✝¹ : linearorder α ; inst✝ : isorderedaddmonoid α ; hα : archimedean α ; <var> : α ; <var> : <num> < p ; a <var> : α",2,exact:2,MathlibSubset/Mathlib/Algebra/Order/ToIntervalMod.lean:2,AddCommGroup.toIcoMod_eq_self;AddCommGroup.toIocMod_eq_self
goal=b = b + <num> • p context=α : type u_1 ; inst✝² : addcommgroup α ; inst✝¹ : linearorder α ; inst✝ : isorderedaddmonoid α ; hα : archimedean α ; <var> : α ; <var> : <num> < p ; a <var> : α,2,simp:2,MathlibSubset/Mathlib/Algebra/Order/ToIntervalMod.lean:2,AddCommGroup.toIcoMod_eq_self;AddCommGroup.toIocMod_eq_self
goal=¬toicomod hp x₃ x₄ ≤ toiocmod hp x₃ x₁ context=case right ; α : type u_1 ; inst✝² : addcommgroup α ; inst✝¹ : linearorder α ; inst✝ : isorderedaddmonoid α ; hα : archimedean α ; <var> : α ; <var> : <num> < p ; x₁ x₂ x₃ x₄ : α ; h₁₂₃ : ,2,rw:2,MathlibSubset/Mathlib/Algebra/Order/ToIntervalMod.lean:2,AddCommGroup.toIxxMod_trans;AddCommGroup.toIxxMod_trans
goal=a * b ≤ a * c context=case inr ; α : type u_1 ; inst✝¹ : mulzeroclass α ; inst✝ : partialorder α ; <var> : covariantclass α><num> α (fun x y => ↑x * y) fun x1 x2 => x1 ≤ x2 ; <var> : α ; ha✝ : <num> ≤ a ; b <var> : α ; <var> : b ≤ c ; ,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,posMulMono_iff_covariant_pos;posMulMono_iff_covariant_pos
goal=b * a ≤ c * a context=case inr ; α : type u_1 ; inst✝¹ : mulzeroclass α ; inst✝ : partialorder α ; <var> : covariantclass α><num> α (fun x y => y * ↑x) fun x1 x2 => x1 ≤ x2 ; <var> : α ; ha✝ : <num> ≤ a ; b <var> : α ; <var> : b ≤ c ; ,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,mulPosMono_iff_covariant_pos;mulPosMono_iff_covariant_pos
goal=b < c context=case inr ; α : type u_1 ; inst✝¹ : mulzeroclass α ; inst✝ : partialorder α ; h✝ : contravariantclass α><num> α (fun x y => ↑x * y) fun x1 x2 => x1 < x2 ; <var> : { x // <num> ≤ x } ; b <var> : α ; <var> : (fun x1 x2 => x1,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,posMulReflectLT_iff_contravariant_pos;posMulReflectLT_iff_contravariant_pos
goal=b < c context=case inr ; α : type u_1 ; inst✝¹ : mulzeroclass α ; inst✝ : partialorder α ; h✝ : contravariantclass α><num> α (fun x y => y * ↑x) fun x1 x2 => x1 < x2 ; <var> : { x // <num> ≤ x } ; b <var> : α ; <var> : (fun x1 x2 => x1,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,mulPosReflectLT_iff_contravariant_pos;mulPosReflectLT_iff_contravariant_pos
goal=a * c < b * d context=case refine_2 ; α : type u_1 ; inst✝³ : mulzeroclass α ; a b c <var> : α ; inst✝² : partialorder α ; inst✝¹ : posmulstrictmono α ; inst✝ : mulposstrictmono α ; <var> : a ≤ b ; hcd✝ : c ≤ d ; <var> : <num> < a ; <v,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,mul_eq_mul_iff_eq_and_eq_of_pos;mul_eq_mul_iff_eq_and_eq_of_pos
goal=a * c < b * d context=case refine_2 ; α : type u_1 ; inst✝³ : mulzeroclass α ; a b c <var> : α ; inst✝² : partialorder α ; inst✝¹ : posmulstrictmono α ; inst✝ : mulposstrictmono α ; <var> : a ≤ b ; hcd✝ : c ≤ d ; <var> : <num> < b ; <v,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,mul_eq_mul_iff_eq_and_eq_of_pos';mul_eq_mul_iff_eq_and_eq_of_pos'
goal=<num> < a ∧ <num> < b ∨ a < <num> ∧ b < <num> context=case inr.inr ; α : type u_1 ; inst✝³ : mulzeroclass α ; a <var> : α ; inst✝² : linearorder α ; inst✝¹ : posmulmono α ; inst✝ : mulposmono α ; <var> : <num> < a * b ; <var> : <num> <,2,refine:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,pos_and_pos_or_neg_and_neg_of_mul_pos;pos_and_pos_or_neg_and_neg_of_mul_pos
goal=a ^ n ≤ a ^ m context=case inr ; m₀ : type u_2 ; inst✝³ : monoidwithzero m₀ ; inst✝² : preorder m₀ ; <var> : m₀ ; m <var> : ℕ ; inst✝¹ : zeroleoneclass m₀ ; inst✝ : posmulmono m₀ ; <var> : <num> ≤ a ; <var> : a ≤ <num> ; <var> : m ≤ n,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Bound.pow_le_pow_right_of_le_one_or_one_le;Bound.pow_le_pow_right_of_le_one_or_one_le
goal=a ^ <num> ≤ b ^ <num> context=m₀ : type u_2 ; inst✝³ : monoidwithzero m₀ ; inst✝² : preorder m₀ ; a <var> : m₀ ; inst✝¹ : posmulmono m₀ ; inst✝ : mulposmono m₀ ; <var> : <num> ≤ a ; <var> : a ≤ b,2,simp:1;simpa:1,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,pow_le_pow_left₀;pow_le_pow_left₀
goal=injective fun x => a ^ x context=case inr ; m₀ : type u_2 ; inst✝³ : monoidwithzero m₀ ; inst✝² : linearorder m₀ ; inst✝¹ : posmulstrictmono m₀ ; <var> : m₀ ; inst✝ : zeroleoneclass m₀ ; ha₀ : <num> < a ; ha₁✝ : a ≠ <num> ; ha₁ : <num>,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,pow_right_injective₀;pow_right_injective₀
goal=a * c / (b * c) ≤ a / b context=case inr ; g₀ : type u_3 ; inst✝¹ : groupwithzero g₀ ; inst✝ : preorder g₀ ; a b <var> : g₀ ; <var> : <num> ≤ a / b ; <var> : c ≠ <num>,2,rw:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,mul_div_mul_right_le;mul_div_mul_right_le
goal=a / b ≤ a * c / (b * c) context=case inr ; g₀ : type u_3 ; inst✝¹ : groupwithzero g₀ ; inst✝ : preorder g₀ ; a b <var> : g₀ ; <var> : a / b ≤ <num> ; <var> : c ≠ <num>,2,rw:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,le_mul_div_mul_right;le_mul_div_mul_right
goal=c * a ≤ b context=case inr ; g₀ : type u_3 ; inst✝² : groupwithzero g₀ ; inst✝¹ : partialorder g₀ ; inst✝ : posmulreflectlt g₀ ; a b <var> : g₀ ; <var> : <num> ≤ b ; hc✝ : <num> ≤ c ; <var> : a ≤ c⁻¹ * b ; <var> : <num> < c,2,rwa:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,mul_le_of_le_inv_mul₀;mul_le_of_le_inv_mul₀
goal=b⁻¹ * a ≤ c context=case inr ; g₀ : type u_3 ; inst✝² : groupwithzero g₀ ; inst✝¹ : partialorder g₀ ; inst✝ : posmulreflectlt g₀ ; a b <var> : g₀ ; hb✝ : <num> ≤ b ; <var> : <num> ≤ c ; <var> : a ≤ b * c ; <var> : <num> < b,2,rwa:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,inv_mul_le_of_le_mul₀;inv_mul_le_of_le_mul₀
goal=a * c ≤ b context=case inr ; g₀ : type u_3 ; inst✝² : groupwithzero g₀ ; inst✝¹ : partialorder g₀ ; inst✝ : mulposreflectlt g₀ ; a b <var> : g₀ ; <var> : <num> ≤ b ; hc✝ : <num> ≤ c ; <var> : a ≤ b * c⁻¹ ; <var> : <num> < c,2,rwa:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Right.mul_le_of_le_mul_inv₀;Right.mul_le_of_le_mul_inv₀
goal=a * b⁻¹ ≤ c context=case inr ; g₀ : type u_3 ; inst✝² : groupwithzero g₀ ; inst✝¹ : partialorder g₀ ; inst✝ : mulposreflectlt g₀ ; a b <var> : g₀ ; hb✝ : <num> ≤ b ; <var> : <num> ≤ c ; <var> : a ≤ c * b ; <var> : <num> < b,2,rwa:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Right.mul_inv_le_of_le_mul₀;Right.mul_inv_le_of_le_mul₀
goal=a ≤ <num> * b context=g₀ : type u_3 ; inst✝³ : groupwithzero g₀ ; inst✝² : partialorder g₀ ; inst✝¹ : mulposreflectlt g₀ ; a <var> : g₀ ; inst✝ : zeroleoneclass g₀ ; <var> : a ≤ b ; <var> : <num> ≤ b,2,rwa:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Right.mul_inv_le_one_of_le₀;Right.div_le_one_of_le₀
goal=injective fun n => a ^ n context=case inr ; g₀ : type u_3 ; inst✝³ : groupwithzero g₀ ; inst✝² : linearorder g₀ ; <var> : g₀ ; inst✝¹ : posmulstrictmono g₀ ; inst✝ : zeroleoneclass g₀ ; ha₀ : <num> < a ; ha₁✝ : a ≠ <num> ; ha₁ : <num> ,2,exact:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Right.zpow_right_injective₀;Right.zpow_right_injective₀
goal=c * a / (c * b) ≤ a / b context=case inr ; g₀ : type u_3 ; inst✝¹ : commgroupwithzero g₀ ; inst✝ : preorder g₀ ; a b <var> : g₀ ; <var> : <num> ≤ a / b ; <var> : c ≠ <num>,2,rw:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Right.mul_div_mul_left_le;Right.mul_div_mul_left_le
goal=a / b ≤ c * a / (c * b) context=case inr ; g₀ : type u_3 ; inst✝¹ : commgroupwithzero g₀ ; inst✝ : preorder g₀ ; a b <var> : g₀ ; <var> : a / b ≤ <num> ; <var> : c ≠ <num>,2,rw:2,MathlibSubset/Mathlib/Algebra/Order/GroupWithZero/Unbundled/Basic.lean:2,Right.le_mul_div_mul_left;Right.le_mul_div_mul_left
"goal=∃ b, f = const α b context=case inr ; α : type u_1 ; β : type u_2 ; inst✝ : nonempty β ; <var> : α → β ; <var> : ∀ (<var> : β), f ⁻¹' {b} = ∅ ∨ f ⁻¹' {b} = univ ; <var> : ¬∃ b, f ⁻¹' {b} = univ",2,have:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.exists_eq_const_of_preimage_singleton;Set.exists_eq_const_of_preimage_singleton
"goal=⟨x, x_in_s⟩ ∈ (subtype.val ⁻¹' v)ᶜ → ⟨x, x_in_s⟩ ∈ subtype.val ⁻¹' u context=case h.mpr ; α : type u_1 ; s u <var> : set α ; <var> : s ⊆ u ∪ v ; h : s ∩ (u ∩ v) = ∅ ; <var> : α ; <var> : x ∈ s",2,grind:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.preimage_subtype_coe_eq_compl;Set.preimage_subtype_coe_eq_compl
goal=i ∈ ⇑σ '' s ↔ i ∈ s context=case h.inr ; α : type u_1 ; <var> : set α ; σ : equiv.perm α ; <var> : {a | σ a ≠ a} ⊆ s ; <var> : α ; <var> : σ i ≠ i,2,refine:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.image_perm;Set.image_perm
goal=t ∈ 𝒫 s ∪ insert a '' 𝒫 s → t ∈ 𝒫 insert a s context=case h.mpr ; α : type u_1 ; <var> : set α ; <var> : α ; <var> : set α,2,grind:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.powerset_insert;Set.powerset_insert
goal=t ∈ 𝒫 s ∪ insert a '' 𝒫 s context=case neg ; α : type u_1 ; <var> : set α ; <var> : α ; <var> : set α ; <var> : t ∈ 𝒫 insert a s ; <var> : ¬a ∈ t,2,grind:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.powerset_insert;Set.powerset_insert
goal=t ⊆ s context=case mp.h₂ ; α : type u_1 ; β : type u_2 ; s <var> : set α ; <var> : β → α ; <var> : s ⊆ range f ; <var> : t ⊆ range f ; <var> : f ⁻¹' s = f ⁻¹' t,2,rw:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.preimage_eq_preimage';Set.preimage_eq_preimage'
goal=(x✝ ∈ range fun x => f ↑x) → x✝ ∈ f '' s context=case h.mpr ; α : type u_1 ; β : type u_2 ; <var> : α → β ; <var> : set α ; x✝ : β,2,rintro:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.image_eq_range;Set.image_eq_range
goal=s ∩ t ⊆ s ∩ u → val ⁻¹' t ⊆ val ⁻¹' u context=case mpr ; α : type u_1 ; s t <var> : set α,2,intro:2,MathlibSubset/Mathlib/Data/Set/Image.lean:2,Set.Function.EquivLike.Subtype.preimage_val_subset_preimage_val_iff;Set.Function.EquivLike.Subtype.preimage_val_subset_preimage_val_iff
