pub struct TreePath<const N: usize>(pub Seq<usize>);Expand description
Path from the current node to the leaf of the tree
N is the maximum number of children of a tree node
TreePath.index(i) returns the i-th element of the path
Tuple Fields§
§0: Seq<usize>Implementations§
Source§impl<const N: usize> TreePath<N>
impl<const N: usize> TreePath<N>
Sourcepub open spec fn inv(self) -> bool
pub open spec fn inv(self) -> bool
{ forall |i: int| 0 <= i < self.len() ==> Self::elem_inv(#[trigger] self.index(i)) }Sourcepub broadcast proof fn inv_property(self)
pub broadcast proof fn inv_property(self)
requires
#[trigger] self.inv(),ensuresforall |i: int| 0 <= i < self.len() ==> #[trigger] Self::elem_inv(self.index(i)),Sourcepub broadcast proof fn index_satisfies_elem_inv(self, i: int)
pub broadcast proof fn index_satisfies_elem_inv(self, i: int)
requires
self.inv(),0 <= i < self.len(),ensures#[trigger] Self::elem_inv(self.index(i)),Sourcepub broadcast proof fn empty_satisfies_inv(self)
pub broadcast proof fn empty_satisfies_inv(self)
requires
#[trigger] self.is_empty(),ensures#[trigger] self.inv(),Sourcepub broadcast proof fn drop_head_property(self)
pub broadcast proof fn drop_head_property(self)
requires
!#[trigger] self.is_empty(),ensuresself.0.drop_first().len() == self.len() - 1,forall |i: int| {
0 <= i < self.0.drop_first().len()
==> #[trigger] self.0.drop_first().index(i) == self.index(i + 1)
},Sourcepub broadcast proof fn drop_last_property(self)
pub broadcast proof fn drop_last_property(self)
requires
!#[trigger] self.is_empty(),ensuresself.0.drop_last().len() == self.len() - 1,forall |i: int| {
0 <= i < self.0.drop_last().len()
==> #[trigger] self.0.drop_last().index(i) == self.index(i)
},Sourcepub open spec fn pop_head(self) -> (usize, TreePath<N>)
pub open spec fn pop_head(self) -> (usize, TreePath<N>)
recommends
!self.is_empty(),{ (self.index(0), TreePath(self.0.drop_first())) }Sourcepub broadcast proof fn pop_head_preserves_inv(self)
pub broadcast proof fn pop_head_preserves_inv(self)
requires
#[trigger] self.inv(),!self.is_empty(),ensuresSelf::elem_inv(self.pop_head().0),self.pop_head().1.inv(),Sourcepub broadcast proof fn pop_head_decreases_len(self)
pub broadcast proof fn pop_head_decreases_len(self)
requires
self.inv(),!self.is_empty(),ensures#[trigger] self.pop_head().1.len() == self.len() - 1,Sourcepub broadcast proof fn pop_head_head_satisfies_inv(self)
pub broadcast proof fn pop_head_head_satisfies_inv(self)
requires
self.inv(),!self.is_empty(),ensures#[trigger] Self::elem_inv(self.pop_head().0),Sourcepub broadcast proof fn pop_head_property(self)
pub broadcast proof fn pop_head_property(self)
requires
self.inv(),!self.is_empty(),ensures#[trigger] self.pop_head().0 == self.index(0),self.pop_head().1.len() == self.len() - 1,Self::elem_inv(self.pop_head().0),self.pop_head().1.inv(),Sourcepub open spec fn pop_tail(self) -> (usize, TreePath<N>)
pub open spec fn pop_tail(self) -> (usize, TreePath<N>)
recommends
!self.is_empty(),{ (self.index(self.len() as int - 1), TreePath(self.0.drop_last())) }Sourcepub broadcast proof fn pop_tail_preserves_inv(self)
pub broadcast proof fn pop_tail_preserves_inv(self)
requires
#[trigger] self.inv(),!self.is_empty(),ensuresSelf::elem_inv(self.pop_tail().0),self.pop_tail().1.inv(),Sourcepub broadcast proof fn pop_tail_decreases_len(self)
pub broadcast proof fn pop_tail_decreases_len(self)
requires
self.inv(),!self.is_empty(),ensures#[trigger] self.pop_tail().1.len() == self.len() - 1,Sourcepub broadcast proof fn pop_tail_tail_satisfies_inv(self)
pub broadcast proof fn pop_tail_tail_satisfies_inv(self)
requires
self.inv(),!self.is_empty(),ensures#[trigger] Self::elem_inv(self.pop_tail().0),Sourcepub broadcast proof fn pop_tail_property(self)
pub broadcast proof fn pop_tail_property(self)
requires
self.inv(),!self.is_empty(),ensures#[trigger] self.pop_tail().0 == self.index(self.len() as int - 1),self.pop_tail().1.len() == self.len() - 1,Self::elem_inv(self.pop_tail().0),self.pop_tail().1.inv(),Sourcepub open spec fn push_head(self, hd: usize) -> TreePath<N>
pub open spec fn push_head(self, hd: usize) -> TreePath<N>
recommends
0 <= hd < N,{ TreePath(seq![hd].add(self.0)) }Sourcepub proof fn push_head_property_len(self, hd: usize)
pub proof fn push_head_property_len(self, hd: usize)
requires
self.inv(),0 <= hd < N,ensuresself.push_head(hd).len() == self.len() + 1,Sourcepub proof fn push_head_property_index(self, hd: usize)
pub proof fn push_head_property_index(self, hd: usize)
requires
self.inv(),0 <= hd < N,ensuresself.push_head(hd).index(0) == hd,forall |i: int| 0 <= i < self.len() ==> self.push_head(hd).index(i + 1) == self.index(i),Sourcepub proof fn push_head_preserves_inv(self, hd: usize)
pub proof fn push_head_preserves_inv(self, hd: usize)
requires
self.inv(),0 <= hd < N,ensuresself.push_head(hd).inv(),Sourcepub broadcast proof fn push_head_property(self, hd: usize)
pub broadcast proof fn push_head_property(self, hd: usize)
requires
self.inv(),0 <= hd < N,ensures#[trigger] self.push_head(hd).inv(),self.push_head(hd).len() == self.len() + 1,self.push_head(hd).index(0) == hd,forall |i: int| 0 <= i < self.len() ==> self.push_head(hd).index(i + 1) == self.index(i),Sourcepub open spec fn push_tail(self, val: usize) -> TreePath<N>
pub open spec fn push_tail(self, val: usize) -> TreePath<N>
recommends
0 <= val < N,{ TreePath(self.0.push(val)) }Sourcepub proof fn push_tail_property_len(self, val: usize)
pub proof fn push_tail_property_len(self, val: usize)
requires
self.inv(),0 <= val < N,ensuresself.push_tail(val).len() == self.len() + 1,Sourcepub proof fn push_tail_property_index(self, val: usize)
pub proof fn push_tail_property_index(self, val: usize)
requires
self.inv(),0 <= val < N,ensuresself.push_tail(val).index(self.len() as int) == val,forall |i: int| {
0 <= i < self.len() ==> #[trigger] self.push_tail(val).index(i) == self.index(i)
},Sourcepub proof fn push_tail_preserves_inv(self, val: usize)
pub proof fn push_tail_preserves_inv(self, val: usize)
requires
self.inv(),0 <= val < N,ensuresself.push_tail(val).inv(),Sourcepub broadcast proof fn push_tail_property(self, val: usize)
pub broadcast proof fn push_tail_property(self, val: usize)
requires
self.inv(),0 <= val < N,ensures#[trigger] self.push_tail(val).inv(),self.push_tail(val).len() == self.len() + 1,self.push_tail(val).index(self.len() as int) == val,forall |i: int| {
0 <= i < self.len() ==> #[trigger] self.push_tail(val).index(i) == self.index(i)
},Sourcepub open spec fn new(path: Seq<usize>) -> TreePath<N>
pub open spec fn new(path: Seq<usize>) -> TreePath<N>
recommends
forall |i: int| 0 <= i < path.len() ==> Self::elem_inv(#[trigger] path[i]),{ TreePath(path) }Sourcepub broadcast proof fn new_preserves_inv(path: Seq<usize>)
pub broadcast proof fn new_preserves_inv(path: Seq<usize>)
requires
forall |i: int| 0 <= i < path.len() ==> Self::elem_inv(#[trigger] path[i]),ensures#[trigger] Self::new(path).inv(),Sourcepub broadcast proof fn new_empty_preserves_inv()
pub broadcast proof fn new_empty_preserves_inv()
ensures
#[trigger] Self::new(Seq::empty()).inv(),Auto Trait Implementations§
impl<const N: usize> Freeze for TreePath<N>
impl<const N: usize> RefUnwindSafe for TreePath<N>
impl<const N: usize> Send for TreePath<N>
impl<const N: usize> Sync for TreePath<N>
impl<const N: usize> Unpin for TreePath<N>
impl<const N: usize> UnwindSafe for TreePath<N>
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