Mesh Oriented datABase  (version 5.4.1)
Array-based unstructured mesh datastructure
moab::TagInfo Class Reference

#include <TagInfo.hpp>

+ Inheritance diagram for moab::TagInfo:
+ Collaboration diagram for moab::TagInfo:

Public Member Functions

 TagInfo ()
 constructor
 TagInfo (const char *name, int size, DataType type, const void *default_value, int default_value_size)
 constructor that takes all parameters
virtual ~TagInfo ()
virtual ErrorCode release_all_data (SequenceManager *seqman, Error *error_handler, bool tag_delete_pending)=0
 Remove/clear tag data for all entities.
void set_name (const std::string &name)
 set the name of the tag
const std::string & get_name () const
 get the name of the tag
int get_default_value_size () const
 get length of default value
const void * get_default_value () const
 get the default data
bool equals_default_value (const void *data, int size=-1) const
 compare the passed value to the default value. returns false if no default value.
DataType get_data_type () const
int get_size () const
 get the size of the data in bytes
bool variable_length () const
 Check if variable-length tag.
bool check_valid_sizes (const int *sizes, int num_sizes) const
ErrorCode validate_lengths (Error *error_handler, const int *lengths, size_t num_lengths) const
virtual TagType get_storage_type () const =0
virtual ErrorCode get_data (const SequenceManager *seqman, Error *error_handler, const EntityHandle *entities, size_t num_entities, void *data) const =0
 Get tag value for passed entities.
virtual ErrorCode get_data (const SequenceManager *seqman, Error *error_handler, const Range &entities, void *data) const =0
 Get tag value for passed entities.
virtual ErrorCode get_data (const SequenceManager *seqman, Error *error_handler, const EntityHandle *entities, size_t num_entities, const void **data_ptrs, int *data_lengths) const =0
 Get tag value for passed entities.
virtual ErrorCode get_data (const SequenceManager *seqman, Error *error_handler, const Range &entities, const void **data_ptrs, int *data_lengths) const =0
 Get tag value for passed entities.
virtual ErrorCode set_data (SequenceManager *seqman, Error *error_handler, const EntityHandle *entities, size_t num_entities, const void *data)=0
 Set tag value for passed entities.
virtual ErrorCode set_data (SequenceManager *seqman, Error *error_handler, const Range &entities, const void *data)=0
 Set tag value for passed entities.
virtual ErrorCode set_data (SequenceManager *seqman, Error *error_handler, const EntityHandle *entities, size_t num_entities, void const *const *data_ptrs, const int *data_lengths)=0
 Set tag value for passed entities.
virtual ErrorCode set_data (SequenceManager *seqman, Error *error_handler, const Range &entities, void const *const *data_ptrs, const int *data_lengths)=0
 Set tag value for passed entities.
virtual ErrorCode clear_data (SequenceManager *seqman, Error *error_handler, const EntityHandle *entities, size_t num_entities, const void *value_ptr, int value_len=0)=0
 Set tag value for passed entities.
virtual ErrorCode clear_data (SequenceManager *seqman, Error *error_handler, const Range &entities, const void *value_ptr, int value_len=0)=0
 Set tag value for passed entities.
virtual ErrorCode remove_data (SequenceManager *seqman, Error *error_handler, const EntityHandle *entities, size_t num_entities)=0
 Remove/clear tag data for entities.
virtual ErrorCode remove_data (SequenceManager *seqman, Error *error_handler, const Range &entities)=0
 Remove/clear tag data for entities.
virtual ErrorCode tag_iterate (SequenceManager *seqman, Error *error_handler, Range::iterator &iter, const Range::iterator &end, void *&data_ptr, bool allocate=true)=0
 Access tag data via direct pointer into contiguous blocks.
virtual ErrorCode get_tagged_entities (const SequenceManager *seqman, Range &output_entities, EntityType type=MBMAXTYPE, const Range *intersect=0) const =0
 Get all tagged entities.
virtual ErrorCode num_tagged_entities (const SequenceManager *seqman, size_t &output_count, EntityType type=MBMAXTYPE, const Range *intersect=0) const =0
 Count all tagged entities.
