# HG changeset patch # User huffman # Date 1231783763 28800 # Node ID 2eadbc24de8c6b54c7c011f240adf07280a657d7 # Parent 3f8b85444512e7171e103afa7c8f01fda8085260 correctness and uniqueness of synthetic division diff -r 3f8b85444512 -r 2eadbc24de8c src/HOL/Polynomial.thy --- a/src/HOL/Polynomial.thy Mon Jan 12 09:35:15 2009 -0800 +++ b/src/HOL/Polynomial.thy Mon Jan 12 10:09:23 2009 -0800 @@ -433,11 +433,11 @@ "smult (a + b) p = smult a p + smult b p" by (rule poly_ext, simp add: ring_simps) -lemma smult_minus_right: +lemma smult_minus_right [simp]: "smult (a::'a::comm_ring) (- p) = - smult a p" by (rule poly_ext, simp) -lemma smult_minus_left: +lemma smult_minus_left [simp]: "smult (- a::'a::comm_ring) p = - smult a p" by (rule poly_ext, simp) @@ -991,8 +991,24 @@ unfolding synthetic_div_def by (simp add: split_def snd_synthetic_divmod) -lemma synthetic_div: +lemma synthetic_div_correct: "p + smult c (synthetic_div p c) = pCons (poly p c) (synthetic_div p c)" by (induct p) simp_all +lemma synthetic_div_unique_lemma: "smult c p = pCons a p \ p = 0" +by (induct p arbitrary: a) simp_all + +lemma synthetic_div_unique: + "p + smult c q = pCons r q \ r = poly p c \ q = synthetic_div p c" +apply (induct p arbitrary: q r) +apply (simp, frule synthetic_div_unique_lemma, simp) +apply (case_tac q, force) +done + +lemma synthetic_div_correct': + fixes c :: "'a::comm_ring_1" + shows "[:-c, 1:] * synthetic_div p c + [:poly p c:] = p" + using synthetic_div_correct [of p c] + by (simp add: group_simps) + end