Theory Native_Word.Code_Target_Int_Bit
chapter ‹Implementation of bit operations on int by target language operations›
theory Code_Target_Int_Bit
imports
Code_Target_Integer_Bit
"HOL-Library.Code_Target_Int"
begin
lemma int_of_integer_symbolic_code [code drop: int_of_integer_symbolic, code]:
"int_of_integer_symbolic = int_of_integer"
by (fact int_of_integer_symbolic_def)
context
includes bit_operations_syntax
begin
context
begin
qualified definition even :: ‹int ⇒ bool›
where [code_abbrev]: ‹even = Parity.even›
end
lemma [code]:
‹Code_Target_Int_Bit.even i ⟷ i AND 1 = 0›
by (simp add: Code_Target_Int_Bit.even_def even_iff_mod_2_eq_zero and_one_eq)
lemma [code_unfold]:
‹of_bool (odd i) = i AND 1› for i :: int
by (simp add: and_one_eq mod2_eq_if)
lemma [code_unfold]:
‹bit x n ⟷ x AND (push_bit n 1) ≠ 0› for x :: int
by (fact bit_iff_and_push_bit_not_eq_0)
lemma set_bit_int_code [code]:
"set_bit (int_of_integer x) n b = int_of_integer (set_bit x n b)"
including integer.lifting by transfer simp
end
end