21 #include "SheafSystem/st4_e2.impl.h"    23 #include "SheafSystem/abstract_poset_member.impl.h"    24 #include "SheafSystem/assert_contract.h"    25 #include "SheafSystem/at0.h"    26 #include "SheafSystem/at1_space.h"    27 #include "SheafSystem/stp_space.h"    28 #include "SheafSystem/fiber_bundles_namespace.h"    29 #include "SheafSystem/schema_poset_member.h"    30 #include "SheafSystem/wsv_block.h"   136   _row_dofs = xrow_dofs;
   148 fiber_bundle::st4_e2_lite::
   164 fiber_bundle::st4_e2_lite::
   283   require(precondition_of(e2_lite::static_tp_prototype(xp)));
   287   const tp_lite& result = e2_lite::static_tp_prototype(xp);
   291   ensure(postcondition_of(e2_lite::static_tp_prototype(xp)));
   304   require(precondition_of(e2_lite::static_atp_prototype(xp)));
   308   const atp_lite& result = e2_lite::static_atp_prototype(xp);
   312   ensure(postcondition_of(e2_lite::static_atp_prototype(xp)));
   325   require(precondition_of(e2_lite::static_stp_prototype(xp)));
   329   const stp_lite& result = e2_lite::static_stp_prototype(xp);
   333   ensure(postcondition_of(e2_lite::static_stp_prototype(xp)));
   370   const string& result = static_class_name();
   374   ensure(!result.empty());
   389   static const string result(
"st4_e2_lite");
   393   ensure(!result.empty());
   415   ensure(is_same_type(*result));
   439   require(&xother != 0);
   445   bool result = 
dynamic_cast<const st4_e2_lite*
>(&xother) != 0;
   458   if(invariant_check())
   462     disable_invariant_check();
   466     invariance(st4_lite::invariant());
   472     enable_invariant_check();
   518   static const poset_path result(standard_schema_poset_name(), 
"st4_e2_schema");
   540   string lmember_names = 
"xxxx DOUBLE false ";
   541   lmember_names       += 
"xxxy DOUBLE false ";
   542   lmember_names       += 
"xxyy DOUBLE false ";
   543   lmember_names       += 
"xyyy DOUBLE false ";
   544   lmember_names       += 
"yyyy DOUBLE false ";
   547                               standard_schema_path().member_name(),
   548                               st4::standard_schema_path(),
   577   require(!xhost_path.
empty());
   580   require(xschema_path.
full());
   582   require(schema_poset_member::conforms_to(xns, xschema_path, standard_schema_path()));
   583   require(schema_poset_member::row_dof_ct(xns, xschema_path, xauto_access) == 5);
   593     host_type::new_table(xns, xhost_path, xschema_path, 4, xvector_space_path, xauto_access);
   597   ensure(xns.
owns(result, xauto_access));
   598   ensure(result.path(
true) == xhost_path);
   599   ensure(result.state_is_not_read_accessible());
   600   ensure(result.schema(
true).path(xauto_access) == xschema_path);
   602   ensure(result.factor_ct(
true) == 5);
   603   ensure(result.d(
true) == 5);
   605   ensure(result.p(
true) == 4);
   606   ensure(result.dd(
true) == 2);
   607   ensure(result.vector_space_path(
true) == xvector_space_path);
   625   require(xsuffix.empty() || poset_path::is_valid_name(xsuffix));
   626   require(standard_host_is_available<st4_e2>(xns, xsuffix, xauto_access));
   636   poset_path lvector_space_path = vector_space_type::standard_host(xns, xsuffix, xauto_access).
