tasm_lib/hashing/
swap_digest.rsuse std::collections::HashMap;
use itertools::Itertools;
use rand::prelude::*;
use triton_vm::prelude::*;
use crate::data_type::DataType;
use crate::empty_stack;
use crate::library::Library;
use crate::push_encodable;
use crate::traits::deprecated_snippet::DeprecatedSnippet;
use crate::Digest;
use crate::InitVmState;
#[derive(Clone, Debug)]
pub struct SwapDigest;
impl DeprecatedSnippet for SwapDigest {
fn entrypoint_name(&self) -> String {
"tasmlib_hashing_swap_digest".to_string()
}
fn input_field_names(&self) -> Vec<String> {
vec![
"b4".to_string(),
"b3".to_string(),
"b2".to_string(),
"b1".to_string(),
"b0".to_string(),
"a4".to_string(),
"a3".to_string(),
"a2".to_string(),
"a1".to_string(),
"a0".to_string(),
]
}
fn input_types(&self) -> Vec<DataType> {
vec![DataType::Digest, DataType::Digest]
}
fn output_field_names(&self) -> Vec<String> {
vec![
"a4".to_string(),
"a3".to_string(),
"a2".to_string(),
"a1".to_string(),
"a0".to_string(),
"b4".to_string(),
"b3".to_string(),
"b2".to_string(),
"b1".to_string(),
"b0".to_string(),
]
}
fn output_types(&self) -> Vec<DataType> {
vec![DataType::Digest, DataType::Digest]
}
fn stack_diff(&self) -> isize {
0
}
fn function_code(&self, _library: &mut Library) -> String {
let entrypoint = self.entrypoint_name();
triton_asm!(
{entrypoint}:
swap 4 swap 9 swap 4 swap 3 swap 8 swap 3 swap 2 swap 7 swap 2 swap 1 swap 6 swap 1 swap 5 return
)
.iter()
.join("\n")
}
fn crash_conditions(&self) -> Vec<String> {
vec![]
}
fn gen_input_states(&self) -> Vec<InitVmState> {
let mut rng = rand::thread_rng();
let digest_a: Digest = rng.gen();
let digest_b: Digest = rng.gen();
let mut stack = empty_stack();
push_encodable(&mut stack, &digest_b);
push_encodable(&mut stack, &digest_a);
vec![InitVmState::with_stack(stack)]
}
fn common_case_input_state(&self) -> InitVmState {
let mut rng = rand::thread_rng();
let mut stack = empty_stack();
push_encodable(&mut stack, &rng.gen::<Digest>());
push_encodable(&mut stack, &rng.gen::<Digest>());
InitVmState::with_stack(stack)
}
fn worst_case_input_state(&self) -> InitVmState {
self.common_case_input_state()
}
fn rust_shadowing(
&self,
stack: &mut Vec<BFieldElement>,
_std_in: Vec<BFieldElement>,
_secret_in: Vec<BFieldElement>,
_memory: &mut HashMap<BFieldElement, BFieldElement>,
) {
let h = stack.len();
for i in 0..Digest::LEN {
let ai_pos = h - i - 1;
let bi_pos = h - i - Digest::LEN - 1;
stack.swap(ai_pos, bi_pos);
}
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::test_helpers::test_rust_equivalence_multiple_deprecated;
#[test]
fn swap_digest_test() {
test_rust_equivalence_multiple_deprecated(&SwapDigest, true);
}
}
#[cfg(test)]
mod benches {
use super::*;
use crate::snippet_bencher::bench_and_write;
#[test]
fn swap_digest_benchmark() {
bench_and_write(SwapDigest);
}
}