#| Copyright (C) 1994 by Robert S. Boyer and J Strother Moore. All Rights Reserved. This script is hereby placed in the public domain, and therefore unlimited editing and redistribution is permitted. NO WARRANTY Robert S. Boyer and J Strother Moore PROVIDE ABSOLUTELY NO WARRANTY. THE EVENT SCRIPT IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, ANY IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE SCRIPT IS WITH YOU. SHOULD THE SCRIPT PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. IN NO EVENT WILL Robert S. Boyer or J Strother Moore BE LIABLE TO YOU FOR ANY DAMAGES, ANY LOST PROFITS, LOST MONIES, OR OTHER SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THIS SCRIPT (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY THIRD PARTIES), EVEN IF YOU HAVE ADVISED US OF THE POSSIBILITY OF SUCH DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. |# (NOTE-LIB "proveall" T) (COMPILE-UNCOMPILED-DEFNS "tmp") (DISABLE EUCLID) (DISABLE QUOTIENT-DIVIDES) (DISABLE IF-TIMES-THEN-DIVIDES) (DISABLE TIMES) (DEFN CRYPT (M E N) (IF (ZEROP E) 1 (IF (EVEN E) (REMAINDER (SQUARE (CRYPT M (QUOTIENT E 2) N)) N) (REMAINDER (TIMES M (REMAINDER (SQUARE (CRYPT M (QUOTIENT E 2) N)) N)) N)))) (PROVE-LEMMA TIMES-MOD-1 (REWRITE) (EQUAL (REMAINDER (TIMES X (REMAINDER Y N)) N) (REMAINDER (TIMES X Y) N))) (PROVE-LEMMA TIMES-MOD-2 (REWRITE) (EQUAL (REMAINDER (TIMES A (TIMES B (REMAINDER Y N))) N) (REMAINDER (TIMES A B Y) N)) ((USE (TIMES-MOD-1 (X (TIMES A B)))) (DISABLE TIMES-MOD-1))) (PROVE-LEMMA CRYPT-CORRECT (REWRITE) (IMPLIES (NOT (EQUAL N 1)) (EQUAL (CRYPT M E N) (REMAINDER (EXP M E) N)))) (PROVE-LEMMA TIMES-MOD-3 (REWRITE) (EQUAL (REMAINDER (TIMES (REMAINDER A N) B) N) (REMAINDER (TIMES A B) N))) (PROVE-LEMMA REMAINDER-EXP-LEMMA (REWRITE) (IMPLIES (EQUAL (REMAINDER Y A) (REMAINDER Z A)) (EQUAL (EQUAL (REMAINDER (TIMES X Y) A) (REMAINDER (TIMES X Z) A)) T))) (PROVE-LEMMA REMAINDER-EXP (REWRITE) (EQUAL (REMAINDER (EXP (REMAINDER A N) I) N) (REMAINDER (EXP A I) N))) (PROVE-LEMMA EXP-MOD-IS-1 (REWRITE) (IMPLIES (EQUAL (REMAINDER (EXP M J) P) 1) (EQUAL (REMAINDER (EXP M (TIMES I J)) P) 1)) ((USE (EXP-EXP (I M) (J J) (K I)) (REMAINDER-EXP (A (EXP M J)) (N P))) (DISABLE EXP-EXP REMAINDER-EXP))) (DEFN PDIFFERENCE (A B) (IF (LESSP A B) (DIFFERENCE B A) (DIFFERENCE A B)) NIL ; We wish to teach the system the trick of proving that A mod p = B mod p by ; considering whether p A-B. If we used DIFFERENCE we would have to split on ; whether A