solution for exercise 07

amethyst
mueck 11 months ago
parent cd222f11c5
commit 1594ef0bd2
No known key found for this signature in database

@ -69,10 +69,12 @@ theories/type_systems/systemf_mu_state/locations.v
theories/type_systems/systemf_mu_state/lang.v
theories/type_systems/systemf_mu_state/notation.v
theories/type_systems/systemf_mu_state/types.v
theories/type_systems/systemf_mu_state/types_sol.v
theories/type_systems/systemf_mu_state/tactics.v
theories/type_systems/systemf_mu_state/execution.v
theories/type_systems/systemf_mu_state/parallel_subst.v
theories/type_systems/systemf_mu_state/logrel.v
theories/type_systems/systemf_mu_state/logrel_sol.v
# By removing the # below, you can add the exercise sheets to make
#theories/type_systems/warmup/warmup.v
@ -92,3 +94,4 @@ theories/type_systems/systemf_mu_state/logrel.v
#theories/type_systems/systemf_mu/exercises06.v
#theories/type_systems/systemf_mu/exercises06_sol.v
#theories/type_systems/systemf_mu_state/exercises07.v
#theories/type_systems/systemf_mu_state/exercises07_sol.v

@ -0,0 +1,202 @@
From iris Require Import prelude.
From semantics.ts.systemf_mu_state Require Import lang notation parallel_subst tactics execution.
(** * Exercise Sheet 7 *)
(** Exercise 1: Stack (LN Exercise 45) *)
(* We use lists to model our stack *)
Section lists.
Context (A : type).
Definition list_type : type :=
μ: Unit + (A.[ren (+1)] × #0).
Definition nil_val : val :=
RollV (InjLV (LitV LitUnit)).
Definition cons_val (v : val) (xs : val) : val :=
RollV (InjRV (v, xs)).
Definition cons_expr (v : expr) (xs : expr) : expr :=
roll (InjR (v, xs)).
Definition list_case : val :=
Λ, λ: "l" "n" "hf", match: unroll "l" with InjL <> => "n" | InjR "h" => "hf" (Fst "h") (Snd "h") end.
Lemma nil_val_typed Σ n Γ :
type_wf n A
TY Σ; n; Γ nil_val : list_type.
Proof.
intros. solve_typing.
Qed.
Lemma cons_val_typed Σ n Γ (v xs : val) :
type_wf n A
TY Σ; n; Γ v : A
TY Σ; n; Γ xs : list_type
TY Σ; n; Γ cons_val v xs : list_type.
Proof.
intros. simpl. solve_typing.
Qed.
Lemma cons_expr_typed Σ n Γ (x xs : expr) :
type_wf n A
TY Σ; n; Γ x : A
TY Σ; n; Γ xs : list_type
TY Σ; n; Γ cons_expr x xs : list_type.
Proof.
intros. simpl. solve_typing.
Qed.
Lemma list_case_typed Σ n Γ :
type_wf n A
TY Σ; n; Γ list_case : (: list_type.[ren (+1)] #0 (A.[ren(+1)] list_type.[ren (+1)] #0) #0).
Proof.
intros. simpl. solve_typing.
Qed.
End lists.
(* The stack interface *)
Definition stack_t A : type :=
: ((Unit #0) (* new *)
× (#0 A.[ren (+1)] Unit) (* push *)
× (#0 Unit + A.[ren (+1)])) (* pop *)
.
(** We assume an abstract implementation of lists (an example implementation is provided above) *)
Definition list_t (A : type) : type :=
: (#0 (* mynil *)
× (A.[ren (+1)] #0 #0) (* mycons *)
× (: #1 #0 (A.[ren (+2)] #1 #0) #0)) (* mylistcase *)
.
Definition mystack : val :=
(* define your stack implementation, assuming "lc" is a list implementation *)
λ: "lc",
((λ: <>, New (Fst (Fst "lc"))),
(λ: "st" "el",
let: "stv" := !"st" in
"st" <- Snd (Fst "lc") "el" "stv"),
(λ: "st",
let: "stv" := !"st" in
(Snd "lc") <> "stv" (InjL #())%V (λ: "h" "rstv",
"st" <- "rstv";;
InjR "h"))).
Definition make_mystack : val :=
Λ, λ: "lc",
unpack "lc" as "lc" in
pack (mystack "lc").
Lemma make_mystack_typed Σ n Γ :
TY Σ; n; Γ make_mystack : (: list_t #0 stack_t #0).
Proof.
repeat solve_typing_fast.
Qed.
(** Exercise 2 (LN Exercise 46): Obfuscated code *)
Definition obf_expr : expr :=
let: "x" := new (λ: "x", "x" + "x") in
let: "f" := (λ: "g", let: "f" := !"x" in "x" <- "g";; "f" #11) in
"f" (λ: "x", "f" (λ: <>, "x")) + "f" (λ: "x", "x" + #9).
(* The following contextual lifting lemma will be helpful *)
Lemma rtc_contextual_step_fill K e e' h h' :
rtc contextual_step (e, h) (e', h')
rtc contextual_step (fill K e, h) (fill K e', h').
Proof.
remember (e, h) as a eqn:Heqa. remember (e', h') as b eqn:Heqb.
induction 1 as [ | ? c ? Hstep ? IH] in e', h', e, h, Heqa, Heqb |-*; subst.
- simplify_eq. done.
- destruct c as (e1, h1).
econstructor 2.
+ apply fill_contextual_step. apply Hstep.
+ apply IH; done.
Qed.
(* You may use the [new_fresh] and [init_heap_singleton] lemmas to allocate locations *)
Lemma obf_expr_eval :
h', rtc contextual_step (obf_expr, ) (of_val #42, h').
Proof.
eexists. unfold obf_expr.
econstructor 2.
{ eapply fill_contextual_step with (K := [AppRCtx _]).
eapply base_contextual_step.
eapply (new_fresh (LamV _ _)).
}
rewrite init_heap_singleton.
simpl.
econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl.
econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. etrans.
{ apply rtc_contextual_step_fill with (K := [BinOpRCtx _ _]).
econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply fill_contextual_step with (K := [AppRCtx _]).
apply base_contextual_step.
econstructor. rewrite lookup_insert. done.
}
simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply fill_contextual_step with (K := [AppRCtx _]).
apply base_contextual_step. econstructor; done.
}
rewrite insert_insert. simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
reflexivity.
}
simpl. etrans.
{ apply rtc_contextual_step_fill with (K := [BinOpLCtx _ (LitV _)]).
econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply fill_contextual_step with (K := [AppRCtx _]).
apply base_contextual_step.
econstructor. rewrite lookup_insert. done.
}
simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply fill_contextual_step with (K := [AppRCtx _]).
apply base_contextual_step. econstructor; done.
}
rewrite insert_insert. simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
simpl. econstructor 2.
{ apply base_contextual_step. econstructor; done. }
reflexivity.
}
simpl.
econstructor 2.
{ apply base_contextual_step. econstructor; simpl; done. }
reflexivity.
Qed.
(** Exercise 4 (LN Exercise 48): Fibonacci *)
Definition knot : val :=
λ: "f",
let: "x" := new (λ: "x", #0) in
let: "g" := "f" (λ: "y", (! "x") "y") in
"x" <- "g";; "g".
Definition fibonacci : val :=
λ: "n", knot (λ: "rec" "n",
if: "n" = #0 then #0 else
if: "n" = #1 then #1 else
"rec" ("n" - #1) + "rec" ("n" - #2)) "n".
Lemma fibonacci_typed Σ n Γ :
TY Σ; n; Γ fibonacci : (Int Int).
Proof.
repeat solve_typing_fast.
Qed.

File diff suppressed because it is too large Load Diff

File diff suppressed because it is too large Load Diff
Loading…
Cancel
Save