virtual ErrorCode find_entities_with_value (const SequenceManager *seqman, Error *error_handler, Range &output_entities, const void *value, int value_bytes=0, EntityType type=MBMAXTYPE, const Range *intersect_entities=0) const =0
 Get all tagged entities with tag value.
virtual bool is_tagged (const SequenceManager *seqman, EntityHandle entity) const =0
 Check if entity is tagged.
virtual ErrorCode get_memory_use (const SequenceManager *seqman, unsigned long &total, unsigned long &per_entity) const =0
 Get memory use for tag data.

Static Public Member Functions

static int size_from_data_type (DataType t)

Protected Member Functions

unsigned long get_memory_use () const

Private Member Functions

 TagInfo (const TagInfo &copy)
TagInfooperator= (const TagInfo &copy)

Private Attributes

void * mDefaultValue
 stores the default data, if any
void * mMeshValue
 store the mesh value, if any
int mDefaultValueSize
 Size of mDefaultValue and mMeshValue, in bytes NOTE: These sizes differ from mDataSize in two cases: a) Variable-length tags b) Bit tags (where mDataSize is bits, not bytes.)
int mMeshValueSize
int mDataSize
 stores the size of the data for this tag
DataType dataType
 type of tag data
std::string mTagName
 stores the tag name

Detailed Description


Constructor & Destructor Documentation

moab::TagInfo::TagInfo ( ) [inline]

constructor

Definition at line 19 of file TagInfo.hpp.

moab::TagInfo::TagInfo ( const char *  name,
int  size,
DataType  type,
const void *  default_value,
int  default_value_size 
)

constructor that takes all parameters

Definition at line 11 of file TagInfo.cpp.

References mDefaultValue, mDefaultValueSize, and mTagName.

    : mDefaultValue( NULL ), mMeshValue( NULL ), mDefaultValueSize( default_value_size ), mMeshValueSize( 0 ),
      mDataSize( size ), dataType( type )
{
    if( default_value )
    {
        mDefaultValue = malloc( mDefaultValueSize );
        memcpy( mDefaultValue, default_value, mDefaultValueSize );
    }
    if( name ) mTagName = name;
}
moab::TagInfo::~TagInfo ( ) [virtual]

Definition at line 23 of file TagInfo.cpp.

References mDefaultValue, and mDefaultValueSize.

moab::TagInfo::TagInfo ( const TagInfo copy) [private]

Member Function Documentation

bool moab::TagInfo::check_valid_sizes ( const int *  sizes,
int  num_sizes 
) const

Definition at line 60 of file TagInfo.cpp.

References get_data_type(), size, size_from_data_type(), and moab::sum().

{
    const unsigned size = size_from_data_type( get_data_type() );
    if( 1 == size ) return true;

    unsigned sum = 0;
    for( int i = 0; i < num_sizes; ++i )
        sum |= ( (unsigned)sizes[i] ) % size;

    return ( 0 == sum );
}
virtual ErrorCode moab::TagInfo::clear_data ( SequenceManager seqman,
Error error_handler,
const EntityHandle entities,
size_t  num_entities,
const void *  value_ptr,
int  value_len = 0 
) [pure virtual]

Set tag value for passed entities.

Store tag data or update stored tag values.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
num_entitiesLength of entities array
value_ptrPointer to a single tag value which is to be stored for each of the passed entities.
value_lenLength of tag value in bytes. Ignored for fixed-length tags. Required for variable- length tags.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::tag_clear_data().

virtual ErrorCode moab::TagInfo::clear_data ( SequenceManager seqman,
Error error_handler,
const Range entities,
const void *  value_ptr,
int  value_len = 0 
) [pure virtual]

Set tag value for passed entities.

Store tag data or update stored tag values.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
value_ptrPointer to a single tag value which is to be stored for each of the passed entities.
value_lenLength of tag value in bytes. Ignored for fixed-length tags. Required for variable- length tags.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

bool moab::TagInfo::equals_default_value ( const void *  data,
int  size = -1 
) const

compare the passed value to the default value. returns false if no default value.

Definition at line 36 of file TagInfo.cpp.

References get_data_type(), get_default_value(), get_default_value_size(), get_size(), MB_TYPE_BIT, and variable_length().

