Ликвидационная абстракция над подтемой типа цели
В качестве грубого и неопознанного фона, в HoTT, выводится вывод из индуктивно определенного типа
Inductive paths {X : Type } : X -> X -> Type :=
| idpath : forall x: X, paths x x.
что позволяет сделать очень общую конструкцию
Lemma transport {X : Type } (P : X -> Type ){ x y : X} (γ : paths x y):
P x -> P y.
Proof.
induction γ.
exact (fun a => a).
Defined.
Lemma transport
станет основой тактики HoTT "replace" или "rewrite"; трюк, насколько я понимаю, был бы, полагая, что цель, которую вы или я можем абстрактно признать как
...
H : paths x y
[ Q : (G x) ]
_____________
(G y)
чтобы выяснить, что является необходимым зависимым типом G, чтобы мы могли apply (transport G H)
. До сих пор все, что я выяснил, это то, что
Ltac transport_along γ :=
match (type of γ) with
| ?a ~~> ?b =>
match goal with
|- ?F b => apply (transport F γ)
| _ => idtac "apparently couldn't abstract" b "from the goal." end
| _ => idtac "Are you sure" γ "is a path?" end.
недостаточно общего. То есть, первый idtac
используется довольно часто.
Вопрос:
[Есть ли | что такое] Правильное дело?
Ответы
Ответ 1
Существует bug об использовании rewrite для отношений в типе, что позволит вам просто сказать rewrite <- y.
В среднем время
Ltac transport_along γ :=
match (type of γ) with
| ?a ~~> ?b => pattern b; apply (transport _ y)
| _ => idtac "Are you sure" γ "is a path?"
end.
вероятно, делает то, что вы хотите.
Ответ 2
Запрос функции, упомянутый Томом Принсом в его ответе, был предоставлен:
Require Import Coq.Setoids.Setoid Coq.Classes.CMorphisms.
Inductive paths {X : Type } : X -> X -> Type :=
| idpath : forall x: X, paths x x.
Lemma transport {X : Type } (P : X -> Type ){ x y : X} (γ : paths x y):
P x -> P y.
Proof.
induction γ.
exact (fun a => a).
Defined.
Global Instance paths_Reflexive {A} : Reflexive (@paths A) := idpath.
Global Instance paths_Symmetric {A} : Symmetric (@paths A).
Proof. intros ?? []; constructor. Defined.
Global Instance proper_paths {A} (x : A) : Proper paths x := idpath x.
Global Instance paths_subrelation
(A : Type) (R : crelation A)
{RR : Reflexive R}
: subrelation paths R.
Proof.
intros ?? p.
apply (transport _ p), RR.
Defined.
Global Instance reflexive_paths_dom_reflexive
{B} {R' : crelation B} {RR' : Reflexive R'}
{A : Type}
: Reflexive (@paths A ==> R')%signature.
Proof. intros ??? []; apply RR'. Defined.
Goal forall (x y : nat) G, paths x y -> G x -> G y.
intros x y G H Q.
rewrite <- H.
exact Q.
Qed.
Я нашел необходимые экземпляры, сравнив журналы, которые я получил с Set Typeclasses Debug
, из setoid_rewrite <- H
, когда H : paths x y
и когда H : eq x y
.