NetworkSimplex

Struct NetworkSimplex 

Source
pub struct NetworkSimplex<F, C> { /* private fields */ }

Implementations§

Source§

impl<F, C> NetworkSimplex<F, C>
where F: Copy + PartialOrd + Zero + Add<Output = F> + Sub<Output = F> + AddAssign + SubAssign, C: Copy + PartialOrd + Zero + One + Add<Output = C> + Sub<Output = C> + AddAssign + SubAssign + Neg<Output = C> + Mul<Output = C> + From<F>,

Source

pub fn new(n: usize) -> Self

Examples found in repository?
crates/library_checker/src/graph/assignment.rs (line 10)
6pub fn assignment(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, a: [[i64; n]; n]);
10    let mut ns = NetworkSimplex::<i64, i64>::new(n * 2);
11    for (i, a) in a.iter().enumerate() {
12        ns.add_supply(i, 1);
13        ns.add_demand(i + n, 1);
14        for (j, &a) in a.iter().enumerate() {
15            ns.add_edge(i, j + n, 0, 1, a);
16        }
17    }
18    let sol = ns.solve_minimize();
19    if let Some(sol) = sol {
20        iter_print!(writer, sol.cost);
21        let p = (0..n * n)
22            .filter(|&eid| sol.flows[eid] != 0)
23            .map(|eid| eid % n);
24        iter_print!(writer, @it p);
25    } else {
26        iter_print!(writer, "infeasible");
27    }
28}
More examples
Hide additional examples
crates/library_checker/src/graph/min_cost_b_flow.rs (line 10)
6pub fn min_cost_b_flow(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, m, b: [i64; n], edges: [(usize, usize, i64, i64, i128); m]);
10    let mut ns = NetworkSimplex::<i64, i128>::new(n);
11    for (i, b) in b.into_iter().enumerate() {
12        ns.add_demand_supply(i, b);
13    }
14    for (s, t, l, u, c) in edges {
15        ns.add_edge(s, t, l, u, c);
16    }
17    let sol = ns.solve_minimize();
18    if let Some(sol) = sol {
19        iter_print!(writer, sol.cost);
20        for i in 0..n {
21            iter_print!(writer, sol.potentials[i]);
22        }
23        for i in 0..m {
24            iter_print!(writer, sol.flows[i]);
25        }
26    } else {
27        iter_print!(writer, "infeasible");
28    }
29}
Source

pub fn add_demand(&mut self, vid: usize, demand: F)

Add demand

Examples found in repository?
crates/library_checker/src/graph/assignment.rs (line 13)
6pub fn assignment(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, a: [[i64; n]; n]);
10    let mut ns = NetworkSimplex::<i64, i64>::new(n * 2);
11    for (i, a) in a.iter().enumerate() {
12        ns.add_supply(i, 1);
13        ns.add_demand(i + n, 1);
14        for (j, &a) in a.iter().enumerate() {
15            ns.add_edge(i, j + n, 0, 1, a);
16        }
17    }
18    let sol = ns.solve_minimize();
19    if let Some(sol) = sol {
20        iter_print!(writer, sol.cost);
21        let p = (0..n * n)
22            .filter(|&eid| sol.flows[eid] != 0)
23            .map(|eid| eid % n);
24        iter_print!(writer, @it p);
25    } else {
26        iter_print!(writer, "infeasible");
27    }
28}
Source

pub fn add_supply(&mut self, vid: usize, supply: F)

Add supply

Examples found in repository?
crates/library_checker/src/graph/assignment.rs (line 12)
6pub fn assignment(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, a: [[i64; n]; n]);
10    let mut ns = NetworkSimplex::<i64, i64>::new(n * 2);
11    for (i, a) in a.iter().enumerate() {
12        ns.add_supply(i, 1);
13        ns.add_demand(i + n, 1);
14        for (j, &a) in a.iter().enumerate() {
15            ns.add_edge(i, j + n, 0, 1, a);
16        }
17    }
18    let sol = ns.solve_minimize();
19    if let Some(sol) = sol {
20        iter_print!(writer, sol.cost);
21        let p = (0..n * n)
22            .filter(|&eid| sol.flows[eid] != 0)
23            .map(|eid| eid % n);
24        iter_print!(writer, @it p);
25    } else {
26        iter_print!(writer, "infeasible");
27    }
28}
Source

pub fn add_demand_supply(&mut self, vid: usize, ds: F)

Add demand/supply (positive for supply, negative for demand)

Examples found in repository?
crates/library_checker/src/graph/min_cost_b_flow.rs (line 12)
6pub fn min_cost_b_flow(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, m, b: [i64; n], edges: [(usize, usize, i64, i64, i128); m]);
10    let mut ns = NetworkSimplex::<i64, i128>::new(n);
11    for (i, b) in b.into_iter().enumerate() {
12        ns.add_demand_supply(i, b);
13    }
14    for (s, t, l, u, c) in edges {
15        ns.add_edge(s, t, l, u, c);
16    }
17    let sol = ns.solve_minimize();
18    if let Some(sol) = sol {
19        iter_print!(writer, sol.cost);
20        for i in 0..n {
21            iter_print!(writer, sol.potentials[i]);
22        }
23        for i in 0..m {
24            iter_print!(writer, sol.flows[i]);
25        }
26    } else {
27        iter_print!(writer, "infeasible");
28    }
29}
Source

