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 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
// Copyright (C) 2019-2023 Aleo Systems Inc.
// This file is part of the snarkVM library.
// The snarkVM library is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// The snarkVM library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with the snarkVM library. If not, see <https://www.gnu.org/licenses/>.
#![cfg_attr(test, allow(clippy::assertions_on_result_states))]
#![warn(clippy::cast_possible_truncation)]
mod arithmetic;
mod bitwise;
mod bytes;
mod compare;
mod from_bits;
mod one;
mod parse;
mod random;
mod serialize;
mod size_in_bits;
mod size_in_bytes;
mod to_bits;
mod zero;
pub use snarkvm_console_network_environment::prelude::*;
pub use snarkvm_console_types_boolean::Boolean;
#[derive(Copy, Clone, PartialEq, Eq, Hash)]
pub struct Field<E: Environment> {
/// The underlying field element.
field: E::Field,
}
impl<E: Environment> FieldTrait for Field<E> {}
impl<E: Environment> Field<E> {
/// The field size in bits.
pub const SIZE_IN_BITS: usize = E::Field::SIZE_IN_BITS;
/// The field size in bytes.
pub const SIZE_IN_BYTES: usize = (E::Field::SIZE_IN_BITS + 7) / 8;
/// The field capacity for data bits.
pub const SIZE_IN_DATA_BITS: usize = E::Field::SIZE_IN_DATA_BITS;
/// Initializes a new field.
pub const fn new(field: E::Field) -> Self {
Self { field }
}
/// Initializes a new field as a domain separator.
pub fn new_domain_separator(domain: &str) -> Self {
Self::new(E::Field::from_bytes_le_mod_order(domain.as_bytes()))
}
/// Initializes a new field from a `u8`.
pub fn from_u8(value: u8) -> Self {
Self { field: E::Field::from(value as u128) }
}
/// Initializes a new field from a `u16`.
pub fn from_u16(value: u16) -> Self {
Self { field: E::Field::from(value as u128) }
}
/// Initializes a new field from a `u32`.
pub fn from_u32(value: u32) -> Self {
Self { field: E::Field::from(value as u128) }
}
/// Initializes a new field from a `u64`.
pub fn from_u64(value: u64) -> Self {
Self { field: E::Field::from(value as u128) }
}
/// Initializes a new field from a `u128`.
pub fn from_u128(value: u128) -> Self {
Self { field: E::Field::from(value) }
}
/// Returns `1 * 2^{-1}`.
pub fn half() -> Self {
Self { field: E::Field::half() }
}
}
impl<E: Environment> TypeName for Field<E> {
/// Returns the type name as a string.
#[inline]
fn type_name() -> &'static str {
"field"
}
}
impl<E: Environment> Deref for Field<E> {
type Target = E::Field;
#[inline]
fn deref(&self) -> &Self::Target {
&self.field
}
}
impl<E: Environment> DerefMut for Field<E> {
#[inline]
fn deref_mut(&mut self) -> &mut Self::Target {
&mut self.field
}
}