diff options
| author | Thomas Bauereiss | 2018-06-21 17:50:54 +0100 |
|---|---|---|
| committer | Thomas Bauereiss | 2018-06-21 17:54:17 +0100 |
| commit | 2005eb7c190f8d28d6499df3dd77cf65a87e60cb (patch) | |
| tree | 73f7c9d58e77f8ff08832b211779ba2789c8f8f7 /lib/isabelle/Sail_values_lemmas.thy | |
| parent | 3f626070c3fcba7871f6364630b05fa62d36c5c8 (diff) | |
Follow Sail2 renaming in Isabelle library
Diffstat (limited to 'lib/isabelle/Sail_values_lemmas.thy')
| -rw-r--r-- | lib/isabelle/Sail_values_lemmas.thy | 206 |
1 files changed, 0 insertions, 206 deletions
diff --git a/lib/isabelle/Sail_values_lemmas.thy b/lib/isabelle/Sail_values_lemmas.thy deleted file mode 100644 index dd008695..00000000 --- a/lib/isabelle/Sail_values_lemmas.thy +++ /dev/null @@ -1,206 +0,0 @@ -theory Sail_values_lemmas - imports Sail_values -begin - -lemma nat_of_int_nat_simps[simp]: "nat_of_int = nat" by (auto simp: nat_of_int_def) - -termination reverse_endianness_list by (lexicographic_order simp add: drop_list_def) - -termination index_list - by (relation "measure (\<lambda>(i, j, step). nat ((j - i + step) * sgn step))") auto - -lemma just_list_map_Some[simp]: "just_list (map Some v) = Some v" by (induction v) auto - -lemma just_list_None_iff[simp]: "just_list xs = None \<longleftrightarrow> None \<in> set xs" - by (induction xs) (auto split: option.splits) - -lemma just_list_Some_iff[simp]: "just_list xs = Some ys \<longleftrightarrow> xs = map Some ys" - by (induction xs arbitrary: ys) (auto split: option.splits) - -lemma just_list_cases: - assumes "just_list xs = y" - obtains (None) "None \<in> set xs" and "y = None" - | (Some) ys where "xs = map Some ys" and "y = Some ys" - using assms by (cases y) auto - -lemma repeat_singleton_replicate[simp]: - "repeat [x] n = replicate (nat n) x" -proof (induction n) - case (nonneg n) - have "nat (1 + int m) = Suc m" for m by auto - then show ?case by (induction n) auto -next - case (neg n) - then show ?case by auto -qed - -lemma bool_of_bitU_simps[simp]: - "bool_of_bitU B0 = Some False" - "bool_of_bitU B1 = Some True" - "bool_of_bitU BU = None" - by (auto simp: bool_of_bitU_def) - -lemma bitops_bitU_of_bool[simp]: - "and_bit (bitU_of_bool x) (bitU_of_bool y) = bitU_of_bool (x \<and> y)" - "or_bit (bitU_of_bool x) (bitU_of_bool y) = bitU_of_bool (x \<or> y)" - "xor_bit (bitU_of_bool x) (bitU_of_bool y) = bitU_of_bool ((x \<or> y) \<and> \<not>(x \<and> y))" - "not_bit (bitU_of_bool x) = bitU_of_bool (\<not>x)" - "not_bit \<circ> bitU_of_bool = bitU_of_bool \<circ> Not" - by (auto simp: bitU_of_bool_def not_bit_def) - -lemma image_bitU_of_bool_B0_B1: "bitU_of_bool ` bs \<subseteq> {B0, B1}" - by (auto simp: bitU_of_bool_def split: if_splits) - -lemma bool_of_bitU_bitU_of_bool[simp]: - "bool_of_bitU \<circ> bitU_of_bool = Some" - "bool_of_bitU \<circ> (bitU_of_bool \<circ> f) = Some \<circ> f" - "bool_of_bitU (bitU_of_bool x) = Some x" - by (intro ext, auto simp: bool_of_bitU_def bitU_of_bool_def)+ - -abbreviation "BC_bitU_list \<equiv> instance_Sail_values_Bitvector_list_dict instance_Sail_values_BitU_Sail_values_bitU_dict" -lemmas BC_bitU_list_def = instance_Sail_values_Bitvector_list_dict_def instance_Sail_values_BitU_Sail_values_bitU_dict_def -abbreviation "BC_mword \<equiv> instance_Sail_values_Bitvector_Machine_word_mword_dict" -lemmas BC_mword_defs = instance_Sail_values_Bitvector_Machine_word_mword_dict_def - access_mword_def access_mword_inc_def access_mword_dec_def - (*update_mword_def update_mword_inc_def update_mword_dec_def*) - subrange_list_def subrange_list_inc_def subrange_list_dec_def - update_subrange_list_def update_subrange_list_inc_def update_subrange_list_dec_def - -declare size_itself_int_def[simp] -declare size_itself_def[simp] -declare word_size[simp] - -lemma int_of_mword_simps[simp]: - "int_of_mword False w = uint w" - "int_of_mword True w = sint w" - "int_of_bv BC_mword False w = Some (uint w)" - "int_of_bv BC_mword True w = Some (sint w)" - by (auto simp: int_of_mword_def int_of_bv_def BC_mword_defs) - -lemma BC_mword_simps[simp]: - "unsigned_method BC_mword a = Some (uint a)" - "signed_method BC_mword a = Some (sint a)" - "length_method BC_mword (a :: ('a :: len) word) = int (LENGTH('a))" - by (auto simp: BC_mword_defs) - -lemma of_bits_mword_of_bl[simp]: - assumes "just_list (map bool_of_bitU bus) = Some bs" - shows "of_bits_method BC_mword bus = Some (of_bl bs)" - and "of_bits_failwith BC_mword bus = of_bl bs" - using assms by (auto simp: BC_mword_defs of_bits_failwith_def maybe_failwith_def) - -lemma nat_of_bits_aux_bl_to_bin_aux: - "nat_of_bools_aux acc bs = nat (bl_to_bin_aux bs (int acc))" - by (induction acc bs rule: nat_of_bools_aux.induct) - (auto simp: Bit_def intro!: arg_cong[where f = nat] arg_cong2[where f = bl_to_bin_aux] split: if_splits) - -lemma nat_of_bits_bl_to_bin[simp]: - "nat_of_bools bs = nat (bl_to_bin bs)" - by (auto simp: nat_of_bools_def bl_to_bin_def nat_of_bits_aux_bl_to_bin_aux) - -lemma unsigned_bits_of_mword[simp]: - "unsigned_method BC_bitU_list (bits_of_method BC_mword a) = Some (uint a)" - by (auto simp: BC_bitU_list_def BC_mword_defs unsigned_of_bits_def unsigned_of_bools_def) - -lemma bits_of_bitU_list[simp]: - "bits_of_method BC_bitU_list v = v" - "of_bits_method BC_bitU_list v = Some v" - by (auto simp: BC_bitU_list_def) - -lemma subrange_list_inc_drop_take: - "subrange_list_inc xs i j = drop (nat i) (take (nat (j + 1)) xs)" - by (auto simp: subrange_list_inc_def split_at_def) - -lemma subrange_list_dec_drop_take: - assumes "i \<ge> 0" and "j \<ge> 0" - shows "subrange_list_dec xs i j = drop (length xs - nat (i + 1)) (take (length xs - nat j) xs)" - using assms unfolding subrange_list_dec_def - by (auto simp: subrange_list_inc_drop_take add.commute diff_diff_add nat_minus_as_int) - -lemma update_subrange_list_inc_drop_take: - assumes "i \<ge> 0" and "j \<ge> i" - shows "update_subrange_list_inc xs i j xs' = take (nat i) xs @ xs' @ drop (nat (j + 1)) xs" - using assms unfolding update_subrange_list_inc_def - by (auto simp: split_at_def min_def) - -lemma update_subrange_list_dec_drop_take: - assumes "j \<ge> 0" and "i \<ge> j" - shows "update_subrange_list_dec xs i j xs' = take (length xs - nat (i + 1)) xs @ xs' @ drop (length xs - nat j) xs" - using assms unfolding update_subrange_list_dec_def update_subrange_list_inc_def - by (auto simp: split_at_def min_def Let_def add.commute diff_diff_add nat_minus_as_int) - -declare access_list_inc_def[simp] - -lemma access_list_dec_rev_nth: - assumes "0 \<le> i" and "nat i < length xs" - shows "access_list_dec xs i = rev xs ! (nat i)" - using assms - by (auto simp: access_list_dec_def rev_nth intro!: arg_cong2[where f = List.nth]) - -lemma access_bv_dec_mword[simp]: - fixes w :: "('a::len) word" - assumes "0 \<le> n" and "nat n < LENGTH('a)" - shows "access_bv_dec BC_mword w n = bitU_of_bool (w !! (nat n))" - using assms unfolding access_bv_dec_def access_list_def - by (auto simp: access_list_dec_rev_nth BC_mword_defs rev_map test_bit_bl) - -lemma access_list_dec_nth[simp]: - assumes "0 \<le> i" - shows "access_list_dec xs i = xs ! (length xs - nat (i + 1))" - using assms - by (auto simp: access_list_dec_def add.commute diff_diff_add nat_minus_as_int) - -lemma update_list_inc_update[simp]: - "update_list_inc xs n x = xs[nat n := x]" - by (auto simp: update_list_inc_def) - -lemma update_list_dec_update[simp]: - "update_list_dec xs n x = xs[length xs - nat (n + 1) := x]" - by (auto simp: update_list_dec_def add.commute diff_diff_add nat_minus_as_int) - -lemma bools_of_nat_aux_simps[simp]: - "\<And>len. len \<le> 0 \<Longrightarrow> bools_of_nat_aux len x acc = acc" - "\<And>len. bools_of_nat_aux (int (Suc len)) x acc = - bools_of_nat_aux (int len) (x div 2) ((if x mod 2 = 1 then True else False) # acc)" - by auto -declare bools_of_nat_aux.simps[simp del] - -lemma bools_of_nat_aux_bin_to_bl_aux: - "bools_of_nat_aux len n acc = bin_to_bl_aux (nat len) (int n) acc" -proof (cases len) - case (nonneg len') - show ?thesis unfolding nonneg - proof (induction len' arbitrary: n acc) - case (Suc len'' n acc) - then show ?case - using zmod_int[of n 2] - by (auto simp del: of_nat_simps simp add: bin_rest_def bin_last_def zdiv_int) - qed auto -qed auto - -lemma bools_of_nat_bin_to_bl[simp]: - "bools_of_nat len n = bin_to_bl (nat len) (int n)" - by (auto simp: bools_of_nat_def bools_of_nat_aux_bin_to_bl_aux) - -lemma add_one_bool_ignore_overflow_aux_rbl_succ[simp]: - "add_one_bool_ignore_overflow_aux xs = rbl_succ xs" - by (induction xs) auto - -lemma add_one_bool_ignore_overflow_rbl_succ[simp]: - "add_one_bool_ignore_overflow xs = rev (rbl_succ (rev xs))" - unfolding add_one_bool_ignore_overflow_def by auto - -lemma map_Not_bin_to_bl: - "map Not (bin_to_bl_aux len n acc) = bin_to_bl_aux len (-n - 1) (map Not acc)" -proof (induction len arbitrary: n acc) - case (Suc len n acc) - moreover have "(- (n div 2) - 1) = ((-n - 1) div 2)" by auto - moreover have "(n mod 2 = 0) = ((- n - 1) mod 2 = 1)" by presburger - ultimately show ?case by (auto simp: bin_rest_def bin_last_def) -qed auto - -lemma bools_of_int_bin_to_bl[simp]: - "bools_of_int (int len) n = bin_to_bl len n" - by (auto simp: bools_of_int_def Let_def map_Not_bin_to_bl rbl_succ[unfolded bin_to_bl_def]) - -end |
