The cellTable persistent data saved as a Map<dictionary>. More...
Public Member Functions | |
cellTable () | |
Construct null. More... | |
cellTable (const objectRegistry &, const word &name="cellTable", const fileName &instance="constant") | |
Construct read from registry, name. instance. More... | |
cellTable (const cellTable &)=delete | |
Disallow default bitwise copy construction. More... | |
~cellTable () | |
Destructor. More... | |
label | append (const dictionary &) |
Append to the end, return index. More... | |
label | findIndex (const word &name) const |
Return index corresponding to name. More... | |
word | name (const label id) const |
Return the name corresponding to id. More... | |
Map< word > | names () const |
Return a Map of (id => name) More... | |
Map< word > | names (const UList< wordRe > &patterns) const |
Return a Map of (id => names) selected by patterns. More... | |
Map< word > | selectType (const word &materialType) const |
Return a Map of (id => name) for materialType. More... | |
Map< word > | fluids () const |
Return a Map of (id => name) for fluids. More... | |
Map< word > | shells () const |
Return a Map of (id => name) for shells. More... | |
Map< word > | solids () const |
Return a Map of (id => name) for solids. More... | |
Map< word > | materialTypes () const |
Return a Map of (id => fluid|solid|shell) More... | |
void | setMaterial (const label, const word &) |
Assign material Type. More... | |
void | setName (const label, const word &) |
Assign name. More... | |
void | setName (const label) |
Assign default name if not already set. More... | |
void | readDict (const objectRegistry &, const word &name="cellTable", const fileName &instance="constant") |
Read constant/cellTable. More... | |
void | writeDict (const objectRegistry &, const word &name="cellTable", const fileName &instance="constant") const |
Write constant/cellTable for later reuse. More... | |
void | operator= (const cellTable &) |
Assignment. More... | |
void | operator= (const Map< dictionary > &) |
Assign from Map<dictionary> More... | |
void | operator= (const polyMesh &) |
Assign from cellZones. More... | |
void | addCellZones (polyMesh &, const labelList &tableIds) const |
Classify tableIds into cellZones according to the cellTable. More... | |
void | combine (const dictionary &, labelList &tableIds) |
Combine tableIds together. More... | |
Public Member Functions inherited from HashTable< T, Key, Hash > | |
HashTable (const label size=128) | |
Construct given initial table size. More... | |
HashTable (Istream &, const label size=128) | |
Construct from Istream. More... | |
HashTable (const UList< Key > &keyList, const UList< T > &elmtList) | |
Construct from a list of keys and list of elements. More... | |
HashTable (const HashTable< T, Key, Hash > &) | |
Copy constructor. More... | |
HashTable (HashTable< T, Key, Hash > &&) | |
Move constructor. More... | |
HashTable (std::initializer_list< Tuple2< Key, T >>) | |
Construct from an initialiser list. More... | |
~HashTable () | |
Destructor. More... | |
label | capacity () const |
The size of the underlying table. More... | |
label | size () const |
Return number of elements in table. More... | |
bool | empty () const |
Return true if the hash table is empty. More... | |
bool | found (const Key &) const |
Return true if hashedEntry is found in table. More... | |
iterator | find (const Key &) |
Find and return an iterator set at the hashedEntry. More... | |
const_iterator | find (const Key &) const |
Find and return an const_iterator set at the hashedEntry. More... | |
List< Key > | toc () const |
Return the table of contents. More... | |
List< Key > | sortedToc () const |
Return the table of contents as a sorted list. More... | |
List< const_iterator > | sorted () const |
Return a sorted list of constant iterators. More... | |
Ostream & | printInfo (Ostream &) const |
Print information. More... | |
bool | insert (const Key &, const T &newElmt) |
Insert a new hashedEntry. More... | |
void | insert (const HashTable< T, Key, Hash > &) |
Insert all the entries from the given HashTable. More... | |
bool | set (const Key &, const T &newElmt) |
Set a new hashedEntry, overwriting existing entries. More... | |
void | set (const HashTable< T, Key, Hash > &) |
Insert all the entries from the given HashTable,. More... | |
bool | erase (const iterator &) |
Erase a hashedEntry specified by given iterator. More... | |
bool | erase (const Key &) |
Erase a hashedEntry specified by the given key. More... | |
label | erase (const UList< Key > &) |
Remove entries given by the listed keys from this HashTable. More... | |
template<class AnyType , class AnyHash > | |
label | erase (const HashTable< AnyType, Key, AnyHash > &) |
Remove entries given by the given keys from this HashTable. More... | |
void | resize (const label newSize) |
Resize the hash table for efficiency. More... | |
void | clear () |
Clear all entries from table. More... | |
void | clearStorage () |
Clear the table entries and the table itself. More... | |
void | shrink () |
Shrink the allocated table to approx. twice number of elements. More... | |
void | transfer (HashTable< T, Key, Hash > &) |
Transfer the contents of the argument table into this table. More... | |
T & | operator[] (const Key &) |
Find and return a hashedEntry. More... | |
const T & | operator[] (const Key &) const |
Find and return a hashedEntry. More... | |
T & | operator() (const Key &) |
Find and return a hashedEntry, create it null if not present. More... | |
void | operator= (const HashTable< T, Key, Hash > &) |
Assignment operator. More... | |
void | operator= (HashTable< T, Key, Hash > &&) |
Move assignment operator. More... | |
void | operator= (std::initializer_list< Tuple2< Key, T >>) |
Assignment to an initialiser list. More... | |
bool | operator== (const HashTable< T, Key, Hash > &) const |
Equality. Hash tables are equal if the keys and values are equal. More... | |
bool | operator!= (const HashTable< T, Key, Hash > &) const |
The opposite of the equality operation. Takes linear time. More... | |
iterator | begin () |
Iterator set to the beginning of the HashTable. More... | |
const_iterator | cbegin () const |
const_iterator set to the beginning of the HashTable More... | |
const_iterator | begin () const |
const_iterator set to the beginning of the HashTable More... | |
template<class AnyType , class AnyHash > | |
Foam::label | erase (const HashTable< AnyType, Key, AnyHash > &rhs) |
Public Member Functions inherited from HashTableCore | |
HashTableCore () | |
Construct null. More... | |
ClassName ("HashTable") | |
Define template name and debug. More... | |
Additional Inherited Members | |
Public Types inherited from HashTable< T, Key, Hash > | |
typedef T | value_type |
Type of values the HashTable contains. More... | |
typedef T & | reference |
Type that can be used for storing into HashTable::value_type. More... | |
typedef const T & | const_reference |
Type that can be used for storing into constant. More... | |
typedef label | size_type |
The type that can represent the size of a HashTable. More... | |
Static Public Member Functions inherited from HashTableCore | |
static label | canonicalSize (const label) |
Return a canonical (power-of-two) size. More... | |
static iteratorEnd | cend () |
iteratorEnd set to beyond the end of any HashTable More... | |
static iteratorEnd | end () |
iteratorEnd set to beyond the end of any HashTable More... | |
Static Public Attributes inherited from HashTableCore | |
static const label | maxTableSize |
Maximum allowable table size. More... | |
The cellTable persistent data saved as a Map<dictionary>.
The meshReader supports cellTable information.
The constant/cellTable
file is an IOMap<dictionary>
that is used to save the information persistently. It contains the cellTable information of the following form:
( ID { Label WORD; MaterialType WORD; MaterialId INT; PorosityId INT; ColorIdx INT; ... } ... )
If the Label is missing, a value cellTable_{ID}
will be inferred. If the MaterialType is missing, the value fluid will be inferred.
Definition at line 77 of file cellTable.H.
cellTable | ( | ) |
Construct null.
Definition at line 103 of file cellTable.C.
cellTable | ( | const objectRegistry & | registry, |
const word & | name = "cellTable" , |
||
const fileName & | instance = "constant" |
||
) |
Construct read from registry, name. instance.
Definition at line 109 of file cellTable.C.
References cellTable::name(), and cellTable::readDict().
~cellTable | ( | ) |
Destructor.
Definition at line 124 of file cellTable.C.
Foam::label append | ( | const dictionary & | dict | ) |
Append to the end, return index.
Definition at line 130 of file cellTable.C.
References dict, forAllConstIter, and Foam::vtkWriteOps::insert().
Foam::label findIndex | ( | const word & | name | ) | const |
Return index corresponding to name.
returns -1 if not found
Definition at line 206 of file cellTable.C.
References forAllConstIter, Foam::name(), and word::null.
Foam::word name | ( | const label | id | ) | const |
Return the name corresponding to id.
returns cellTable_ID if not otherwise defined
Definition at line 192 of file cellTable.C.
References Foam::name().
Referenced by cellTable::cellTable().
Foam::Map< Foam::word > names | ( | ) | const |
Return a Map of (id => name)
Definition at line 146 of file cellTable.C.
References forAllConstIter, HashTable< T, Key, Hash >::insert(), and Foam::name().
Foam::Map< Foam::word > names | ( | const UList< wordRe > & | patterns | ) | const |
Return a Map of (id => names) selected by patterns.
Definition at line 167 of file cellTable.C.
References Foam::findStrings(), forAllConstIter, HashTable< T, Key, Hash >::insert(), and Foam::name().
Foam::Map< Foam::word > selectType | ( | const word & | materialType | ) | const |
Return a Map of (id => name) for materialType.
(fluid | solid | shell)
Definition at line 242 of file cellTable.C.
References forAllConstIter, HashTable< T, Key, Hash >::insert(), and Foam::name().
Foam::Map< Foam::word > fluids | ( | ) | const |
Return a Map of (id => name) for fluids.
Definition at line 270 of file cellTable.C.
Foam::Map< Foam::word > shells | ( | ) | const |
Return a Map of (id => name) for shells.
Definition at line 282 of file cellTable.C.
Foam::Map< Foam::word > solids | ( | ) | const |
Return a Map of (id => name) for solids.
Definition at line 276 of file cellTable.C.
Foam::Map< Foam::word > materialTypes | ( | ) | const |
Return a Map of (id => fluid|solid|shell)
Definition at line 225 of file cellTable.C.
References forAllConstIter, and HashTable< T, Key, Hash >::insert().
Assign material Type.
Definition at line 289 of file cellTable.C.
Assign name.
Definition at line 295 of file cellTable.C.
References Foam::name().
void setName | ( | const label | id | ) |
Assign default name if not already set.
Definition at line 301 of file cellTable.C.
References found, and Foam::name().
void readDict | ( | const objectRegistry & | registry, |
const word & | name = "cellTable" , |
||
const fileName & | instance = "constant" |
||
) |
Read constant/cellTable.
Definition at line 312 of file cellTable.C.
References clear(), Foam::endl(), regIOobject::headerOk(), Foam::Info, Foam::name(), IOobject::NO_WRITE, and IOobject::READ_IF_PRESENT.
Referenced by cellTable::cellTable(), and STARCD::STARCD().
void writeDict | ( | const objectRegistry & | registry, |
const word & | name = "cellTable" , |
||
const fileName & | instance = "constant" |
||
) | const |
Write constant/cellTable for later reuse.
Definition at line 347 of file cellTable.C.
References Foam::endl(), Foam::Info, IOobject::name(), Foam::name(), IOobject::NO_READ, IOobject::NO_WRITE, IOobject::note(), regIOobject::objectPath(), and IOobject::writeHeader().
Assignment.
Definition at line 381 of file cellTable.C.
References HashTable< T, label, Hash< label > >::operator=().
void operator= | ( | const Map< dictionary > & | rhs | ) |
Assign from Map<dictionary>
Definition at line 388 of file cellTable.C.
References HashTable< T, label, Hash< label > >::operator=().
Assign from cellZones.
Definition at line 395 of file cellTable.C.
References dictionary::add(), polyMesh::cellZones(), HashTable< T, Key, Hash >::clear(), dict, forAll, HashTable< T, Key, Hash >::insert(), primitiveMesh::nCells(), HashTable< T, label, Hash< label > >::operator=(), List< T >::size(), and DictionaryBase< IDLListType, T >::toc().
Classify tableIds into cellZones according to the cellTable.
Definition at line 440 of file cellTable.C.
References List< T >::append(), IOobject::AUTO_WRITE, polyMesh::cellZones(), ZoneList< ZoneType, ZonesType, MeshType >::clear(), HashTableCore::end(), Foam::endl(), HashTable< T, Key, Hash >::find(), forAll, Foam::Info, PtrListDictionary< T >::set(), List< T >::setSize(), PtrList< T >::setSize(), List< T >::size(), and IOobject::writeOpt().
void combine | ( | const dictionary & | mapDict, |
labelList & | tableIds | ||
) |
Combine tableIds together.
each dictionary entry is a wordList
Definition at line 506 of file cellTable.C.
References Foam::endl(), erase(), HashTable< T, Key, Hash >::erase(), Foam::findIndex(), Foam::findStrings(), forAllConstIter, Foam::identityMap(), Foam::Info, Foam::inplaceRenumber(), HashTable< T, Key, Hash >::insert(), Foam::max(), Foam::min(), HashTable< T, Key, Hash >::size(), and HashTable< T, Key, Hash >::toc().