pub fn add_edge(&mut self, from: usize, to: usize, lower: F, upper: F, cost: C)

Add edge with lower/upper capacity and cost

Examples found in repository?
crates/library_checker/src/graph/assignment.rs (line 15)
6pub fn assignment(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, a: [[i64; n]; n]);
10    let mut ns = NetworkSimplex::<i64, i64>::new(n * 2);
11    for (i, a) in a.iter().enumerate() {
12        ns.add_supply(i, 1);
13        ns.add_demand(i + n, 1);
14        for (j, &a) in a.iter().enumerate() {
15            ns.add_edge(i, j + n, 0, 1, a);
16        }
17    }
18    let sol = ns.solve_minimize();
19    if let Some(sol) = sol {
20        iter_print!(writer, sol.cost);
21        let p = (0..n * n)
22            .filter(|&eid| sol.flows[eid] != 0)
23            .map(|eid| eid % n);
24        iter_print!(writer, @it p);
25    } else {
26        iter_print!(writer, "infeasible");
27    }
28}
More examples
Hide additional examples
crates/library_checker/src/graph/min_cost_b_flow.rs (line 15)
6pub fn min_cost_b_flow(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, m, b: [i64; n], edges: [(usize, usize, i64, i64, i128); m]);
10    let mut ns = NetworkSimplex::<i64, i128>::new(n);
11    for (i, b) in b.into_iter().enumerate() {
12        ns.add_demand_supply(i, b);
13    }
14    for (s, t, l, u, c) in edges {
15        ns.add_edge(s, t, l, u, c);
16    }
17    let sol = ns.solve_minimize();
18    if let Some(sol) = sol {
19        iter_print!(writer, sol.cost);
20        for i in 0..n {
21            iter_print!(writer, sol.potentials[i]);
22        }
23        for i in 0..m {
24            iter_print!(writer, sol.flows[i]);
25        }
26    } else {
27        iter_print!(writer, "infeasible");
28    }
29}
Source

pub fn set_bucket_size(&mut self, size: usize)

Source

pub fn set_minor_limit(&mut self, limit: usize)

Source

pub fn solve_minimize(self) -> Option<NetworkSimplexSolution<F, C>>

Examples found in repository?
crates/library_checker/src/graph/assignment.rs (line 18)
6pub fn assignment(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, a: [[i64; n]; n]);
10    let mut ns = NetworkSimplex::<i64, i64>::new(n * 2);
11    for (i, a) in a.iter().enumerate() {
12        ns.add_supply(i, 1);
13        ns.add_demand(i + n, 1);
14        for (j, &a) in a.iter().enumerate() {
15            ns.add_edge(i, j + n, 0, 1, a);
16        }
17    }
18    let sol = ns.solve_minimize();
19    if let Some(sol) = sol {
20        iter_print!(writer, sol.cost);
21        let p = (0..n * n)
22            .filter(|&eid| sol.flows[eid] != 0)
23            .map(|eid| eid % n);
24        iter_print!(writer, @it p);
25    } else {
26        iter_print!(writer, "infeasible");
27    }
28}
More examples
Hide additional examples
crates/library_checker/src/graph/min_cost_b_flow.rs (line 17)
6pub fn min_cost_b_flow(reader: impl Read, mut writer: impl Write) {
7    let s = read_all_unchecked(reader);
8    let mut scanner = Scanner::new(&s);
9    scan!(scanner, n, m, b: [i64; n], edges: [(usize, usize, i64, i64, i128); m]);
10    let mut ns = NetworkSimplex::<i64, i128>::new(n);
11    for (i, b) in b.into_iter().enumerate() {
12        ns.add_demand_supply(i, b);
13    }
14    for (s, t, l, u, c) in edges {
15        ns.add_edge(s, t, l, u, c);
16    }
17    let sol = ns.solve_minimize();
18    if let Some(sol) = sol {
19        iter_print!(writer, sol.cost);
20        for i in 0..n {
21            iter_print!(writer, sol.potentials[i]);
22        }
23        for i in 0..m {
24            iter_print!(writer, sol.flows[i]);
25        }
26    } else {
27        iter_print!(writer, "infeasible");
28    }
29}

Trait Implementations§

Source§

impl<F: Clone, C: Clone> Clone for NetworkSimplex<F, C>

Source§

fn clone(&self) -> NetworkSimplex<F, C>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<F: Debug, C: Debug> Debug for NetworkSimplex<F, C>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<F, C> Freeze for NetworkSimplex<F, C>

§

impl<F, C> RefUnwindSafe for NetworkSimplex<F, C>

§

impl<F, C> Send for NetworkSimplex<F, C>
where F: Send, C: Send,

§

impl<F, C> Sync for NetworkSimplex<F, C>
where F: Sync, C: Sync,

§

impl<F, C> Unpin for NetworkSimplex<F, C>
where F: Unpin, C: Unpin,

§

impl<F, C> UnwindSafe for NetworkSimplex<F, C>
where F: UnwindSafe, C: UnwindSafe,

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.