1
0
mirror of https://github.com/TREX-CoE/trexio.git synced 2025-01-10 21:18:35 +01:00

Tests in bitfields

This commit is contained in:
Anthony Scemama 2023-10-13 11:17:13 +02:00
parent 2afc6160f0
commit 1e7dfc8ddd
3 changed files with 53 additions and 32 deletions

View File

@ -1,18 +1,16 @@
#[derive(Debug)] #[derive(Debug)]
pub struct Bitfield { pub struct Bitfield {
data: Vec<i64>, data: Vec<i64>,
n_int: usize
} }
use crate::c; use crate::c;
use crate::File;
use crate::ExitCode; use crate::ExitCode;
impl Bitfield { impl Bitfield {
/// Creates a new bitfield , using a number of i64 elements consistent /// Creates a new bitfield , using a number of i64 elements consistent
/// with the number of MOs in the TREXIO file. /// with the number of MOs in the TREXIO file.
pub fn from(n_int: usize, orb_list: Vec<usize>) -> Result<(Self, f64), ExitCode> { pub fn from(n_int: usize, orb_list: &[usize]) -> Result<(Self, f64), ExitCode> {
let orb_list: Vec<i32> = orb_list.iter().map(|&x| x as i32).collect(); let orb_list: Vec<i32> = orb_list.iter().map(|&x| x as i32).collect();
let occ_num = orb_list.len().try_into().expect("try_into failed in Bitfield::from"); let occ_num = orb_list.len().try_into().expect("try_into failed in Bitfield::from");
@ -27,7 +25,7 @@ impl Bitfield {
let data = unsafe { Vec::from_raw_parts(bit_list, n_int, n_int) }; let data = unsafe { Vec::from_raw_parts(bit_list, n_int, n_int) };
let result = Bitfield { data, n_int }; let result = Bitfield { data };
match ExitCode::from(rc) { match ExitCode::from(rc) {
ExitCode::Success => Ok( (result, 1.0) ), ExitCode::Success => Ok( (result, 1.0) ),
@ -36,19 +34,24 @@ impl Bitfield {
} }
} }
/// Number of i64 needed to represent a spin sector pub fn from_alpha_beta(alpha: Bitfield, beta: Bitfield) -> Result<Bitfield, ExitCode> {
pub fn n_int(&self) -> usize { if alpha.data.len() != beta.data.len() {
self.n_int return Err(ExitCode::InvalidArg2)
};
let mut data = alpha.data.clone();
data.extend_from_slice(&beta.data);
Ok(Bitfield { data })
} }
/// Returns the alpha part /// Returns the alpha part
pub fn alpha(&self) -> &[i64] { pub fn alpha(&self) -> &[i64] {
&self.data[0..self.n_int] let n_int = self.data.len()/2;
&self.data[0..n_int]
} }
/// Returns the beta part /// Returns the beta part
pub fn beta(&self) -> &[i64] { pub fn beta(&self) -> &[i64] {
let n_int = self.n_int; let n_int = self.data.len()/2;
&self.data[n_int..2*n_int] &self.data[n_int..2*n_int]
} }
@ -69,9 +72,9 @@ impl Bitfield {
/// Converts the bitfield into a list of orbital indices (0-based) /// Converts the bitfield into a list of orbital indices (0-based)
pub fn to_orbital_list(&self) -> Result< Vec<usize>, ExitCode> { pub fn to_orbital_list(&self) -> Result< Vec<usize>, ExitCode> {
let n_int : i32 = self.n_int.try_into().expect("try_into failed in to_orbital_list"); let n_int : i32 = self.data.len().try_into().expect("try_into failed in to_orbital_list");
let d1 = self.as_ptr(); let d1 = self.as_ptr();
let cap = self.n_int * 64; let cap = self.data.len() * 64;
let mut list = vec![ 0i32 ; cap ]; let mut list = vec![ 0i32 ; cap ];
let list_c = list.as_mut_ptr() as *mut i32; let list_c = list.as_mut_ptr() as *mut i32;
std::mem::forget(list); std::mem::forget(list);
@ -97,9 +100,9 @@ impl Bitfield {
/// Converts the determinant into a list of orbital indices (0-based) /// Converts the determinant into a list of orbital indices (0-based)
pub fn to_orbital_list_up_dn(&self) -> Result< (Vec<usize>, Vec<usize>), ExitCode> { pub fn to_orbital_list_up_dn(&self) -> Result< (Vec<usize>, Vec<usize>), ExitCode> {
let n_int : i32 = (self.n_int/2).try_into().expect("try_into failed in to_orbital_list"); let n_int : i32 = (self.data.len()/2).try_into().expect("try_into failed in to_orbital_list");
let d1 = self.as_ptr(); let d1 = self.as_ptr();
let cap = self.n_int * 64; let cap = self.data.len()/2 * 64;
let mut b = vec![ 0i32 ; cap ]; let mut b = vec![ 0i32 ; cap ];
let list_up_c = b.as_mut_ptr() as *mut i32; let list_up_c = b.as_mut_ptr() as *mut i32;
std::mem::forget(b); std::mem::forget(b);
@ -136,3 +139,40 @@ impl Bitfield {
} }
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn creation_from_list() {
let list0 = vec![0, 1, 2, 3, 4];
let list1 = vec![0, 1, 2, 4, 3];
let list2 = vec![0, 1, 4, 2, 3];
let (alpha0, phase0) = Bitfield::from(2, &list0).unwrap();
let list = alpha0.to_orbital_list().unwrap();
assert_eq!(list, list0);
let (alpha1, phase1) = Bitfield::from(2, &list1).unwrap();
let list = alpha1.to_orbital_list().unwrap();
assert_eq!(list, list0);
assert_eq!(phase1, -phase0);
let (alpha2, phase2) = Bitfield::from(2, &list2).unwrap();
let list = alpha2.to_orbital_list().unwrap();
assert_eq!(list, list0);
assert_eq!(phase2, phase0);
}
#[test]
fn creation_alpha_beta() {
let (alpha, _) = Bitfield::from(2, &[0, 1, 2, 3, 4]).unwrap();
let (beta , _) = Bitfield::from(2, &[0, 1, 2, 4, 5]).unwrap();
let det = Bitfield::from_alpha_beta(alpha, beta).unwrap();
let list = det.to_orbital_list().unwrap();
assert_eq!(list, [0,1,2,3,4,128,129,130,132,133]);
}
}

View File

@ -113,17 +113,3 @@ impl File {
include!("generated.rs"); include!("generated.rs");
#[cfg(test)]
mod tests {
use super::*;
use std::mem;
use c::*;
#[test]
fn read_trexio_file() {
println!("============================================");
println!(" TREXIO MAJOR VERSION : {}", TREXIO_VERSION_MAJOR);
println!("============================================");
}
}

View File

@ -98,11 +98,6 @@ pub fn test_write(file_name: &str, back_end: BackEnd) -> Result<(), trexio::Exit
} }
trex_file.write_mo_spin(spin)?; trex_file.write_mo_spin(spin)?;
let (det, phase) = trexio::Bitfield::from(4, vec![0, 1, 2, 3, 4, 5, 6, 151, 152, 153, 154])?;
println!("{} {:?}", phase, det);
println!("{:?}", det.to_orbital_list().unwrap());
println!("{:?}", det.to_orbital_list().unwrap());
println!("{:?}", det.to_orbital_list_up_dn().unwrap());
trex_file.close() trex_file.close()