X-Git-Url: https://git.distorted.org.uk/u/mdw/catacomb/blobdiff_plain/342c3212d1da321c0eb3281a98af8f1a8e6fce7d..c760149fcb65296defd1af967fbfa098bd83143a:/tests/mp diff --git a/tests/mp b/tests/mp index 329c0ee..d12167f 100644 --- a/tests/mp +++ b/tests/mp @@ -1,6 +1,6 @@ # Test vectors for MP functions # -# $Id: mp,v 1.3 1999/12/10 23:25:51 mdw Exp $ +# $Id: mp,v 1.5 2000/06/22 19:01:14 mdw Exp $ add { 5 4 9; 5 -4 1; -5 4 -1; -5 -4 -9; @@ -21,6 +21,31 @@ div { 9 4 2 1; -9 4 -3 3; 9 -4 -3 -3; -9 -4 2 -1; } +odd { + 1 0 1; + 2 1 1; + 4 2 1; + 12 2 3; + 0x10000000000000 52 1; + 0x10000000400000 22 0x40000001; +} + +sqrt { + 0 0; + 1 1; + 4 2; + 9 3; + 16 4; + 99 9; +100 10; +101 10; +120 10; +121 11; + +10106623487257186586 3179091613; +14565040310136678240 3816417208; +} + gcd { # --- Simple tests --- @@ -76,6 +101,30 @@ gcd { 1 -4601007896041464028712478963832994007038251361995647370 514778499400157641662814932021958856708417966520837469125919104431; + + # --- Misery --- + # + # Some bugs discovered during RSA testing. + + 100000423751500546004561515884626739136961367515520675987004088469753859696407139054406989735113827981148062449057870561788973142250811838720214530386151198455545176591384352343648452329042764530196327665219224050630680827543991306749402959935685172017409062967157813233001567797128414009962262840951763040181 + 44895767034162990997987303986882660674722497505237491649296190658571471979065889234144353811843706629535512848235473808330181517421970135930320187227697512315919757806204341545022714991717913006031724818461724742069401359454784533576615919680949125073761586043027941204059690093447093117249681641020785611986 + 1 + -44146175664861261172356293340716833133750232401287328189797639296698679436925232375473973898100363205157703913050824405116878299310008848005045714833814493992539429428295945643439440068026313232881493081836812480325977761600303456915493177366981470223898994906470419007730670657168179659899713837827764669213 + 98330790743257232930640417364963717704786040860302439189781385170246412183980882564239377268174203679366339563908361674571088519452885615348465535190260914996055274486493192655677181637142116473172979503236297658204730543049175626205461452256333155750566288282331419748434569978343545573401114593095927172889; + + 44895767034162990997987303986882660674722497505237491649296190658571471979065889234144353811843706629535512848235473808330181517421970135930320187227697512315919757806204341545022714991717913006031724818461724742069401359454784533576615919680949125073761586043027941204059690093447093117249681641020785611986 + 100000423751500546004561515884626739136961367515520675987004088469753859696407139054406989735113827981148062449057870561788973142250811838720214530386151198455545176591384352343648452329042764530196327665219224050630680827543991306749402959935685172017409062967157813233001567797128414009962262840951763040181 + 1 + -1669633008243313073921098519663021432175326655218236797222703299507447512426256490167612466939624301781722885149508887217884622797926223371748995195890283459489902104891159687971270691900648057023348161982926392425950284494815680543941507679352016266842774684826393484566997818784868436561148247855835867292 + 749591369301729825631010646165827540972265103950163459498551361872792542140656858670379913743343424377808935184649403213303218111961287925274472393883018323380328377908395901583274923691599773150231736624912261743423597854481076661122742313967654849862591136557522196329019436278913457349967803193020942773; + + # --- Some other bugs --- + + 19504439280113284806725522136967618725661733412699408177537810327183285842670 + 1 + 1 + 0 + 1; } jacobi { @@ -84,3 +133,15 @@ jacobi { 15 27 0; 2132498039840981 98729378979237498798347932749951 1; } + +modsqrt { + 4 5 3; + 9775592058107450692 13391974640168007623 3264570455655810730; + 8155671698868891620 10189552848261357803 2073812183305821596; + 3248339460720824413 8976233780911635437 1220523478429582717; + 3447751741648956439 10155704720805654949 2812971608818169892; + 1453601744816463433 3095659104519735473 1260511572497628526; + 3366261317119810224 3756232416311497601 610261287187759737; + 3869491397135339653 5762828162167967567 2974328005712882420; + 660864223630638896 1729533840094059799 1058197842375219723; +}