Mctt.Core.Soundness.SubtypingCases
From Mctt Require Import LibTactics.
From Mctt.Core Require Import Base.
From Mctt.Core.Completeness Require Import FundamentalTheorem.
From Mctt.Core.Semantic Require Import Realizability.
From Mctt.Core.Soundness Require Import LogicalRelation.
Import Domain_Notations.
Lemma glu_rel_exp_subtyp : forall {Γ M A A' i},
{{ Γ ⊩ M : A }} ->
{{ Γ ⊩ A' : Type@i }} ->
{{ Γ ⊢ A ⊆ A' }} ->
{{ Γ ⊩ M : A' }}.
Proof.
intros * [] HA' [env_relΓ [? [k]]]%completeness_fundamental_subtyp.
destruct_conjs.
invert_glu_rel_exp HA'.
econstructor; split; [eassumption |].
exists (max i k); intros.
destruct_glu_rel_exp_with_sub.
simplify_evals.
match_by_head glu_univ_elem ltac:(fun H => directed invert_glu_univ_elem H).
handle_functional_glu_univ_elem.
assert {{ Dom ρ ≈ ρ ∈ env_relΓ }} by (eapply glu_ctx_env_per_env; mauto).
(on_all_hyp: destruct_rel_by_assumption env_relΓ).
destruct_by_head rel_typ.
destruct_by_head rel_exp.
handle_per_univ_elem_irrel.
unfold univ_glu_exp_pred' in *.
destruct_conjs.
eapply mk_glu_rel_exp_with_sub''; intuition mauto using per_univ_elem_cumu_max_left, per_univ_elem_cumu_max_right.
eapply glu_univ_elem_per_subtyp_trm_conv; mauto.
assert (i <= max i k) by lia.
eapply glu_univ_elem_typ_cumu_ge; revgoals; mauto.
Qed.
#[export]
Hint Resolve glu_rel_exp_subtyp : mctt.
Lemma glu_rel_sub_subtyp : forall {Γ σ Δ Δ'},
{{ Γ ⊩s σ : Δ }} ->
{{ ⊩ Δ' }} ->
{{ ⊢ Δ ⊆ Δ' }} ->
{{ Γ ⊩s σ : Δ' }}.
Proof.
intros * [] [] Hsubtyp.
destruct_conjs.
econstructor; eexists; repeat split; [eassumption | eassumption |].
intros.
destruct_glu_rel_sub_with_sub.
econstructor; mauto.
eapply glu_ctx_env_subtyp_sub_if; mauto.
Qed.
#[export]
Hint Resolve glu_rel_sub_subtyp : mctt.
Lemma glu_rel_exp_conv : forall {Γ M A A' i},
{{ Γ ⊩ M : A }} ->
{{ Γ ⊩ A' : Type@i }} ->
{{ Γ ⊢ A ≈ A' : Type@i }} ->
{{ Γ ⊩ M : A' }}.
Proof.
mauto 3.
Qed.
#[export]
Hint Resolve glu_rel_exp_conv : mctt.
Lemma glu_rel_sub_conv : forall {Γ σ Δ Δ'},
{{ Γ ⊩s σ : Δ }} ->
{{ ⊩ Δ' }} ->
{{ ⊢ Δ ≈ Δ' }} ->
{{ Γ ⊩s σ : Δ' }}.
Proof.
mauto 3.
Qed.
#[export]
Hint Resolve glu_rel_sub_conv : mctt.
From Mctt.Core Require Import Base.
From Mctt.Core.Completeness Require Import FundamentalTheorem.
From Mctt.Core.Semantic Require Import Realizability.
From Mctt.Core.Soundness Require Import LogicalRelation.
Import Domain_Notations.
Lemma glu_rel_exp_subtyp : forall {Γ M A A' i},
{{ Γ ⊩ M : A }} ->
{{ Γ ⊩ A' : Type@i }} ->
{{ Γ ⊢ A ⊆ A' }} ->
{{ Γ ⊩ M : A' }}.
Proof.
intros * [] HA' [env_relΓ [? [k]]]%completeness_fundamental_subtyp.
destruct_conjs.
invert_glu_rel_exp HA'.
econstructor; split; [eassumption |].
exists (max i k); intros.
destruct_glu_rel_exp_with_sub.
simplify_evals.
match_by_head glu_univ_elem ltac:(fun H => directed invert_glu_univ_elem H).
handle_functional_glu_univ_elem.
assert {{ Dom ρ ≈ ρ ∈ env_relΓ }} by (eapply glu_ctx_env_per_env; mauto).
(on_all_hyp: destruct_rel_by_assumption env_relΓ).
destruct_by_head rel_typ.
destruct_by_head rel_exp.
handle_per_univ_elem_irrel.
unfold univ_glu_exp_pred' in *.
destruct_conjs.
eapply mk_glu_rel_exp_with_sub''; intuition mauto using per_univ_elem_cumu_max_left, per_univ_elem_cumu_max_right.
eapply glu_univ_elem_per_subtyp_trm_conv; mauto.
assert (i <= max i k) by lia.
eapply glu_univ_elem_typ_cumu_ge; revgoals; mauto.
Qed.
#[export]
Hint Resolve glu_rel_exp_subtyp : mctt.
Lemma glu_rel_sub_subtyp : forall {Γ σ Δ Δ'},
{{ Γ ⊩s σ : Δ }} ->
{{ ⊩ Δ' }} ->
{{ ⊢ Δ ⊆ Δ' }} ->
{{ Γ ⊩s σ : Δ' }}.
Proof.
intros * [] [] Hsubtyp.
destruct_conjs.
econstructor; eexists; repeat split; [eassumption | eassumption |].
intros.
destruct_glu_rel_sub_with_sub.
econstructor; mauto.
eapply glu_ctx_env_subtyp_sub_if; mauto.
Qed.
#[export]
Hint Resolve glu_rel_sub_subtyp : mctt.
Lemma glu_rel_exp_conv : forall {Γ M A A' i},
{{ Γ ⊩ M : A }} ->
{{ Γ ⊩ A' : Type@i }} ->
{{ Γ ⊢ A ≈ A' : Type@i }} ->
{{ Γ ⊩ M : A' }}.
Proof.
mauto 3.
Qed.
#[export]
Hint Resolve glu_rel_exp_conv : mctt.
Lemma glu_rel_sub_conv : forall {Γ σ Δ Δ'},
{{ Γ ⊩s σ : Δ }} ->
{{ ⊩ Δ' }} ->
{{ ⊢ Δ ≈ Δ' }} ->
{{ Γ ⊩s σ : Δ' }}.
Proof.
mauto 3.
Qed.
#[export]
Hint Resolve glu_rel_sub_conv : mctt.