CiFEr
dlog.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2018 XLAB d.o.o.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef CIFER_DLOG_H
18 #define CIFER_DLOG_H
19 
20 #include <gmp.h>
21 #include <amcl/fp12_BN254.h>
22 
23 #include "cifer/internal/errors.h"
24 
51 cfe_error cfe_baby_giant(mpz_t res, mpz_t h, mpz_t g, mpz_t p, mpz_t order, mpz_t bound);
52 
71 cfe_error cfe_baby_giant_with_neg(mpz_t res, mpz_t h, mpz_t g, mpz_t p, mpz_t _order, mpz_t bound);
72 
83 cfe_error cfe_pollard_rho(mpz_t res, mpz_t h, mpz_t g, mpz_t p, mpz_t n);
84 
99 cfe_error cfe_baby_giant_FP12_BN256_with_neg(mpz_t res, FP12_BN254 *h, FP12_BN254 *g, mpz_t bound);
100 
101 #endif
cfe_baby_giant_FP12_BN256_with_neg
cfe_error cfe_baby_giant_FP12_BN256_with_neg(mpz_t res, FP12_BN254 *h, FP12_BN254 *g, mpz_t bound)
Baby-step giant-step method for computing the discrete logarithm in the pairing group FP12_BN254 find...
errors.h
Error definitions.
cfe_pollard_rho
cfe_error cfe_pollard_rho(mpz_t res, mpz_t h, mpz_t g, mpz_t p, mpz_t n)
Pollard's rho algorithm - simple, non-parallel version.
cfe_baby_giant
cfe_error cfe_baby_giant(mpz_t res, mpz_t h, mpz_t g, mpz_t p, mpz_t order, mpz_t bound)
Baby-step giant-step method for computing the discrete logarithm in the Zp group.
cfe_baby_giant_with_neg
cfe_error cfe_baby_giant_with_neg(mpz_t res, mpz_t h, mpz_t g, mpz_t p, mpz_t _order, mpz_t bound)
Baby-step giant-step method for computing the discrete logarithm in the Zp group finding also negativ...