path(
true);
   638   poset_path lpath(standard_host_path<st4_e2>(xsuffix));
   647     result_ptr = &new_host(xns, lpath, standard_schema_path(), lvector_space_path, xauto_access);
   654   ensure(xns.
owns(result, xauto_access));
   655   ensure(result.
path(
true) == standard_host_path<st4_e2>(xsuffix));
   657   ensure(result.
schema(
true).
path(xauto_access) == standard_schema_path());
   660   ensure(result.
d(
true) == 5);
   661   ensure(result.
scalar_space_path(
true) == standard_host_path<vector_space_type::scalar_type>(xsuffix) );
   662   ensure(result.
p(
true) == 4);
   663   ensure(result.
dd(
true) == 2);
   664   ensure(result.
vector_space_path(
true) == standard_host_path<vector_space_type>(xsuffix) );
   707   attach_to_state(xhost, xhub_id);
   713   ensure(index() == xhub_id);
   714   ensure(is_attached());
   728   attach_to_state(xhost, xid.
hub_pod());
   734   ensure(index() ==~ xid);
   735   ensure(is_attached());
   746   require(!xname.empty());
   751   attach_to_state(xhost, xname);
   757   ensure(name() == xname);
   758   ensure(is_attached());
   768   require(xother != 0);
   772   attach_to_state(xother);
   777   ensure(is_attached());
   778   ensure(is_same_state(xother));
   788   require(precondition_of(new_jim_state(xhost, 0, 
false, xauto_access)));
   792   new_jim_state(xhost, 0, 
false, xauto_access);
   796   ensure(postcondition_of(new_jim_state(xhost, 0, 
false, xauto_access)));
   811   require(precondition_of(new_jim_state(&xhost, 0, 
false, xauto_access)));
   815   new_jim_state(&xhost, 0, 
false, xauto_access);
   831   ensure(postcondition_of(new_jim_state(&xhost, 0, 
false, xauto_access)));
   845   require(state_is_read_write_accessible());
   853   ensure_for_all(i, 0, d(), component(i) == xrdt.
components[i]);
   868   require(is_ancestor_of(&xother));
   869   require(precondition_of(attach_to_state(&xother)));
   873   attach_to_state(&xother);
   877   ensure(postcondition_of(attach_to_state(&xother)));
   891   require(precondition_of(attach_to_state(&xother)));
   895   attach_to_state(&xother);
   899   ensure(postcondition_of(attach_to_state(&xother)));
   959   require(state_is_read_write_accessible());
   963   put_component(0, xcomp);
   975 fiber_bundle::st4_e2::
   991 fiber_bundle::st4_e2::
  1057   require(precondition_of(e2::new_tp(vector_space(xauto_access), xp)));
  1061   tp* result = e2::new_tp(vector_space(xauto_access), xp);
  1065   ensure(postcondition_of(e2::new_tp(vector_space(xauto_access), xp)));
  1078   require(precondition_of(e2::new_atp(vector_space(xauto_access), xp)));
  1082   atp* result = e2::new_atp(vector_space(xauto_access), xp);
  1086   ensure(postcondition_of(e2::new_atp(vector_space(xauto_access), xp)));
  1099   require(precondition_of(e2::new_stp(vector_space(xauto_access), xp)));
  1103   stp* result = e2::new_stp(vector_space(xauto_access), xp);
  1107   ensure(postcondition_of(e2::new_stp(vector_space(xauto_access), xp)));
  1133   const string& result = static_class_name();
  1137   ensure(!result.empty());
  1152   static const string result(
"st4_e2");
  1156   ensure(!result.empty());
  1178   ensure(result != 0);
  1203   require(xother != 0);
  1207   bool result = 
dynamic_cast<const st4_e2*
>(xother) != 0;
  1226   if(invariant_check())
  1230     disable_invariant_check();
  1234     invariance(st4::invariant());
  1238     invariance((state_is_read_accessible() ? dd() == 2 : 
true));
  1242     enable_invariant_check();
 virtual void get_read_write_access(bool xrelease_read_only_access=false)
