lemma char_of_integer_of_char [code abstype]: ‹Chr (integer_of_char c) = c› by (simp add: integer_of_char_def)
lemma char_of_integer_code [code]: ‹integer_of_char (char_of_integer k) = (if 0 ≤ k ∧ k < 256 then k else k mod 256)› by (simp add: integer_of_char_def char_of_integer_def integer_eq_iff integer_less_eq_iff integer_less_iff)
lemma of_char_code [code]: ‹of_char c = of_nat (nat_of_integer (integer_of_char c))› proof - have‹int_of_integer (of_char c) = of_char c› by (cases c) simp thenshow ?thesis by (simp add: integer_of_char_def nat_of_integer_def of_nat_of_char) qed
lemma digit_0_code [code]: ‹digit0 c ⟷ bit (integer_of_char c) 0› by (cases c) (simp add: integer_of_char_def)
lemma digit_1_code [code]: ‹digit1 c ⟷ bit (integer_of_char c) 1› by (cases c) (simp add: integer_of_char_def)
lemma digit_2_code [code]: ‹digit2 c ⟷ bit (integer_of_char c) 2› by (cases c) (simp add: integer_of_char_def)
lemma digit_3_code [code]: ‹digit3 c ⟷ bit (integer_of_char c) 3› by (cases c) (simp add: integer_of_char_def)
lemma digit_4_code [code]: ‹digit4 c ⟷ bit (integer_of_char c) 4› by (cases c) (simp add: integer_of_char_def)
lemma digit_5_code [code]: ‹digit5 c ⟷ bit (integer_of_char c) 5› by (cases c) (simp add: integer_of_char_def)
lemma digit_6_code [code]: ‹digit6 c ⟷ bit (integer_of_char c) 6› by (cases c) (simp add: integer_of_char_def)
lemma digit_7_code [code]: ‹digit7 c ⟷ bit (integer_of_char c) 7› by (cases c) (simp add: integer_of_char_def)
lemma case_char_code [code]: ‹case_char f c = f (digit0 c) (digit1 c) (digit2 c) (digit3 c) (digit4 c) (digit5 c) (digit6 c) (digit7 c)› by (fact char.case_eq_if)
lemma rec_char_code [code]: ‹rec_char f c = f (digit0 c) (digit1 c) (digit2 c) (digit3 c) (digit4 c) (digit5 c) (digit6 c) (digit7 c)› by (cases c) simp
lemma char_of_code [code]: ‹integer_of_char (char_of a) =
byte (bit a 0) (bit a 1) (bit a 2) (bit a 3) (bit a 4) (bit a 5) (bit a 6) (bit a 7)› by (simp add: char_of_def integer_of_char_def)
lemma ascii_of_code [code]: ‹integer_of_char (String.ascii_of c) = (let k = integer_of_char c inif k < 128 then k else k - 128)› proof (cases ‹of_char c < (128 :: integer)›) case True moreoverhave‹(of_nat 0 :: integer) ≤ of_nat (of_char c)› by simp thenhave‹(0 :: integer) ≤ of_char c› by (simp only: of_nat_0 of_nat_of_char) ultimatelyshow ?thesis by (simp add: Let_def integer_of_char_def take_bit_eq_mod integer_eq_iff integer_less_eq_iff integer_less_iff) next case False thenhave‹(128 :: integer) ≤ of_char c› by simp moreoverhave‹of_nat (of_char c) < (of_nat 256 :: integer)› by (simp only: of_nat_less_iff) simp thenhave‹of_char c < (256 :: integer)› by (simp add: of_nat_of_char) moreover define k :: integer where‹k = of_char c - 128› thenhave‹of_char c = k + 128› by simp ultimatelyshow ?thesis by (simp add: Let_def integer_of_char_def take_bit_eq_mod integer_eq_iff integer_less_eq_iff integer_less_iff) qed
lemma equal_char_code [code]: ‹HOL.equal c d ⟷ integer_of_char c = integer_of_char d› by (simp add: integer_of_char_def equal)
lemma less_eq_char_code [code]: ‹c ≤ d ⟷ integer_of_char c ≤ integer_of_char d› (is‹?P ⟷ ?Q›) proof - have‹?P ⟷ of_nat (of_char c) ≤ (of_nat (of_char d) :: integer)› by (simp add: less_eq_char_def) alsohave‹…⟷ ?Q› by (simp add: of_nat_of_char integer_of_char_def) finallyshow ?thesis . qed
lemma less_char_code [code]: ‹c < d ⟷ integer_of_char c < integer_of_char d› (is‹?P ⟷ ?Q›) proof - have‹?P ⟷ of_nat (of_char c) < (of_nat (of_char d) :: integer)› by (simp add: less_char_def) alsohave‹…⟷ ?Q› by (simp add: of_nat_of_char integer_of_char_def) finallyshow ?thesis . qed
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.