From: Claudio Sacerdoti Coen <claudio.sacerdoticoen@unibo.it> Date: Tue, 4 Mar 2008 16:42:17 +0000 (+0000) Subject: New syntax for patterns. X-Git-Tag: make_still_working~5568 X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=commitdiff_plain;h=289d8d049e72beef41c17930f13727b5049981a2;p=helm.git New syntax for patterns. --- diff --git a/helm/software/matita/library/freescale/medium_tests_lemmas.ma b/helm/software/matita/library/freescale/medium_tests_lemmas.ma index c7ae9a74e..e708f57bc 100644 --- a/helm/software/matita/library/freescale/medium_tests_lemmas.ma +++ b/helm/software/matita/library/freescale/medium_tests_lemmas.ma @@ -150,70 +150,70 @@ lemma execute_HCS08_LDHX_maIMM2 : intros; whd in ⢠(? ? % ?); - whd in ⢠(? ? match % in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?); + whd in ⢠(? ? match % return ? with [_â?|_â?|_â?] ?); rewrite > H; - whd in ⢠(? ? match % in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?); - whd in ⢠(? ? match match % in fetch_result return ? with [FetchERRâ?|FetchOKâ?] in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?); + whd in ⢠(? ? match % in tick_result return ? with [_â?|_â?|_â?] ?); + whd in ⢠(? ? match match % in fetch_result return ? with [_â?|_â?] in tick_result return ? with [_â?|_â?|_â?] ?); rewrite > H1; - whd in ⢠(? ? match match % in fetch_result return ? with [FetchERRâ?|FetchOKâ?] in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?); - change in ⢠(? ? match % in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?) with + whd in ⢠(? ? match match % in fetch_result return ? with [_â?|_â?] in tick_result return ? with [_â?|_â?|_â?] ?); + change in ⢠(? ? match % in tick_result return ? with [_â?|_â?|_â?] ?) with (match (quadrupleT (any_opcode HCS08) ??? LDHX MODE_IMM2 â©x4,x5⪠â©x0,x3âª) with [quadrupleT pseudo mode _ tot_clk â match eq_b8 â©x0,x1⪠tot_clk with [ true â tick_execute HCS08 t s pseudo mode (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)) | false â TickOK (any_status HCS08 t) (set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x1⪠pseudo mode tot_clk (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)))))]]); - change in ⢠(? ? match % in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?) with + change in ⢠(? ? match % in tick_result return ? with [_â?|_â?|_â?] ?) with (match eq_b8 â©x0,x1⪠â©x0,x3⪠with [ true â tick_execute HCS08 t s (anyOP HCS08 LDHX) MODE_IMM2 (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)) | false â TickOK (any_status HCS08 t) (set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x1⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)))))]); - whd in ⢠(? ? match % in tick_result return ? with [TickERRâ?|TickSUSPâ?|TickOKâ?] ?); + whd in ⢠(? ? match % in tick_result return ? with [_â?|_â?|_â?] ?); letin status1 â (set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x1⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))); change in ⢠(? ? % ?) with (match 2 with [ O â TickOK ? status1 | S (n':nat) â execute HCS08 t (tick HCS08 t status1) n']); - whd in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? % ?] ?); - unfold status1 in ⢠(? ? match ? in nat return ? with [Oâ? |S (n':?)â ? ? ? match ? ? ? % in option return ? with [Noneâ?|Someâ?] ?] ?); + whd in ⢠(? ? match ? return ? with [_â?|_âλ_:?.? ? ? % ?] ?); + unfold status1 in ⢠(? ? match ? in nat return ? with [_â? |_ â λ_.? ? ? match ? ? ? % in option return ? with [_â?|_â?] ?] ?); rewrite > (get_set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x1⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))); - whd in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? % ?] ?); - normalize in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? (? ? (? ? ? ? (? ? (? ? ? ? ? ? % ? ? ? ?)))) ?] ?); - whd in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â%] ?); + whd in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? % ?] ?); + normalize in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? (? ? (? ? ? ? (? ? (? ? ? ? ? ? % ? ? ? ?)))) ?] ?); + whd in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.%] ?); - unfold status1 in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? (? ? (? ? ? % ?)) ?] ?); + unfold status1 in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? (? ? (? ? ? % ?)) ?] ?); rewrite > (set_set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x1⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)))) (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))) - in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? (? ? %) ?] ?); + in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? (? ? %) ?] ?); letin status2 â (set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))); change in ⢠(? ? % ?) with (match 1 with [ O â TickOK ? status2 | S (n':nat) â execute HCS08 t (tick HCS08 t status2) n']); - whd in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? % ?] ?); - unfold status2 in ⢠(? ? match ? in nat return ? with [Oâ? |S (n':?)â ? ? ? match ? ? ? % in option return ? with [Noneâ?|Someâ?] ?] ?); + whd in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? % ?] ?); + unfold status2 in ⢠(? ? match ? in nat return ? with [_â? |_â λ_. ? ? ? match ? ? ? % in option return ? with [_â?|_â?] ?] ?); rewrite > (get_set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))); - whd in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? % ?] ?); - change in ⢠(? ? match ? in nat return ? with [Oâ? |S (n':?)â? ? ? match % in option return ? with [Noneâ?|Someâ?] ?] ?) with + whd in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? % ?] ?); + change in ⢠(? ? match ? in nat return ? with [_â? |_âλ_.? ? ? match % in option return ? with [_â?|_â?] ?] ?) with (execute_LDHX HCS08 t status2 MODE_IMM2 (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))); - whd in ⢠(? ? match ? in nat return ? with [Oâ? |S (n':?)â? ? ? match % in option return ? with [Noneâ?|Someâ?] ?] ?); - whd in ⢠(? ? match ? in nat return ? with [Oâ? |S (n':?)â ? ? ? match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); + whd in ⢠(? ? match ? in nat return ? with [_â? |_âλ_.? ? ? match % in option return ? with [_â?|_â?] ?] ?); + whd in ⢠(? ? match ? in nat return ? with [_â? |_â λ_.? ? ? match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); - unfold status2 in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match ? ? ? % ? in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); + unfold status2 in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match ? ? ? % ? in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); rewrite > (memory_filter_read_set_clk_desc HCS08 t s (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)) (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))) - in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); - rewrite > H2 in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); - whd in ⢠(? ? match ? in nat return ? with [Oâ? |S (n':?)â ? ? ? match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); + in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); + rewrite > H2 in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); + whd in ⢠(? ? match ? in nat return ? with [_â? |_âλ_. ? ? ? match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); - unfold status2 in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); + unfold status2 in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); rewrite > (filtered_inc_set_clk_desc HCS08 t s (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)))) (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))) - in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match ? ? ? ? % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); + in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match ? ? ? ? % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); rewrite > (memory_filter_read_set_clk_desc HCS08 t s (filtered_inc_w16 HCS08 t s (filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))) (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s))))) - in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); - rewrite > H3 in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â ? ? ? match match match % in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] in option return ? with [Noneâ?|Someâ?] ?] ?); + in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); + rewrite > H3 in ⢠(? ? match ? in nat return ? with [_â?|_âλ_. ? ? ? match match match % in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] in option return ? with [_â?|_â?] ?] ?); - whd in ⢠(? ? match ? in nat return ? with [Oâ?|S (n':?)â? ? ? % ?] ?); + whd in ⢠(? ? match ? in nat return ? with [_â?|_âλ_.? ? ? % ?] ?); change in ⢠(? ? % ?) with (TickOK ? (set_clk_desc HCS08 t @@ -244,7 +244,7 @@ lemma execute_HCS08_LDHX_maIMM2 : rewrite > (set_clk_desc_set_pc_reg HCS08 t (setweak_v_flag HCS08 t (setweak_n_flag HCS08 t (set_z_flag HCS08 t (set_alu HCS08 t s (set_indX_16_reg_HC08 (alu HCS08 t s) â©bhigh:blowâª)) (eq_w16 â©bhigh:blow⪠â©â©x0,x0âª:â©x0,x0âªâª)) (MSB_w16 â©bhigh:blowâª)) false) (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)))) (filtered_plus_w16 HCS08 t s (get_pc_reg HCS08 t s) 3)); rewrite > (set_set_clk_desc HCS08 t (set_pc_reg HCS08 t (setweak_v_flag HCS08 t (setweak_n_flag HCS08 t (set_z_flag HCS08 t (set_alu HCS08 t s (set_indX_16_reg_HC08 (alu HCS08 t s) â©bhigh:blowâª)) (eq_w16 â©bhigh:blow⪠â©â©x0,x0âª:â©x0,x0âªâª)) (MSB_w16 â©bhigh:blowâª)) false) (filtered_plus_w16 HCS08 t s (get_pc_reg HCS08 t s) 3)) (Some ? (quintupleT ????? â©x0,x2⪠(anyOP HCS08 LDHX) MODE_IMM2 â©x0,x3⪠(filtered_inc_w16 HCS08 t s (get_pc_reg HCS08 t s)))) (None ?)); rewrite > (set_clk_f_set_clk_desc HCS08 t s (λtmps.set_pc_reg HCS08 t (setweak_v_flag HCS08 t (setweak_n_flag HCS08 t (set_z_flag HCS08 t (set_alu HCS08 t tmps (set_indX_16_reg_HC08 (alu HCS08 t tmps) â©bhigh:blowâª)) (eq_w16 â©bhigh:blow⪠â©â©x0,x0âª:â©x0,x0âªâª)) (MSB_w16 â©bhigh:blowâª)) false) (filtered_plus_w16 HCS08 t tmps (get_pc_reg HCS08 t tmps) 3))) in ⢠(? ? (? ? %) ?); - [2: elim H; reflexivity ] + [2: assumption ] reflexivity. qed.