Referenced by moab::Core::tag_get_handle().

{
    if( !get_default_value() ) return false;

    if( variable_length() && size != get_default_value_size() ) return false;

    if( !variable_length() && size >= 0 && size != get_size() ) return false;

    if( get_data_type() == MB_TYPE_BIT )
    {
        assert( get_size() <= 8 && get_default_value_size() == 1 );
        unsigned char byte1 = *reinterpret_cast< const unsigned char* >( data );
        unsigned char byte2 = *reinterpret_cast< const unsigned char* >( get_default_value() );
        unsigned char mask  = (unsigned char)( ( 1u << get_size() ) - 1 );
        return ( byte1 & mask ) == ( byte2 & mask );
    }
    else
    {
        return !memcmp( data, get_default_value(), get_default_value_size() );
    }
}
virtual ErrorCode moab::TagInfo::find_entities_with_value ( const SequenceManager seqman,
Error error_handler,
Range output_entities,
const void *  value,
int  value_bytes = 0,
EntityType  type = MBMAXTYPE,
const Range intersect_entities = 0 
) const [pure virtual]

Get all tagged entities with tag value.

Get the list of entities which have the specified tag value.

Parameters:
seqmanPointer to entity storage database
output_entitiesResults *appended* to this range
valuePointer to tag value
value_bytesSize of tag value in bytes.
typeOptional entity type. If specified, search is limited to entities of specified type.
intersect_entitiesOptional intersect list. If specified, search is restricted to entities in this list.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::get_entities_by_type_and_tag().

virtual ErrorCode moab::TagInfo::get_data ( const SequenceManager seqman,
Error error_handler,
const EntityHandle entities,
size_t  num_entities,
void *  data 
) const [pure virtual]

Get tag value for passed entities.

Get tag values for specified entities.

Will fail for variable-length data.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to retrieve tag data
num_entitiesLength of entities array
dataPointer to memory in which to store consecutive tag values, one for each passed entity.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::ParallelComm::packed_tag_size(), moab::Core::tag_get_by_ptr(), and moab::Core::tag_get_data().

virtual ErrorCode moab::TagInfo::get_data ( const SequenceManager seqman,
Error error_handler,
const Range entities,
void *  data 
) const [pure virtual]

Get tag value for passed entities.

Get tag values for specified entities.

Will fail for variable-length data.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to retrieve tag data
dataPointer to memory in which to store consecutive tag values, one for each passed entity.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

virtual ErrorCode moab::TagInfo::get_data ( const SequenceManager seqman,
Error error_handler,
const EntityHandle entities,
size_t  num_entities,
const void **  data_ptrs,
int *  data_lengths 
) const [pure virtual]

Get tag value for passed entities.

Get tag values for specified entities.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to retrieve tag data
num_entitiesLength of entities array
data_ptrsArray of pointers to tag values, one pointer for each passed entity.
data_lengthsOne value for each entity specifying the length of the tag value for the corresponding entity.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

virtual ErrorCode moab::TagInfo::get_data ( const SequenceManager seqman,
Error error_handler,
const Range entities,
const void **  data_ptrs,
int *  data_lengths 
) const [pure virtual]

Get tag value for passed entities.

Get tag values for specified entities.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to retrieve tag data
data_ptrsArray of pointers to tag values, one pointer for each passed entity.
data_lengthsOne value for each entity specifying the length of the tag value for the corresponding entity.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

virtual ErrorCode moab::TagInfo::get_memory_use ( const SequenceManager seqman,
unsigned long &  total,
unsigned long &  per_entity 
) const [pure virtual]
virtual ErrorCode moab::TagInfo::get_tagged_entities ( const SequenceManager seqman,
Range output_entities,
EntityType  type = MBMAXTYPE,
const Range intersect = 0 
) const [pure virtual]

Get all tagged entities.

Get the list of entities for which the a tag value has been set, or a close approximation if the tag storage scheme cannot accurately determine exactly which entities have explicit values.

Parameters:
seqmanPointer to entity storage database
output_entitiesResults *appended* to this range
typeOptional entity type. If specified, search is limited to entities of specified type.
intersectOptional intersect list. If specified, search is restricted to entities in this list.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::get_entities_by_type_and_tag().

