use crate::ffi_apis::common::BincodeBuffer;
use crate::ffi_apis::common::from_bincode_buffer;
use crate::ffi_apis::common::to_bincode_buffer;
use crate::symbolic::core::Expr;
use crate::symbolic::topology::Simplex;
use crate::symbolic::topology::SimplicialComplex;
use crate::symbolic::topology::SymbolicChain;
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_simplex_create(vertices_buf: BincodeBuffer) -> BincodeBuffer {
let vertices: Option<Vec<usize>> = from_bincode_buffer(&vertices_buf);
if let Some(v) = vertices {
let simplex = Simplex::new(&v);
to_bincode_buffer(&simplex)
} else {
BincodeBuffer::empty()
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_simplex_dimension(simplex_buf: BincodeBuffer) -> BincodeBuffer {
let simplex: Option<Simplex> = from_bincode_buffer(&simplex_buf);
if let Some(s) = simplex {
to_bincode_buffer(&s.dimension())
} else {
BincodeBuffer::empty()
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_simplicial_complex_create() -> BincodeBuffer {
let complex = SimplicialComplex::new();
to_bincode_buffer(&complex)
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_simplicial_complex_add_simplex(
complex_buf: BincodeBuffer,
vertices_buf: BincodeBuffer,
) -> BincodeBuffer {
let complex: Option<SimplicialComplex> = from_bincode_buffer(&complex_buf);
let vertices: Option<Vec<usize>> = from_bincode_buffer(&vertices_buf);
if let (Some(mut c), Some(v)) = (complex, vertices) {
c.add_simplex(&v);
to_bincode_buffer(&c)
} else {
BincodeBuffer::empty()
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_simplicial_complex_get_symbolic_boundary_matrix(
complex_buf: BincodeBuffer,
k: usize,
) -> BincodeBuffer {
let complex: Option<SimplicialComplex> = from_bincode_buffer(&complex_buf);
if let Some(c) = complex {
match c.get_symbolic_boundary_matrix(k) {
| Some(expr) => to_bincode_buffer(&expr),
| None => BincodeBuffer::empty(),
}
} else {
BincodeBuffer::empty()
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_symbolic_chain_create(dimension: usize) -> BincodeBuffer {
let chain = SymbolicChain::new(dimension);
to_bincode_buffer(&chain)
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_symbolic_chain_add_term(
chain_buf: BincodeBuffer,
simplex_buf: BincodeBuffer,
coeff_buf: BincodeBuffer,
) -> BincodeBuffer {
let chain: Option<SymbolicChain> = from_bincode_buffer(&chain_buf);
let simplex: Option<Simplex> = from_bincode_buffer(&simplex_buf);
let coeff: Option<Expr> = from_bincode_buffer(&coeff_buf);
match (chain, simplex, coeff) {
| (Some(mut c), Some(s), Some(coeff)) => {
match c.add_term(s, coeff) {
| Ok(()) => to_bincode_buffer(&c),
| Err(_) => BincodeBuffer::empty(),
}
},
| _ => BincodeBuffer::empty(),
}
}
#[unsafe(no_mangle)]
pub extern "C" fn rssn_bincode_simplicial_complex_apply_symbolic_boundary_operator(
complex_buf: BincodeBuffer,
chain_buf: BincodeBuffer,
) -> BincodeBuffer {
let complex: Option<SimplicialComplex> = from_bincode_buffer(&complex_buf);
let chain: Option<SymbolicChain> = from_bincode_buffer(&chain_buf);
match (complex, chain) {
| (Some(c), Some(ch)) => {
match c.apply_symbolic_boundary_operator(&ch) {
| Some(result) => to_bincode_buffer(&result),
| None => BincodeBuffer::empty(),
}
},
| _ => BincodeBuffer::empty(),
}
}