#![cfg(feature = "faer")]
use basin::problems::Rosenbrock;
use basin::{Executor, GradientTolerance, QuasiNewtonState, TerminationReason, BFGS};
use faer::{Col, Mat};
#[test]
fn bfgs_converges_on_rosenbrock() {
let problem = Rosenbrock::<Col<f64>>::default();
let initial = Col::from_fn(2, |i| if i == 0 { -1.2 } else { 1.0 });
let result = Executor::new(
problem,
BFGS::new(),
QuasiNewtonState::<Col<f64>, Mat<f64>>::new(initial),
)
.max_iter(100)
.run();
assert!(
result.cost() < 1e-8,
"expected near-zero cost, got {}",
result.cost()
);
assert!(
(result.param()[0] - 1.0).abs() < 1e-4,
"x[0] = {}",
result.param()[0]
);
assert!(
(result.param()[1] - 1.0).abs() < 1e-4,
"x[1] = {}",
result.param()[1]
);
}
#[test]
fn bfgs_terminates_on_gradient_tolerance() {
let problem = Rosenbrock::<Col<f64>>::default();
let initial = Col::from_fn(2, |i| if i == 0 { -1.2 } else { 1.0 });
let result = Executor::new(
problem,
BFGS::new(),
QuasiNewtonState::<Col<f64>, Mat<f64>>::new(initial),
)
.max_iter(200)
.terminate_on(GradientTolerance(1e-6))
.run();
assert_eq!(result.reason, TerminationReason::GradientTolerance);
assert!(result.cost() < 1e-10, "cost = {}", result.cost());
}