virtual bool moab::TagInfo::is_tagged ( const SequenceManager seqman,
EntityHandle  entity 
) const [pure virtual]
virtual ErrorCode moab::TagInfo::num_tagged_entities ( const SequenceManager seqman,
size_t &  output_count,
EntityType  type = MBMAXTYPE,
const Range intersect = 0 
) const [pure virtual]

Count all tagged entities.

Count the entities for which the a tag value has been set, or a close approximation if the tag storage scheme cannot accurately determine exactly which entities have explicit values.

Parameters:
seqmanPointer to entity storage database
output_countThis is *incremented* for each detected entity.
typeOptional entity type. If specified, search is limited to entities of specified type.
intersectOptional intersect list. If specified, search is restricted to entities in this list.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::estimated_memory_use_internal().

TagInfo& moab::TagInfo::operator= ( const TagInfo copy) [private]
virtual ErrorCode moab::TagInfo::release_all_data ( SequenceManager seqman,
Error error_handler,
bool  tag_delete_pending 
) [pure virtual]

Remove/clear tag data for all entities.

Remove tag values from entities.

Parameters:
tag_delete_pendingIf true, then release any global data associated with the tag in preparation for deleting the tag itself.

Invalidates tag if tag_delete_pending is true. The only valid method that can be invoked that is is the destructor.

Parameters:
seqmanPointer to mesh entity database

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::tag_delete().

virtual ErrorCode moab::TagInfo::remove_data ( SequenceManager seqman,
Error error_handler,
const EntityHandle entities,
size_t  num_entities 
) [pure virtual]

Remove/clear tag data for entities.

Remove tag values from entities.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
num_entitiesLength of entities array

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::tag_delete_data().

virtual ErrorCode moab::TagInfo::remove_data ( SequenceManager seqman,
Error error_handler,
const Range entities 
) [pure virtual]

Remove/clear tag data for entities.

Remove tag values from entities.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

virtual ErrorCode moab::TagInfo::set_data ( SequenceManager seqman,
Error error_handler,
const EntityHandle entities,
size_t  num_entities,
const void *  data 
) [pure virtual]

Set tag value for passed entities.

Store tag data or update stored tag values Will fail for variable-length data.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
num_entitiesLength of entities array
dataPointer to memory holding consecutive tag values, one for each passed entity.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::tag_set_by_ptr(), and moab::Core::tag_set_data().

virtual ErrorCode moab::TagInfo::set_data ( SequenceManager seqman,
Error error_handler,
const Range entities,
const void *  data 
) [pure virtual]

Set tag value for passed entities.

Store tag data or update stored tag values Will fail for variable-length data.

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
dataPointer to memory holding consecutive tag values, one for each passed entity.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

virtual ErrorCode moab::TagInfo::set_data ( SequenceManager seqman,
Error error_handler,
const EntityHandle entities,
size_t  num_entities,
void const *const *  data_ptrs,
const int *  data_lengths 
) [pure virtual]

Set tag value for passed entities.

Store tag data or update stored tag values

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
num_entitiesLength of entities array
data_ptrsArray of pointers to tag values, one pointer for each passed entity.
data_lengthsOne value for each entity specifying the length of the tag value for the corresponding entity. Array is required for variable-length tags and is ignored for fixed-length tags.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

virtual ErrorCode moab::TagInfo::set_data ( SequenceManager seqman,
Error error_handler,
const Range entities,
void const *const *  data_ptrs,
const int *  data_lengths 
) [pure virtual]

Set tag value for passed entities.

Store tag data or update stored tag values

Parameters:
seqmanPointer to mesh entity database
entitiesEntity handles for which to store tag data
data_ptrsArray of pointers to tag values, one pointer for each passed entity.
data_lengthsOne value for each entity specifying the length of the tag value for the corresponding entity. Array is required for variable-length tags and is ignored for fixed-length tags.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

void moab::TagInfo::set_name ( const std::string &  name) [inline]

set the name of the tag

Definition at line 46 of file TagInfo.hpp.

References mTagName.

    {
        mTagName = name;
    }
