pub struct SwapSchedule<V, Id>{
pub root: V,
pub steps: Vec<ScheduledSwapStep<V, Id>>,
}Expand description
Pre-computed swap schedule for swap_site_indices.
The schedule is derived purely from graph structure plus current and target site assignments. It contains no tensor data and can therefore be built, inspected, and unit-tested without performing any tensor contractions.
Related types:
ScheduledSwapStepis one local two-site update in this schedule.SwapOptionsaffects execution of the schedule, but not its contents.
§Examples
use std::collections::HashMap;
use tensor4all_treetn::{NodeNameNetwork, SwapSchedule};
let mut topology = NodeNameNetwork::new();
topology.add_node("A".to_string()).unwrap();
topology.add_node("B".to_string()).unwrap();
topology.add_edge(&"A".to_string(), &"B".to_string()).unwrap();
let current = HashMap::from([("s0".to_string(), "A".to_string())]);
let target = HashMap::from([("s0".to_string(), "B".to_string())]);
let root = "A".to_string();
let schedule = SwapSchedule::build(&topology, ¤t, &target, &root).unwrap();
assert_eq!(schedule.root, "A");
assert_eq!(schedule.steps.len(), 1);
assert_eq!(schedule.steps[0].node_a, "A");
assert_eq!(schedule.steps[0].node_b, "B");Fields§
§root: VRoot used for the base Euler sweep and initial canonicalization.
steps: Vec<ScheduledSwapStep<V, Id>>Fully expanded sequence of swap steps.
Implementations§
Source§impl<V, Id> SwapSchedule<V, Id>
impl<V, Id> SwapSchedule<V, Id>
Sourcepub fn build(
topology: &NodeNameNetwork<V>,
current_assignment: &HashMap<Id, V>,
target_assignment: &HashMap<Id, V>,
root: &V,
) -> Result<Self>
pub fn build( topology: &NodeNameNetwork<V>, current_assignment: &HashMap<Id, V>, target_assignment: &HashMap<Id, V>, root: &V, ) -> Result<Self>
Build a swap schedule from topology plus current and target assignments.
The returned schedule is a pure graph computation. It simulates site positions through repeated Euler-tour sweeps, emits only edges where at least one targeted site index crosses, and records any required canonical-center transport between non-adjacent emitted swap steps.
§Arguments
topology- Tree topology whose nodes are named byV.current_assignment- Current node for every site index ID in the network.target_assignment- Partial target map; indices not listed keep their current side.root- Sweep root and assumed initial canonical center.
§Returns
A SwapSchedule containing the ordered local updates needed to realize target_assignment.
§Errors
Returns an error if root is missing, an index ID in target_assignment
is unknown, a referenced node is missing from topology, no tree path
exists between required nodes, or the simulated sweeps fail to satisfy
the requested target assignment within the tree-diameter pass bound.
Trait Implementations§
Source§impl<V: Clone, Id> Clone for SwapSchedule<V, Id>
impl<V: Clone, Id> Clone for SwapSchedule<V, Id>
Source§fn clone(&self) -> SwapSchedule<V, Id>
fn clone(&self) -> SwapSchedule<V, Id>
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl<V, Id> Freeze for SwapSchedule<V, Id>where
V: Freeze,
impl<V, Id> RefUnwindSafe for SwapSchedule<V, Id>where
V: RefUnwindSafe,
Id: RefUnwindSafe,
impl<V, Id> Send for SwapSchedule<V, Id>
impl<V, Id> Sync for SwapSchedule<V, Id>
impl<V, Id> Unpin for SwapSchedule<V, Id>
impl<V, Id> UnsafeUnpin for SwapSchedule<V, Id>where
V: UnsafeUnpin,
impl<V, Id> UnwindSafe for SwapSchedule<V, Id>where
V: UnwindSafe,
Id: UnwindSafe,
Blanket Implementations§
§impl<U> As for U
impl<U> As for U
§fn as_<T>(self) -> Twhere
T: CastFrom<U>,
fn as_<T>(self) -> Twhere
T: CastFrom<U>,
self to type T. The semantics of numeric casting with the as operator are followed, so <T as As>::as_::<U> can be used in the same way as T as U for numeric conversions. Read moreSource§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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> DistributionExt for Twhere
T: ?Sized,
impl<T> DistributionExt for Twhere
T: ?Sized,
fn rand<T>(&self, rng: &mut (impl Rng + ?Sized)) -> Twhere
Self: Distribution<T>,
§impl<T> DistributionExt for Twhere
T: ?Sized,
impl<T> DistributionExt for Twhere
T: ?Sized,
fn rand<T>(&self, rng: &mut (impl Rng + ?Sized)) -> Twhere
Self: Distribution<T>,
§impl<T> DistributionExt for Twhere
T: ?Sized,
impl<T> DistributionExt for Twhere
T: ?Sized,
fn rand<T>(&self, rng: &mut (impl Rng + ?Sized)) -> Twhere
Self: Distribution<T>,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more