lift tactic #
This file defines the lift tactic, allowing the user to lift elements from one type to another
under a specified condition.
Tags #
lift, tactic
@[class]
structure
can_lift
(α : Sort u_1)
(β : Sort u_2)
(coe : out_param (β → α))
(cond : out_param (α → Prop)) :
A class specifying that you can lift elements from α to β assuming cond is true.
Used by the tactic lift.
Instances of this typeclass
- has_le.le.can_lift
- pi.can_lift
- pi_subtype.can_lift
- pi_subtype.can_lift'
- subtype.can_lift
- is_unit.can_lift
- is_add_unit.can_lift
- equiv.function.bijective.can_lift
- with_bot.can_lift
- with_top.can_lift
- set.pi_set_coe.can_lift
- set.pi_set_coe.can_lift'
- set.can_lift
- function.injective.can_lift
- order_hom.monotone.can_lift
- with_one.can_lift
- with_zero.can_lift
- nat.can_lift_pnat
- int.can_lift_pnat
- rat.can_lift
- list.can_lift
- multiset.can_lift
- multiset.can_lift_finset
- finset.pi_finset_coe.can_lift
- finset.pi_finset_coe.can_lift'
- finset.finset_coe.can_lift
- finset.can_lift
- set.finite.can_lift
- finsupp.can_lift
- enat.can_lift
- part_enat.part.dom.can_lift
- cardinal.can_lift_cardinal_Type
- cardinal.can_lift_cardinal_nat
- filter.can_lift
- nnreal.can_lift
- ennreal.can_lift
- nnreal.continuous_map.can_lift
- complex.can_lift
- topological_space.opens.is_open.can_lift
- topological_space.open_nhds_of.can_lift_set
- topological_space.compacts.is_compact.can_lift
- linear_map.can_lift_continuous_linear_map
- linear_equiv.can_lift_continuous_linear_equiv
- quadratic_form.can_lift
Instances of other typeclasses for can_lift
- can_lift.has_sizeof_inst
@[protected, instance]
Equations
- pi_subtype.can_lift' ι α p = pi_subtype.can_lift ι (λ (_x : ι), α) p
@[protected, instance]
Equations
- subtype.can_lift p = {prf := _}
Lift an expression to another type.
- Usage:
'lift' expr 'to' expr ('using' expr)? ('with' id (id id?)?)?. - If
n : ℤandhn : n ≥ 0then the tacticlift n to ℕ using hncreates a new constant of typeℕ, also namednand replaces all occurrences of the old variable(n : ℤ)with↑n(wherenin the new variable). It will removenandhnfrom the context.- So for example the tactic
lift n to ℕ using hntransforms the goaln : ℤ, hn : n ≥ 0, h : P n ⊢ n = 3ton : ℕ, h : P ↑n ⊢ ↑n = 3(herePis some term of typeℤ → Prop).
- So for example the tactic
- The argument
using hnis optional, the tacticlift n to ℕdoes the same, but also creates a new subgoal thatn ≥ 0(wherenis the old variable). This subgoal will be placed at the top of the goal list.- So for example the tactic
lift n to ℕtransforms the goaln : ℤ, h : P n ⊢ n = 3to two goalsn : ℤ, h : P n ⊢ n ≥ 0andn : ℕ, h : P ↑n ⊢ ↑n = 3.
- So for example the tactic
- You can also use
lift n to ℕ using ewhereeis any expression of typen ≥ 0. - Use
lift n to ℕ with kto specify the name of the new variable. - Use
lift n to ℕ with k hkto also specify the name of the equality↑k = n. In this case,nwill remain in the context. You can userflfor the name ofhkto substitutenaway (i.e. the default behavior). - You can also use
lift e to ℕ with k hkwhereeis any expression of typeℤ. In this case, thehkwill always stay in the context, but it will be used to rewriteein all hypotheses and the target.- So for example the tactic
lift n + 3 to ℕ using hn with k hktransforms the goaln : ℤ, hn : n + 3 ≥ 0, h : P (n + 3) ⊢ n + 3 = 2 * nto the goaln : ℤ, k : ℕ, hk : ↑k = n + 3, h : P ↑k ⊢ ↑k = 2 * n.
- So for example the tactic
- The tactic
lift n to ℕ using hwill removehfrom the context. If you want to keep it, specify it again as the third argument towith, like this:lift n to ℕ using h with n rfl h. - More generally, this can lift an expression from
αtoβassuming that there is an instance ofcan_lift α β. In this case the proof obligation is specified bycan_lift.cond. - Given an instance
can_lift β γ, it can also liftα → βtoα → γ; more generally, givenβ : Π a : α, Type*,γ : Π a : α, Type*, and[Π a : α, can_lift (β a) (γ a)], it automatically generates an instancecan_lift (Π a, β a) (Π a, γ a).
lift is in some sense dual to the zify tactic. lift (z : ℤ) to ℕ will change the type of an
integer z (in the supertype) to ℕ (the subtype), given a proof that z ≥ 0;
propositions concerning z will still be over ℤ. zify changes propositions about ℕ (the
subtype) to propositions about ℤ (the supertype), without changing the type of any variable.