21 #include "SheafSystem/ij_adjacency_implicit_index_space_iterator.h" 23 #include "SheafSystem/assert_contract.h" 24 #include "SheafSystem/ij_adjacency_index_space_interval.h" 25 #include "SheafSystem/index_space_family.h" 45 ensure(!is_attached());
64 ensure((*
this) == xother);
77 require(conforms_to_state(xid_spaces, xindex));
81 attach_to(xid_spaces, xindex);
86 ensure(is_attached());
87 ensure(&id_spaces() == &xid_spaces);
88 ensure(index() == xindex);
97 const std::string& xname)
101 require(conforms_to_state(xid_spaces, xname));
105 attach_to(xid_spaces, xname);
110 ensure(is_attached());
111 ensure(&id_spaces() == &xid_spaces);
112 ensure(name() == xname);
131 _i_ct = xother.
_i_ct;
132 _j_ct = xother.
_j_ct;
136 (void) implicit_index_space_iterator::operator=(xother);
146 ensure((*
this) == xother);
179 ensure(is_basic_query);
196 ensure(is_basic_query);
213 ensure(is_basic_query);
230 ensure(is_basic_query);
265 require(is_ancestor_of(&xother));
272 (void) this->
operator=(lother);
277 ensure((*
this) == xother);
290 require(is_ancestor_of(&xother));
295 if(result && is_attached())
300 result = result && (_hub_begin == lother.
_hub_begin);
301 result = result && (_j_size == lother.
_j_size);
302 result = result && (_i_ct == lother.
_i_ct);
303 result = result && (_j_ct == lother.
_j_ct);
304 result = result && (_i == lother.
_i);
305 result = result && (_j == lother.
_j);
332 ensure(is_same_type(result));
333 ensure(*result == *
this);
357 require(is_attached());
362 define_old_variable(
pod_type old_pod = pod());
363 define_old_variable(
pod_type old_hub_pod = hub_pod());
386 _hub_pod = (_i * _j_size) + _hub_begin;
400 ensure(is_done() || pod() != old_pod);
401 ensure(is_done() || hub_pod() != old_hub_pod);
414 require(is_attached());
423 _hub_pod = _hub_begin;
455 require(conforms_to_state(xhost, xlocal_id));
462 _local_id = xlocal_id;
470 _j_size = lhost->
j_size();
479 ensure(is_attached());
480 ensure(&host() == &xhost);
501 ensure(is_basic_query);
546 if(invariant_check())
554 disable_invariant_check();
560 enable_invariant_check();
size_type j_ct() const
The number of adjacent zones in the j direction.
size_type _j_size
The number of zones in the j direction.
pod_type _hub_begin
The hub id of the first zone in the adjacency list.
An abstract iterator over the ids of an id space.
An implementation of index_space_interval for an interval of implicit id spaces for the adjacency of ...
void adjacent_zones(pod_type xlocal_id, pod_type &xzone_hub_begin, size_type &xi_ct, size_type &xj_ct) const
Compute the hub id of the fist adjacent zone and the number of adjacent zones in each direction for i...
ij_adjacency_implicit_index_space_iterator & operator=(const ij_adjacency_implicit_index_space_iterator &xother)
Assignment operator.
virtual pod_type family_scope(pod_type xlocal_id) const =0
Id relative to the id space family equivalent to the local id xlocal_id.
virtual bool is_ancestor_of(const any *other) const
Conformance test; true if other conforms to this.
virtual bool operator==(const index_space_iterator &xother) const
True if this is equivalent to xother.
ij_adjacency_implicit_index_space_iterator()
Default constructor.
Abstract base class with useful features for all objects.
An implementation of implicit_index_space_iterator for an implicit id space in an ij_adjacency_index_...
size_type j_size() const
The number of zones in the j direction.
virtual bool conforms_to_state(const index_space_collection &xhost, pod_type xlocal_id) const
True if this conforms to the handle type required by the state with local scope id xlocal_id in the h...
pod_type hub_begin() const
The hub id of the first zone in the adjacency list.
size_type _i_ct
The number of adjacent zones in the i direction.
unsigned long size_type
An unsigned integral type used to represent sizes and capacities.
pod_type _i
The current index in the i direction.
virtual void next()
Makes item() the next id in the iteration.
size_type j_size() const
The number of zones in the j direction.
pod_type _j
The current index in the j direction.
A collection of id space states. This is a virtual class with provides an interface for accessing the...
virtual bool contains(pod_type xlocal_id) const =0
True if this collection contains the id space with local id xlocal_id.
virtual bool invariant() const
Class invariant.
virtual ij_adjacency_implicit_index_space_iterator * clone() const
Virtual constructor, makes a new instance of the same type as this. If the iterator is attached...
virtual bool is_attached() const
True if this iterator is attached to a state.
virtual bool invariant() const
Class invariant.
virtual void reset()
Restarts the iteration.
virtual ~ij_adjacency_implicit_index_space_iterator()
Destructor.
virtual void attach_to(const index_space_collection &xhost, pod_type xlocal_id)
Attach to the state with local scope id, xlocal_id in the host id space collection xhost...
Factory and container for a family of id spaces.
pod_index_type pod_type
The "plain old data" index type for this.
size_type _j_ct
The number of adjacent zones in the j direction.
Namespace for the fiber_bundles component of the sheaf system.
virtual bool operator==(const index_space_iterator &xother) const
True if this is equivalent to xother.
size_type i_ct() const
The number of adjacent zones in the i direction.