1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#[macro_export]
macro_rules! ext_field_operation {
($extension_field:ident, $sub_field:ident, $limbs_length:ident) => {
use zero_crypto::behave::*;
use zero_crypto::common::*;
ext_field_ring_operation!($extension_field, $sub_field, $limbs_length);
impl Field for $extension_field {}
impl Div for $extension_field {
type Output = $extension_field;
#[inline]
fn div(self, rhs: $extension_field) -> $extension_field {
let inv = rhs.invert().unwrap();
self * inv
}
}
impl DivAssign for $extension_field {
fn div_assign(&mut self, rhs: $extension_field) {
let inv = rhs.invert().unwrap();
*self *= inv
}
}
};
}
pub use ext_field_operation;