pub struct ILP {
pub num_vars: usize,
pub bounds: Vec<VarBounds>,
pub constraints: Vec<LinearConstraint>,
pub objective: Vec<(usize, f64)>,
pub sense: ObjectiveSense,
}Expand description
Integer Linear Programming (ILP) problem.
An ILP consists of:
- A set of integer variables with bounds
- Linear constraints on those variables
- A linear objective function to optimize
- An optimization sense (maximize or minimize)
§Example
use problemreductions::models::optimization::{ILP, VarBounds, Comparison, LinearConstraint, ObjectiveSense};
use problemreductions::Problem;
// Create a simple ILP: maximize x0 + 2*x1
// subject to: x0 + x1 <= 3, x0, x1 binary
let ilp = ILP::new(
2,
vec![VarBounds::binary(), VarBounds::binary()],
vec![LinearConstraint::le(vec![(0, 1.0), (1, 1.0)], 3.0)],
vec![(0, 1.0), (1, 2.0)],
ObjectiveSense::Maximize,
);
assert_eq!(ilp.num_variables(), 2);Fields§
§num_vars: usizeNumber of variables.
bounds: Vec<VarBounds>Bounds for each variable.
constraints: Vec<LinearConstraint>Linear constraints.
objective: Vec<(usize, f64)>Sparse objective coefficients: (var_index, coefficient).
sense: ObjectiveSenseOptimization direction.
Implementations§
Source§impl ILP
impl ILP
Sourcepub fn new(
num_vars: usize,
bounds: Vec<VarBounds>,
constraints: Vec<LinearConstraint>,
objective: Vec<(usize, f64)>,
sense: ObjectiveSense,
) -> Self
pub fn new( num_vars: usize, bounds: Vec<VarBounds>, constraints: Vec<LinearConstraint>, objective: Vec<(usize, f64)>, sense: ObjectiveSense, ) -> Self
Sourcepub fn binary(
num_vars: usize,
constraints: Vec<LinearConstraint>,
objective: Vec<(usize, f64)>,
sense: ObjectiveSense,
) -> Self
pub fn binary( num_vars: usize, constraints: Vec<LinearConstraint>, objective: Vec<(usize, f64)>, sense: ObjectiveSense, ) -> Self
Create a binary ILP (all variables are 0-1).
This is a convenience constructor for common binary optimization problems.
Sourcepub fn evaluate_objective(&self, values: &[i64]) -> f64
pub fn evaluate_objective(&self, values: &[i64]) -> f64
Evaluate the objective function for given variable values.
Sourcepub fn bounds_satisfied(&self, values: &[i64]) -> bool
pub fn bounds_satisfied(&self, values: &[i64]) -> bool
Check if all bounds are satisfied for given variable values.
Sourcepub fn constraints_satisfied(&self, values: &[i64]) -> bool
pub fn constraints_satisfied(&self, values: &[i64]) -> bool
Check if all constraints are satisfied for given variable values.
Sourcepub fn is_feasible(&self, values: &[i64]) -> bool
pub fn is_feasible(&self, values: &[i64]) -> bool
Check if a solution is feasible (satisfies bounds and constraints).
Trait Implementations§
Source§impl<'de> Deserialize<'de> for ILP
impl<'de> Deserialize<'de> for ILP
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl Problem for ILP
impl Problem for ILP
Source§type GraphType = SimpleGraph
type GraphType = SimpleGraph
The graph type this problem operates on.
Source§fn num_variables(&self) -> usize
fn num_variables(&self) -> usize
Returns the number of variables in the problem.
Source§fn num_flavors(&self) -> usize
fn num_flavors(&self) -> usize
Returns the number of possible values (flavors) for each variable.
For binary problems, this is 2.
Source§fn problem_size(&self) -> ProblemSize
fn problem_size(&self) -> ProblemSize
Returns metadata about the problem size.
Source§fn energy_mode(&self) -> EnergyMode
fn energy_mode(&self) -> EnergyMode
Returns whether larger or smaller objective values are better.
Source§fn solution_size(&self, config: &[usize]) -> SolutionSize<f64>
fn solution_size(&self, config: &[usize]) -> SolutionSize<f64>
Evaluate the solution size for a given configuration. Read more
Source§fn is_valid_config(&self, config: &[usize]) -> bool
fn is_valid_config(&self, config: &[usize]) -> bool
Check if a configuration is valid for this problem.
Source§fn solution_size_multiple(
&self,
configs: &[Vec<usize>],
) -> Vec<SolutionSize<Self::Size>>
fn solution_size_multiple( &self, configs: &[Vec<usize>], ) -> Vec<SolutionSize<Self::Size>>
Evaluate multiple configurations at once (batch evaluation).
Auto Trait Implementations§
impl Freeze for ILP
impl RefUnwindSafe for ILP
impl Send for ILP
impl Sync for ILP
impl Unpin for ILP
impl UnwindSafe for ILP
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Conv for T
impl<T> Conv for T
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
Causes
self to use its Binary implementation when Debug-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
Causes
self to use its Display implementation when
Debug-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
Causes
self to use its LowerExp implementation when
Debug-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
Causes
self to use its LowerHex implementation when
Debug-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
Causes
self to use its Octal implementation when Debug-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
Causes
self to use its Pointer implementation when
Debug-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
Causes
self to use its UpperExp implementation when
Debug-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
Causes
self to use its UpperHex implementation when
Debug-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
Formats each item in a sequence. Read more
§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
Pipes by value. This is generally the method you want to use. Read more
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
Borrows
self and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
Mutably borrows
self and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
Borrows
self, then passes self.as_ref() into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
Mutably borrows
self, then passes self.as_mut() into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
Borrows
self, then passes self.deref() into the pipe function.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Immutable access to the
Borrow<B> of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
Mutable access to the
BorrowMut<B> of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
Immutable access to the
AsRef<R> view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
Mutable access to the
AsMut<R> view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Immutable access to the
Deref::Target of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Mutable access to the
Deref::Target of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
Calls
.tap() only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
Calls
.tap_mut() only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
Calls
.tap_borrow() only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
Calls
.tap_borrow_mut() only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
Calls
.tap_ref() only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
Calls
.tap_ref_mut() only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
Calls
.tap_deref() only in debug builds, and is erased in release
builds.