virtual ErrorCode moab::TagInfo::tag_iterate ( SequenceManager seqman,
Error error_handler,
Range::iterator iter,
const Range::iterator end,
void *&  data_ptr,
bool  allocate = true 
) [pure virtual]

Access tag data via direct pointer into contiguous blocks.

Iteratively obtain direct access to contiguous blocks of tag storage. This function cannot be used with bit tags because of the compressed bit storage. This function cannot be used with variable length tags because it does not provide a mechanism to determine the length of the value for each entity. This function may be used with sparse tags, but if it is used, it will return data for a single entity at a time.

Parameters:
iterAs input, the first entity for which to return data. As output, one past the last entity for which data was returned.
endOne past the last entity for which data is desired
data_ptrOutput: pointer to tag storage.
allocateIf true, space for this tag will be allocated, if not it wont

If this function is called for entities for which no tag value has been set, but for which a default value exists, it will force the allocation of explicit storage for each such entity even though MOAB would normally not explicitly store tag values for such entities.

Implemented in moab::SparseTag, moab::VarLenSparseTag, moab::VarLenDenseTag, moab::DenseTag, moab::BitTag, and moab::MeshTag.

Referenced by moab::Core::tag_iterate().

ErrorCode moab::TagInfo::validate_lengths ( Error error_handler,
const int *  lengths,
size_t  num_lengths 
) const
Returns:
MB_VARIABLE_LENGTH_DATA If variable_length() && lengths is NULL MB_INVALID_SIZE If variable_length() && lengths is not NULL && any size is not a multiple of type size. MB_INVALID_SIZE If !variable_length() && lengths is not NULL && any size is not the tag size. MB_SUCCESS Otherwise.

Definition at line 72 of file TagInfo.cpp.

References get_data_type(), get_size(), MB_INVALID_SIZE, MB_SET_ERR, MB_SUCCESS, MB_VARIABLE_DATA_LENGTH, size_from_data_type(), and variable_length().

Referenced by moab::MeshTag::clear_data(), moab::VarLenSparseTag::clear_data(), moab::MeshTag::set_data(), moab::DenseTag::set_data(), moab::VarLenSparseTag::set_data(), moab::SparseTag::set_data(), and moab::VarLenDenseTag::set_data().

{
    int bits = 0;
    if( variable_length() )
    {
        if( !lengths )
        {
            MB_SET_ERR( MB_VARIABLE_DATA_LENGTH, "No size specified for variable-length tag" );
        }
        const unsigned type_size = size_from_data_type( get_data_type() );
        if( type_size == 1 ) return MB_SUCCESS;
        for( size_t i = 0; i < num_lengths; ++i )
            bits |= lengths[i] % type_size;
    }
    else if( lengths )
    {
        for( size_t i = 0; i < num_lengths; ++i )
            bits |= lengths[i] - get_size();
    }
    if( 0 == bits ) return MB_SUCCESS;

    MB_SET_ERR( MB_INVALID_SIZE, "Tag data with invalid size" );
}

Member Data Documentation

type of tag data

Definition at line 432 of file TagInfo.hpp.

Referenced by get_data_type().

int moab::TagInfo::mDataSize [private]

stores the size of the data for this tag

Definition at line 429 of file TagInfo.hpp.

Referenced by get_size().

stores the default data, if any

Definition at line 417 of file TagInfo.hpp.

Referenced by get_default_value(), TagInfo(), and ~TagInfo().

Size of mDefaultValue and mMeshValue, in bytes NOTE: These sizes differ from mDataSize in two cases: a) Variable-length tags b) Bit tags (where mDataSize is bits, not bytes.)

Definition at line 426 of file TagInfo.hpp.

Referenced by get_default_value_size(), TagInfo(), and ~TagInfo().

void* moab::TagInfo::mMeshValue [private]

store the mesh value, if any

Definition at line 420 of file TagInfo.hpp.

Definition at line 426 of file TagInfo.hpp.

std::string moab::TagInfo::mTagName [private]

stores the tag name

Definition at line 435 of file TagInfo.hpp.

Referenced by get_name(), set_name(), and TagInfo().

List of all members.


The documentation for this class was generated from the following files:
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines