demo: verify that negative number handling in mp_jacobi works
This commit is contained in:
parent
e8d2609f81
commit
3ae9d0fbd2
22
demo/demo.c
22
demo/demo.c
@ -145,7 +145,7 @@ int main(void)
|
|||||||
unsigned long s, t;
|
unsigned long s, t;
|
||||||
unsigned long long q, r;
|
unsigned long long q, r;
|
||||||
mp_digit mp;
|
mp_digit mp;
|
||||||
int i, n, err;
|
int i, n, err, should;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (mp_init_multi(&a, &b, &c, &d, &e, &f, NULL)!= MP_OKAY)
|
if (mp_init_multi(&a, &b, &c, &d, &e, &f, NULL)!= MP_OKAY)
|
||||||
@ -206,8 +206,8 @@ int main(void)
|
|||||||
|
|
||||||
mp_set_int(&a, 0);
|
mp_set_int(&a, 0);
|
||||||
mp_set_int(&b, 1);
|
mp_set_int(&b, 1);
|
||||||
if ((ix = mp_jacobi(&a, &b, &i)) != MP_OKAY) {
|
if ((err = mp_jacobi(&a, &b, &i)) != MP_OKAY) {
|
||||||
printf("Failed executing mp_jacobi(0 | 1) %s.\n", mp_error_to_string(ix));
|
printf("Failed executing mp_jacobi(0 | 1) %s.\n", mp_error_to_string(err));
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
if (i != 1) {
|
if (i != 1) {
|
||||||
@ -217,15 +217,19 @@ int main(void)
|
|||||||
for (cnt = 0; cnt < (int)(sizeof(jacobi)/sizeof(jacobi[0])); ++cnt) {
|
for (cnt = 0; cnt < (int)(sizeof(jacobi)/sizeof(jacobi[0])); ++cnt) {
|
||||||
mp_set_int(&b, jacobi[cnt].n);
|
mp_set_int(&b, jacobi[cnt].n);
|
||||||
/* only test positive values of a */
|
/* only test positive values of a */
|
||||||
// for (n = -5; n <= 10; ++n) {
|
for (n = -5; n <= 10; ++n) {
|
||||||
for (n = 0; n <= 10; ++n) {
|
|
||||||
mp_set_int(&a, abs(n));
|
mp_set_int(&a, abs(n));
|
||||||
if (n < 0) mp_neg(&a, &a);
|
should = MP_OKAY;
|
||||||
if ((ix = mp_jacobi(&a, &b, &i)) != MP_OKAY) {
|
if (n < 0) {
|
||||||
printf("Failed executing mp_jacobi(%d | %lu) %s.\n", n, jacobi[cnt].n, mp_error_to_string(ix));
|
mp_neg(&a, &a);
|
||||||
|
/* Until #44 is fixed the negative a's must fail */
|
||||||
|
should = MP_VAL;
|
||||||
|
}
|
||||||
|
if ((err = mp_jacobi(&a, &b, &i)) != should) {
|
||||||
|
printf("Failed executing mp_jacobi(%d | %lu) %s.\n", n, jacobi[cnt].n, mp_error_to_string(err));
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
if (i != jacobi[cnt].c[n + 5]) {
|
if (err == MP_OKAY && i != jacobi[cnt].c[n + 5]) {
|
||||||
printf("Failed trivial mp_jacobi(%d | %lu) %d != %d\n", n, jacobi[cnt].n, i, jacobi[cnt].c[n + 5]);
|
printf("Failed trivial mp_jacobi(%d | %lu) %d != %d\n", n, jacobi[cnt].n, i, jacobi[cnt].c[n + 5]);
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user