Get read write access to the state associated with this. If release_read_only_access is requested...
virtual const std::string & class_name() const
The name of this class. 
virtual poset_path path(bool xauto_access=true) const
The path of this poset. 
bool state_is_auto_read_write_accessible(bool xauto_access) const
True if state is auto accessible for read and write, that is, if the state is already accessible for ...
virtual atp * new_atp(int xp, bool xauto_access) const
Virtual constructor for antisymmetric tensors of degree xp over vector space xvector_space. 
A symmetric tensor of degree p over an abstract vector space. 
bool full() const
True if both poset name and member name are not empty. 
An antisymmetric tensor of degree p. 
virtual const stp_lite & stp_prototype(int xp) const
Prototype for symmetric tensors of degree xp over this vector space. 
static int d(const namespace_poset &xns, int xp, const poset_path &xvector_space_path, bool xauto_access)
The tensor dimension implied by tensor degree xp and the dimension of the domain vector space specifi...
bool invariant() const
Class invariant. 
virtual const std::string & class_name() const
The name of this class. 
poset_path path(bool xauto_access=true) const
A path to this component. 
virtual void put_components(dof_type xcomp)
Sets the value of the component to xcomp. 
bool conforms_to(const schema_poset_member &xother) const
True if the dofs defined by this agree in type and in order with the dofs defined by xother...
The default name space; a poset which contains other posets as members. 
bool state_is_read_accessible() const
True if this is attached and if the state is accessible for read or access control is disabled...
bool path_is_auto_read_accessible(const poset_path &xpath, bool xauto_access) const
True if the state referred to xpath exists and is auto read accessible. 
The standard fiber bundles name space; extends the standard sheaves namespace by defining base space...
poset_path vector_space_path() const
The path of the underlying vector space. 
st4_e2()
Default constructor. 
bool contains_poset_member(pod_index_type xposet_hub_id, pod_index_type xmember_hub_id, bool xauto_access=true) const
True if this contains a poset with hub id xposet_hub_id which contains a member with hub id xmember_h...
A client handle for a general, abstract partially order set. 
st4_e2 & operator=(const row_dofs_type &xrdt)
Assignment to an instance of the associated row dofs type. 
A path defined by a poset name and a member name separated by a forward slash ('/'). For example: "cell_definitions/triangle". 
bool invariant() const
Class invariant. 
virtual void * row_dofs()
The row dofs for this instance (mutable version). 
poset_state_handle & member_poset(pod_index_type xhub_id, bool xauto_access=true) const
The poset_state_handle object referred to by hub id xhub_id. 
virtual st4_e2_lite * clone() const
Virtual constructor, makes a new instance of the same type as this. 
static const std::string & static_class_name()
The name of this class. 
T::row_dofs_type & row_dofs(T &x0)
The row dofs pod type for x0 (mutable version). 
An antisymmetric tensor of degree p over an abstract vector space (volatile version). 
static int d(const namespace_poset &xns, int xp, const poset_path &xvector_space_path, bool xauto_access)
The tensor dimension implied by tensor degree xp and the dimension of the domain vector space specifi...
row_dofs_type _row_dofs
Row_dofs_type. 
A general tensor of "degree" p and given "variance" over an abstract vector space. 
Abstract base class with useful features for all volatile objects. 
Abstract base class with useful features for all objects. 
st4_e2_lite()
Default constructor. 
virtual st4_e2 * clone() const
Make a new handle, no state instance of current. 
virtual schema_poset_member & schema()
The schema for this poset (mutable version). 
virtual int dd() const
Dimension of the underlying vector space. 
bool state_is_read_write_accessible() const
True if this is attached and if the state is accessible for read and write or access control is disab...
virtual const atp_lite & atp_prototype(int xp) const
Prototype for antisymmetric tensors of degree xp over this vector space. 
bool owns(const poset_state_handle &xposet, bool xauto_access) const
True if and only if this contains the poset xposet. synonym for contains_poset(xposet.poset_path(true), xauto_access) 
static host_type & standard_host(namespace_type &xns, const std::string &xsuffix, bool xauto_access)
The host with path standard_host_path<st4_e2>(xsuffix). Returns the host if it already exists...
virtual void detach_from_state()
Detach this handle from its state, if any. 
An index within the external ("client") scope of a given id space. 
static const std::string & static_class_name()
The name of this class. 
virtual ~st4_e2_lite()
Destructor. 
bool is_ancestor_of(const any *xother) const
True if xother conforms to current. 
static void make_standard_schema(namespace_poset &xns)
Creates the standard schema for this class in namespace xns. 
bool contains_path(const poset_path &xpath, bool xauto_access=true) const
True if this contains the poset or poset member specified by xpath. 
static host_type & new_host(namespace_type &xns, const poset_path &xhost_path, const poset_path &xschema_path, const poset_path &xvector_space_path, bool xauto_access)
Creates a new host table for members of this type. The poset is created in namespace xns with path xh...
virtual bool contains_member(pod_index_type xmbr_hub_id, bool xauto_access=true) const
True if some version of this poset contains poset member with hub id xmbr_hub_id. ...
int p(int xd, int xdd) const
Tensor degree as a function of tensor dimension xd and domain dimension xdd. 
virtual bool is_ancestor_of(const any_lite &xother) const
Conformance test; true if other conforms to this. 
A symmetric rank 3 tensor over a 3D Euclidean vector space (persistent version). 
bool empty() const
True if both poset name and member name are empty. 
virtual void release_access(bool xall=false) const
Release access. If xall is true, release all levels of access. Otherwise, release one level of access...
virtual tp * new_tp(int xp, bool xauto_access) const
Virtual constructor for general tensors of degree xp over vector space xvector_space. 
A general tensor of degree p over an abstract vector space (volatile version). Volatile version does ...
bool contains_poset(pod_index_type xhub_id, bool xauto_access=true) const
True if this contains a poset with hub id xhub_id.. 
A symmetric rank 4 tensor over a Euclidean vector space of dimension 3. (volatile version)...
bool path_is_auto_read_available(const poset_path &xpath, bool xauto_access) const
True if the state referred to xpath does not exist or exists and is auto read accessible. 
poset_path scalar_space_path() const
The path of the underlying space of scalars. 
An abstract vector space viewed as an antisymmetric tensor space of degree 1. 
virtual const volatile_type & lite_prototype() const
Virtual constructor for the associated volatile type. 
virtual const tp_lite & tp_prototype(int xp) const
Prototype for general tensors of degree xp over this vector space. 
static int factor_ct(int xd)
Factor_ct() as a function of dimension xd. 
static const poset_path & standard_schema_path()
The path to the standard schema for this class. 
int_type pod_index_type
The plain old data index type. 
T components[5]
The components in the order: 
int dd() const
The dimension of the underlying ("domain") vector space. 
virtual stp * new_stp(int xp, bool xauto_access) const
Virtual constructor for symmetric tensors of degree xp over vector space xvector_space. 
st4_e2_lite & operator=(const st4_e2_lite &xother)
Assignment operator. 
An abstract client handle for a member of a poset. 
std::string path() const
The full path as a string. 
vd_dof_type dof_type
The type of the degrees of freedom. Note that although dof_type == value_type in this implementation...
A symmetric tensor of degree p over an abstract vector space (volatile version). 
An abstract symmetric tensor space of degree p. 
Namespace for the fiber_bundles component of the sheaf system. 
virtual volatile_type * lite_type() const
Virtual conversion to the associated volatile type. 
bool state_is_not_read_accessible() const
True if this is attached and if the state is accessible for read or if access control is disabled...
A client handle for a poset member which has been prepared for use as a schema. 
A symmetric rank 4 tensor over an abstract vector space. (volatile version). 
pod_type hub_pod() const
The pod value of this mapped to the unglued hub id space. 
SHEAF_DLL_SPEC bool isunordered_or_equals(float x1, float x2)
True if isunordered(x1, x2) or x1 == x2.