use crate::rng::Rng64;
use crate::rng64::{Mt1993764, Sfmt1993764};
use std::slice::from_raw_parts_mut;
#[unsafe(no_mangle)]
pub extern "C" fn mt1993764_new(seed: u64) -> *mut Mt1993764 {
Box::into_raw(Box::new(Mt1993764::new(seed)))
}
#[unsafe(no_mangle)]
pub extern "C" fn mt1993764_free(ptr: *mut Mt1993764) {
if !ptr.is_null() {
unsafe { drop(Box::from_raw(ptr)) };
}
}
#[unsafe(no_mangle)]
pub extern "C" fn mt1993764_next_u64s(ptr: *mut Mt1993764, out: *mut u64, count: usize) {
if count == 0 {
return;
}
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Mt1993764::new, |r| r.nextu());
}
}
#[unsafe(no_mangle)]
pub extern "C" fn mt1993764_next_f64s(ptr: *mut Mt1993764, out: *mut f64, count: usize) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Mt1993764::new, |r| r.nextf());
}
}
#[unsafe(no_mangle)]
pub extern "C" fn mt1993764_rand_i64s(
ptr: *mut Mt1993764,
out: *mut i64,
count: usize,
min: i64,
max: i64,
) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Mt1993764::new, |r| r.randi(min, max));
}
}
#[unsafe(no_mangle)]
pub extern "C" fn mt1993764_rand_f64s(
ptr: *mut Mt1993764,
out: *mut f64,
count: usize,
min: f64,
max: f64,
) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Mt1993764::new, |r| r.randf(min, max));
}
}
#[unsafe(no_mangle)]
pub extern "C" fn sfmt1993764_new(seed: u64) -> *mut Sfmt1993764 {
Box::into_raw(Box::new(Sfmt1993764::new(seed)))
}
#[unsafe(no_mangle)]
pub extern "C" fn sfmt1993764_free(ptr: *mut Sfmt1993764) {
if !ptr.is_null() {
unsafe { drop(Box::from_raw(ptr)) };
}
}
#[unsafe(no_mangle)]
pub extern "C" fn sfmt1993764_next_u64s(ptr: *mut Sfmt1993764, out: *mut u64, count: usize) {
if count == 0 {
return;
}
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Sfmt1993764::new, |r| r.nextu());
}
}
#[unsafe(no_mangle)]
pub extern "C" fn sfmt1993764_next_f64s(ptr: *mut Sfmt1993764, out: *mut f64, count: usize) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Sfmt1993764::new, |r| r.nextf());
}
}
#[unsafe(no_mangle)]
pub extern "C" fn sfmt1993764_rand_i64s(
ptr: *mut Sfmt1993764,
out: *mut i64,
count: usize,
min: i64,
max: i64,
) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Sfmt1993764::new, |r| r.randi(min, max));
}
}
#[unsafe(no_mangle)]
pub extern "C" fn sfmt_rand_f64s(
ptr: *mut Sfmt1993764,
out: *mut f64,
count: usize,
min: f64,
max: f64,
) {
unsafe {
let rng = &mut *ptr;
let buffer = from_raw_parts_mut(out, count);
crate::_internal::par_fill_reseed64(buffer, rng.nextu(), Sfmt1993764::new, |r| r.randf(min, max));
}
}