#[cfg(feature = "serde")]
use serde::{Deserialize, Serialize};
#[cfg_attr(feature = "serde", derive(Serialize, Deserialize))]
#[derive(Debug, Clone, PartialEq)]
pub struct Evaluation {
pub objectives: Vec<f64>,
pub constraint_violation: f64,
}
impl Evaluation {
pub fn new(objectives: Vec<f64>) -> Self {
Self {
objectives,
constraint_violation: 0.0,
}
}
pub fn constrained(objectives: Vec<f64>, constraint_violation: f64) -> Self {
Self {
objectives,
constraint_violation,
}
}
pub fn is_feasible(&self) -> bool {
self.constraint_violation <= 0.0
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn new_is_feasible() {
let e = Evaluation::new(vec![1.0, 2.0]);
assert_eq!(e.constraint_violation, 0.0);
assert!(e.is_feasible());
}
#[test]
fn constrained_sets_violation() {
let e = Evaluation::constrained(vec![0.0], 0.5);
assert!(!e.is_feasible());
assert_eq!(e.constraint_violation, 0.5);
}
#[test]
fn zero_or_negative_violation_is_feasible() {
assert!(Evaluation::constrained(vec![0.0], 0.0).is_feasible());
assert!(Evaluation::constrained(vec![0.0], -1.0).is_feasible());
}
}