void run_wnaf(void) { secp256k1_num_t n; for (int i=0; i<count; i++) { random_num_order(&n); if (i % 1) secp256k1_num_negate(&n); test_wnaf(&n, 4+(i%10)); } }
void test_num_copy_inc_cmp(void) { secp256k1_num_t n1,n2; random_num_order(&n1); secp256k1_num_copy(&n2, &n1); CHECK(secp256k1_num_eq(&n1, &n2)); CHECK(secp256k1_num_eq(&n2, &n1)); secp256k1_num_inc(&n2); CHECK(!secp256k1_num_eq(&n1, &n2)); CHECK(!secp256k1_num_eq(&n2, &n1)); }
int main() { secp256k1_fe_start(); secp256k1_ge_start(); secp256k1_ecmult_start(); secp256k1_fe_t x; const secp256k1_num_t *order = &secp256k1_ge_consts->order; secp256k1_num_t r, s, m; secp256k1_num_init(&r); secp256k1_num_init(&s); secp256k1_num_init(&m); secp256k1_ecdsa_sig_t sig; secp256k1_ecdsa_sig_init(&sig); secp256k1_fe_set_hex(&x, "a357ae915c4a65281309edf20504740f0eb3343990216b4f81063cb65f2f7e0f", 64); int cnt = 0; int good = 0; for (int i=0; i<1000000; i++) { random_num_order(&r); random_num_order(&s); random_num_order(&m); secp256k1_ecdsa_sig_set_rs(&sig, &r, &s); secp256k1_ge_t pubkey; secp256k1_ge_set_xo(&pubkey, &x, 1); if (secp256k1_ge_is_valid(&pubkey)) { cnt++; good += secp256k1_ecdsa_sig_verify(&sig, &pubkey, &m); } } printf("%i/%i\n", good, cnt); secp256k1_num_free(&r); secp256k1_num_free(&s); secp256k1_num_free(&m); secp256k1_ecdsa_sig_free(&sig); secp256k1_ecmult_stop(); secp256k1_ge_stop(); secp256k1_fe_stop(); return 0; }
void test_num_copy_inc_cmp() { secp256k1_num_t n1,n2; secp256k1_num_init(&n1); secp256k1_num_init(&n2); random_num_order(&n1); secp256k1_num_copy(&n2, &n1); assert(secp256k1_num_cmp(&n1, &n2) == 0); assert(secp256k1_num_cmp(&n2, &n1) == 0); secp256k1_num_inc(&n2); assert(secp256k1_num_cmp(&n1, &n2) != 0); assert(secp256k1_num_cmp(&n2, &n1) != 0); secp256k1_num_free(&n1); secp256k1_num_free(&n2); }