Raven Core
3.0.0
P2P Digital Currency
Main Page
Modules
+
Namespaces
Namespace List
+
Namespace Members
+
All
a
b
c
d
e
f
g
h
i
l
m
n
o
p
q
r
s
t
v
z
+
Functions
b
c
d
f
g
h
i
m
o
p
q
s
v
Variables
Typedefs
Enumerations
Enumerator
+
Classes
Class List
Class Index
Class Hierarchy
+
Class Members
+
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
~
+
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
z
~
+
Variables
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
+
Typedefs
a
b
c
d
f
i
k
l
m
o
p
r
s
t
v
+
Enumerations
b
c
d
e
f
m
n
o
r
s
t
u
v
w
+
Enumerator
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
Properties
+
Related Functions
a
c
d
f
o
p
t
u
v
w
+
Files
File List
+
File Members
+
All
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
+
Functions
_
a
b
c
d
e
f
g
h
i
j
k
l
m
n
o
p
q
r
s
t
u
v
w
z
+
Variables
a
b
c
d
e
f
g
h
i
l
m
n
p
r
s
t
u
v
w
z
+
Typedefs
b
c
h
i
k
m
n
r
s
t
u
v
w
+
Enumerations
a
b
c
d
e
f
g
h
i
j
m
n
o
q
r
s
t
w
+
Enumerator
a
b
c
d
e
f
g
h
i
j
l
m
n
o
r
s
t
u
+
Macros
_
a
b
c
d
e
f
g
h
i
k
l
m
n
o
p
q
r
s
t
u
v
w
x
y
z
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Modules
Pages
src
secp256k1
src
ecmult.h
Go to the documentation of this file.
1
/**********************************************************************
2
* Copyright (c) 2013, 2014 Pieter Wuille *
3
* Distributed under the MIT software license, see the accompanying *
4
* file COPYING or http://www.opensource.org/licenses/mit-license.php.*
5
**********************************************************************/
6
7
#ifndef SECP256K1_ECMULT_H
8
#define SECP256K1_ECMULT_H
9
10
#include "
num.h
"
11
#include "
group.h
"
12
13
typedef
struct
{
14
/* For accelerating the computation of a*P + b*G: */
15
secp256k1_ge_storage
(*pre_g)[];
/* odd multiples of the generator */
16
#ifdef USE_ENDOMORPHISM
17
secp256k1_ge_storage
(*pre_g_128)[];
/* odd multiples of 2^128*generator */
18
#endif
19
}
secp256k1_ecmult_context
;
20
21
static
void
secp256k1_ecmult_context_init(
secp256k1_ecmult_context
*ctx);
22
static
void
secp256k1_ecmult_context_build(
secp256k1_ecmult_context
*ctx,
const
secp256k1_callback
*cb);
23
static
void
secp256k1_ecmult_context_clone(
secp256k1_ecmult_context
*dst,
24
const
secp256k1_ecmult_context
*src,
const
secp256k1_callback
*cb);
25
static
void
secp256k1_ecmult_context_clear(
secp256k1_ecmult_context
*ctx);
26
static
int
secp256k1_ecmult_context_is_built(
const
secp256k1_ecmult_context
*ctx);
27
29
static
void
secp256k1_ecmult(
const
secp256k1_ecmult_context
*ctx,
secp256k1_gej
*r,
const
secp256k1_gej
*a,
const
secp256k1_scalar
*na,
const
secp256k1_scalar
*ng);
30
31
#endif
/* SECP256K1_ECMULT_H */
group.h
secp256k1_gej
A group element of the secp256k1 curve, in jacobian coordinates.
Definition:
group.h:24
secp256k1_ge_storage
Definition:
group.h:34
secp256k1_scalar
A scalar modulo the group order of the secp256k1 curve.
Definition:
scalar_4x64.h:13
num.h
secp256k1_ecmult_context
Definition:
ecmult.h:13
secp256k1_callback
Definition:
util.h:18
Generated on Mon Jul 29 2019 02:32:20 for Raven Core by
1.8.13