feos 0.9.5

FeOs - A framework for equations of state and classical density functional theory.
Documentation
use crate::hard_sphere::HardSphere;
use crate::uvtheory::parameters::UVTheoryPars;
use attractive_perturbation::AttractivePerturbation;
use feos_core::StateHD;
use num_dual::DualNum;
use reference_perturbation::ReferencePerturbation;

mod attractive_perturbation;
mod hard_sphere;
mod reference_perturbation;

pub struct BarkerHenderson;

impl BarkerHenderson {
    pub fn residual_helmholtz_energy_contributions<D: DualNum<f64> + Copy>(
        &self,
        parameters: &UVTheoryPars,
        state: &StateHD<D>,
    ) -> Vec<(&'static str, D)> {
        vec![
            (
                "Hard Sphere (BH)",
                HardSphere.helmholtz_energy_density(parameters, state),
            ),
            (
                "Reference Perturbation (BH)",
                ReferencePerturbation.helmholtz_energy_density(parameters, state),
            ),
            (
                "Attractive Perturbation (BH)",
                AttractivePerturbation.helmholtz_energy_density(parameters, state),
            ),
        ]
    }
}