DGtal 1.3.0
|
This class represents a voxel complex living in some Khalimsky space. Voxel complexes are derived from. More...
#include <DGtal/topology/VoxelComplex.h>
Public Types | |
using | Self = VoxelComplex< TKSpace, TCellContainer > |
using | Parent = CubicalComplex< TKSpace, TCellContainer > |
using | KSpace = TKSpace |
using | CellContainer = TCellContainer |
using | Data = typename CellContainer::mapped_type |
using | Integer = typename KSpace::Integer |
using | Cell = typename KSpace::Cell |
using | PreCell = typename Cell::PreCell |
using | Cells = typename KSpace::Cells |
using | Space = typename KSpace::Space |
using | Size = typename KSpace::Size |
using | Point = typename KSpace::Point |
using | DirIterator = typename KSpace::DirIterator |
using | CellMap = CellContainer |
using | CellMapConstIterator = typename CellMap::const_iterator |
using | CellMapIterator = typename CellMap::iterator |
using | Clique = Parent |
using | CliqueContainer = std::vector< Clique > |
using | ConfigMap = boost::dynamic_bitset<> |
using | PointToMaskMap = std::unordered_map< Point, unsigned int > |
Public Types inherited from DGtal::CubicalComplex< TKSpace, TCellContainer > | |
enum | CellType { Maximal , Free , Any } |
Possible cell types within a complex. More... | |
typedef CubicalComplex< TKSpace, TCellContainer > | Self |
typedef TKSpace | KSpace |
Type of the cellular grid space. More... | |
typedef TCellContainer | CellContainer |
Type for storing cells, an associative container Cell -> Data. More... | |
typedef CellContainer::mapped_type | Data |
Type of data associated to each cell. More... | |
typedef KSpace::Integer | Integer |
Type for integers in the space. More... | |
typedef KSpace::Cell | Cell |
Type for a cell in the space. More... | |
typedef Cell::PreCell | PreCell |
Type for a precell in the space. More... | |
typedef KSpace::Cells | Cells |
Type for a sequence of cells in the space. More... | |
typedef KSpace::Space | Space |
Type of the digital space. More... | |
typedef KSpace::Size | Size |
Type for a number of elements. More... | |
typedef KSpace::Point | Point |
Type for a point in the digital space. More... | |
typedef KSpace::DirIterator | DirIterator |
Type for iterating over cell directions. More... | |
typedef CellContainer | CellMap |
Type for storing cells, an associative container Cell -> Data. More... | |
typedef CellMap::const_iterator | CellMapConstIterator |
Const iterator for visiting type CellMap. More... | |
typedef CellMap::iterator | CellMapIterator |
Iterator for visiting type CellMap. More... | |
typedef ConstIterator | const_iterator |
typedef Iterator | iterator |
typedef Cell | value_type |
typedef Cell const & | reference |
typedef Cell const & | const_reference |
typedef CellContainer::size_type | size_type |
typedef CellContainer::difference_type | difference_type |
typedef Cell const * | pointer |
typedef Cell const * | const_pointer |
Public Member Functions | |
VoxelComplex (const VoxelComplex &other) | |
Self & | operator= (const Self &other) |
template<typename TDigitalSet > | |
void | construct (const TDigitalSet &input_set, const Alias< ConfigMap > input_table) |
void | setSimplicityTable (const Alias< ConfigMap > input_table) |
void | copySimplicityTable (const Self &other) |
const ConfigMap & | table () const |
const bool & | isTableLoaded () const |
void | voxelClose (const Cell &kcell) |
void | cellsClose (Dimension k_d, const Cells &cells) |
void | insertVoxelCell (const Cell &kcell, const bool &close_it=true, const Data &data=Data()) |
void | insertVoxelCell (const std::pair< Cell, Data > &data_pair, const bool &close_it=true) |
void | insertVoxelPoint (const Point &dig_point, const bool &close_it=true, const Data &data=Data()) |
template<typename TDigitalSet > | |
void | dumpVoxels (TDigitalSet &in_out_set) const |
void | pointelsFromCell (std::set< Cell > &pointels_out, const Cell &input_cell) const |
void | spelsFromCell (std::set< Cell > &spels_out, const Cell &input_cell) const |
std::set< Cell > | neighborhoodVoxels (const Cell &input_cell) const |
std::set< Cell > | properNeighborhoodVoxels (const Cell &input_cell) const |
Clique | Kneighborhood (const Cell &input_cell) const |
bool | isSimpleByThinning (const Cell &input_spel) const |
bool | isSimple (const Cell &input_spel) const |
std::pair< bool, Clique > | criticalCliquePair (const Dimension d, const CellMapConstIterator &cellMapIterator) const |
std::array< CliqueContainer, dimension+1 > | criticalCliques (const Parent &cubical, bool verbose=false) const |
std::array< CliqueContainer, dimension+1 > | criticalCliques (bool verbose=false) const |
CliqueContainer | criticalCliquesForD (const Dimension d, const Parent &cubical, bool verbose=false) const |
std::pair< bool, Clique > | K_2 (const Cell &A, const Cell &B, bool verbose=false) const |
std::pair< bool, Clique > | K_2 (const typename KSpace::Point &A, const typename KSpace::Point &B, bool verbose=false) const |
std::pair< bool, Clique > | K_2 (const Cell &face2, bool verbose=false) const |
std::pair< bool, Clique > | K_1 (const Cell &face1, bool verbose=false) const |
std::pair< bool, Clique > | K_0 (const Cell &face0, bool verbose=false) const |
std::pair< bool, Clique > | K_3 (const Cell &input_spel, bool verbose=false) const |
bool | isSpel (const Cell &c) const |
Cell | surfelBetweenAdjacentSpels (const Cell &A, const Cell &B) const |
void | selfDisplay (std::ostream &out) const |
bool | isValid () const |
std::string | className () const |
template<typename TDigitalSet > | |
void | construct (const TDigitalSet &set) |
Public Member Functions inherited from DGtal::CubicalComplex< TKSpace, TCellContainer > | |
BOOST_CONCEPT_ASSERT ((concepts::CCellularGridSpaceND< TKSpace >)) | |
BOOST_STATIC_ASSERT (IsPairAssociativeContainer< TCellContainer >::value) | |
BOOST_CONCEPT_ASSERT ((concepts::CSTLAssociativeContainer< TCellContainer >)) | |
BOOST_STATIC_ASSERT ((boost::is_base_of< CubicalCellData, Data >::value)) | |
BOOST_STATIC_ASSERT ((boost::is_same< typename TKSpace::Cell, typename CellContainer::key_type >::value)) | |
BOOST_STATIC_CONSTANT (uint32_t, REMOVED=0x10000000) | |
Flag Used to indicate in a cell data that this cell has been (virtually) removed. More... | |
BOOST_STATIC_CONSTANT (uint32_t, COLLAPSIBLE=0x20000000) | |
Flag Used to indicate in a cell data that this cell is collapsible. More... | |
BOOST_STATIC_CONSTANT (uint32_t, FIXED=0x40000000) | |
Flag Used to indicate in a cell data that this cell is fixed. More... | |
BOOST_STATIC_CONSTANT (uint32_t, USER1=0x80000000) | |
User flag for a cell. More... | |
BOOST_STATIC_CONSTANT (uint32_t, VALUE=0x0fffffff) | |
Value for a cell. More... | |
~CubicalComplex () | |
CubicalComplex (ConstAlias< KSpace > aK) | |
CubicalComplex (const CubicalComplex &other) | |
template<typename TDigitalSet > | |
void | construct (const TDigitalSet &set) |
CubicalComplex & | operator= (const CubicalComplex &other) |
void | clear () |
void | clear (Dimension d) |
void | fillData (Data data=Data()) |
void | fillData (Dimension d, Data data=Data()) |
Dimension | dim () const |
Dimension | dim (const Cell &aCell) const |
Size | nbCells (Dimension d) const |
Integer | euler () const |
const KSpace & | space () const |
const CellMap & | getCells (const Dimension d) const |
CellMap & | getCells (const Dimension d) |
ConstIterator | begin () const |
ConstIterator | end () const |
Iterator | begin () |
Iterator | end () |
Size | count (const Cell &aCell) const |
Size | size () const |
Size | max_size () const |
bool | empty () const |
std::pair< ConstIterator, ConstIterator > | equal_range (const Cell &aCell) const |
std::pair< Iterator, Iterator > | equal_range (const Cell &aCell) |
void | erase (Iterator position) |
Size | erase (const Cell &aCell) |
void | erase (Iterator first, Iterator last) |
ConstIterator | find (const Cell &aCell) const |
Iterator | find (const Cell &aCell) |
std::pair< Iterator, bool > | insert (const Cell &aCell) |
Iterator | insert (Iterator position, const Cell &aCell) |
template<class InputIterator > | |
void | insert (InputIterator first, InputIterator last) |
void | swap (CubicalComplex &other) |
Data & | operator[] (const Cell &aCell) |
bool | operator() (const Cell &aCell) const |
void | insertCell (const Cell &aCell, const Data &data=Data()) |
void | insertCell (Dimension d, const Cell &aCell, const Data &data=Data()) |
template<typename CellConstIterator > | |
void | insertCells (CellConstIterator it, CellConstIterator itE, const Data &data=Data()) |
template<typename CellConstIterator > | |
void | insertCells (Dimension d, CellConstIterator it, CellConstIterator itE, const Data &data=Data()) |
bool | belongs (const Cell &aCell) const |
bool | belongs (const PreCell &aCell) const |
bool | belongs (Dimension d, const Cell &aCell) const |
bool | belongs (Dimension d, const PreCell &aCell) const |
Size | eraseCell (const Cell &aCell) |
Size | eraseCell (Dimension d, const Cell &aCell) |
void | eraseCell (CellMapIterator it) |
void | eraseCells (CellMapIterator it, CellMapIterator itE) |
template<typename CellConstIterator > | |
Size | eraseCells (CellConstIterator it, CellConstIterator itE) |
template<typename CellConstIterator > | |
Size | eraseCells (Dimension d, CellConstIterator it, CellConstIterator itE) |
template<typename CellOutputIterator > | |
void | faces (CellOutputIterator &outIt, const Cell &aCell, bool hintClosed=false) const |
template<typename CellOutputIterator > | |
void | directFaces (CellOutputIterator &outIt, const Cell &aCell, bool hintClosed=false) const |
template<typename CellMapIteratorOutputIterator > | |
void | directFacesIterators (CellMapIteratorOutputIterator &outIt, const Cell &aCell) |
template<typename CellOutputIterator > | |
void | coFaces (CellOutputIterator &outIt, const Cell &aCell, bool hintOpen=false) const |
template<typename CellOutputIterator > | |
void | directCoFaces (CellOutputIterator &outIt, const Cell &aCell, bool hintOpen=false) const |
template<typename CellMapIteratorOutputIterator > | |
void | directCoFacesIterators (CellMapIteratorOutputIterator &outIt, const Cell &aCell) |
CellMapConstIterator | begin (Dimension d) const |
CellMapConstIterator | end (Dimension d) const |
CellMapIterator | begin (Dimension d) |
CellMapIterator | end (Dimension d) |
CellMapConstIterator | findCell (const Cell &aCell) const |
CellMapConstIterator | findCell (Dimension d, const Cell &aCell) const |
CellMapIterator | findCell (const Cell &aCell) |
CellMapIterator | findCell (Dimension d, const Cell &aCell) |
Cells | cellBoundary (const Cell &aCell, bool hintClosed=false) const |
Cells | cellCoBoundary (const Cell &aCell, bool hintOpen=false) const |
bool | isCellInterior (const Cell &aCell) const |
bool | isCellBoundary (const Cell &aCell) const |
CellType | computeCellType (const Cell &c, CellMapIterator &it_cell_up, Dimension n=dimension) |
CubicalComplex | interior () const |
CubicalComplex | boundary (bool hintClosed=false) const |
void | getInteriorAndBoundary (CubicalComplex &intcc, CubicalComplex &bdcc, bool hintClosed=false) const |
CubicalComplex | closure (const CubicalComplex &S, bool hintClosed=false) const |
CubicalComplex | star (const CubicalComplex &S, bool hintOpen=false) const |
CubicalComplex | link (const CubicalComplex &S, bool hintClosed=false, bool hintOpen=false) const |
void | close () |
void | close (Dimension k) |
void | open () |
void | open (Dimension k) |
void | selfDisplay (std::ostream &out) const |
bool | isValid () const |
std::string | className () const |
Static Public Attributes | |
static const Dimension | dimension = KSpace::dimension |
The dimension of the embedding space. More... | |
Static Public Attributes inherited from DGtal::CubicalComplex< TKSpace, TCellContainer > | |
static const Dimension | dimension = KSpace::dimension |
The dimension of the embedding space. More... | |
Protected Member Functions | |
VoxelComplex () | |
const PointToMaskMap & | pointToMask () const |
Protected Member Functions inherited from DGtal::CubicalComplex< TKSpace, TCellContainer > | |
CubicalComplex () | |
Protected Attributes | |
CountedPtrOrPtr< ConfigMap > | myTablePtr |
CountedPtrOrPtr< PointToMaskMap > | myPointToMaskPtr |
bool | myIsTableLoaded {false} |
Flag if using a LUT for simplicity. More... | |
Protected Attributes inherited from DGtal::CubicalComplex< TKSpace, TCellContainer > | |
const KSpace * | myKSpace |
The Khalimsky space in which lives the cubical complex. More... | |
std::vector< CellMap > | myCells |
Friends | |
Self & | DGtal::operator-= (Self &, const Self &) |
Self | DGtal::operator- (const Self &, const Self &) |
This class represents a voxel complex living in some Khalimsky space. Voxel complexes are derived from.
Description of template class 'VoxelComplex'
The aim is to implement critical kernels, ie, cliques of spels, as shown by M.Couprie and G.Bertrand [37]
Implemented using resources from CubicalComplex and (Digital) Object for simplicity check in voxels.
TKSpace | any model of concepts::CCellularGridSpaceND, i.e. a type that models a Khalimsky space. |
TCellContainer | any model of associative container, mapping a KSpace::Cell to a CubicalCellData or any type deriving from it. It could be for instance a std::map or a std::unordered_map. Note that unfortunately, unordered_map are (strangely) not models of boost::AssociativeContainer, hence we cannot check concepts here. |
Definition at line 91 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Cell = typename KSpace::Cell |
Type for a cell in the space.
Definition at line 114 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::CellContainer = TCellContainer |
Type for storing cells, an associative container < Cell -> Data
Definition at line 104 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::CellMap = CellContainer |
Type for storing cells, an associative container Cell -> Data.
Definition at line 128 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::CellMapConstIterator = typename CellMap::const_iterator |
Type Const iterator for visiting type CellMap.
Definition at line 130 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::CellMapIterator = typename CellMap::iterator |
Type Iterator for visiting type CellMap.
Definition at line 132 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Cells = typename KSpace::Cells |
Type for a sequence of cells in the space.
Definition at line 118 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Clique = Parent |
Definition at line 135 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::CliqueContainer = std::vector<Clique> |
Definition at line 136 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::ConfigMap = boost::dynamic_bitset<> |
Definition at line 139 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Data = typename CellContainer::mapped_type |
Type of data associated to each cell.
Definition at line 106 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::DirIterator = typename KSpace::DirIterator |
Type for iterating over cell directions.
Definition at line 126 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Integer = typename KSpace::Integer |
Type for integers in the space.
Definition at line 112 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::KSpace = TKSpace |
Type of the cellular grid space.
Definition at line 102 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Parent = CubicalComplex<TKSpace, TCellContainer> |
Type of the parent class CubicalComplex.
Definition at line 100 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Point = typename KSpace::Point |
Type for a point in the digital space.
Definition at line 124 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::PointToMaskMap = std::unordered_map<Point, unsigned int> |
Definition at line 140 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::PreCell = typename Cell::PreCell |
Type for a PreCell in the space.
Definition at line 116 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Self = VoxelComplex<TKSpace, TCellContainer> |
Type of this instance of VoxelComplex.
Definition at line 94 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Size = typename KSpace::Size |
Type for a number of elements.
Definition at line 122 of file VoxelComplex.h.
using DGtal::VoxelComplex< TKSpace, TCellContainer >::Space = typename KSpace::Space |
Type of the digital space.
Definition at line 120 of file VoxelComplex.h.
|
protected |
Default constructor. Note that the state of the VoxelComplex is invalid without a k-space. Use CubicalComplex(KSpace ks) constructor.
DGtal::VoxelComplex< TKSpace, TCellContainer >::VoxelComplex | ( | const VoxelComplex< TKSpace, TCellContainer > & | other | ) |
Copy constructor.
other | VoxelComplex to copy. |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::cellsClose | ( | Dimension | k_d, |
const Cells & | cells | ||
) |
Iterate over all the input cells and close them.
k_d | dimension |
cells | input cells to close around. |
std::string DGtal::VoxelComplex< TKSpace, TCellContainer >::className | ( | ) | const |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::construct | ( | const TDigitalSet & | input_set, |
const Alias< ConfigMap > | input_table | ||
) |
Construct from digital set and precomputed look up table for simplicity. Object and methods involving object will be empty/invalid. But they might not be needed thanks to the loaded table.
input_set | points to construct the CubicalComplex. Calls CubicalComplex::construct |
input_table | input table[conf]->bool |
void DGtal::CubicalComplex< TKSpace, TCellContainer >::construct | ( | const TDigitalSet & | set | ) |
Construct a complex from a digital set.
TDigitalSet | either kind of DigitalSet |
set | - a digital set from which to create a complex. Set has to be of the same dimension as a Khalimsky space. |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::copySimplicityTable | ( | const Self & | other | ) |
Copy table variables from other Complex.
other | complex to copy table from |
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliquePair | ( | const Dimension | d, |
const CellMapConstIterator & | cellMapIterator | ||
) | const |
|
inline |
Helper. Call criticalCliques of this VoxelComplex.
verbose | print messages |
Definition at line 408 of file VoxelComplex.h.
References DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliques().
|
inline |
Return all critical cliques for cubical. It calls criticalCliquesForD
cubical | target complex to get critical cliques. |
verbose | print messages |
Definition at line 384 of file VoxelComplex.h.
References DGtal::Trace::beginBlock(), DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliquesForD(), DGtal::VoxelComplex< TKSpace, TCellContainer >::dimension, DGtal::Trace::endBlock(), DGtal::Trace::info(), and DGtal::trace.
Referenced by DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliques().
CliqueContainer DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliquesForD | ( | const Dimension | d, |
const Parent & | cubical, | ||
bool | verbose = false |
||
) | const |
Main method to iterate over cells of selected dimension in a complex, returning critical cliques. Uses criticalCliquePair.
d | dimension of cell. |
cubical | target complex to get critical cliques. |
verbose | print messages |
Referenced by DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliques().
void DGtal::VoxelComplex< TKSpace, TCellContainer >::dumpVoxels | ( | TDigitalSet & | in_out_set | ) | const |
Dump the voxels (kcell with dimension 3) into a input container.
TDigitalSet | the type of the container |
in_out_set | input and output digital set, voxels gets inserted in the set. Note that the input digital set is not cleared in this function before inserting. |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::insertVoxelCell | ( | const Cell & | kcell, |
const bool & | close_it = true , |
||
const Data & | data = Data() |
||
) |
Insert cell (voxel) in the khalimsky space
kcell | input voxel |
close_it | if true, apply voxelClose. |
data | associated data with the input cell. |
Referenced by DGtal::VoxelComplex< TKSpace, TCellContainer >::insertVoxelCell().
|
inline |
Insert cell(voxel) in K-space and in the object set.
data_pair | pair<Cell, Data> |
close_it | if true, apply voxelClose |
Definition at line 250 of file VoxelComplex.h.
References DGtal::VoxelComplex< TKSpace, TCellContainer >::insertVoxelCell().
void DGtal::VoxelComplex< TKSpace, TCellContainer >::insertVoxelPoint | ( | const Point & | dig_point, |
const bool & | close_it = true , |
||
const Data & | data = Data() |
||
) |
Create a uSpel from the input Point and insert it using insertVoxelCell.
dig_point | input point of the KSpace |
close_it | flag to apply voxelClose |
data | associated data with the input point. |
bool DGtal::VoxelComplex< TKSpace, TCellContainer >::isSimple | ( | const Cell & | input_spel | ) | const |
Check if the input_spel from khalimsky space is simple using either a simplicity_table if loaded, or isSimpleByThinning.
input_spel | khalimsky space spel. |
bool DGtal::VoxelComplex< TKSpace, TCellContainer >::isSimpleByThinning | ( | const Cell & | input_spel | ) | const |
Use thinning to check if cell is simple. First create a CubicalComplex from the neighbor voxels on input_cell. This does not include input_cell itself, close the new clique and apply a collapse operation. A input_spel is simple in the complex, if after the collapse on the proper neighborhood clique, there is only one pointel.
input_spel | input spel for checking its simplicity. |
bool DGtal::VoxelComplex< TKSpace, TCellContainer >::isSpel | ( | const Cell & | c | ) | const |
True if input cell is a cell with max dimension.
c | input Cell |
const bool & DGtal::VoxelComplex< TKSpace, TCellContainer >::isTableLoaded | ( | ) | const |
Get const reference to isTableLoaded bool member.
bool DGtal::VoxelComplex< TKSpace, TCellContainer >::isValid | ( | ) | const |
Checks the validity/consistency of the object.
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::K_0 | ( | const Cell & | face0, |
bool | verbose = false |
||
) | const |
Compute the criticality of the pointel and the associated 0-clique.
face0 | a pointel cell. |
verbose | flag for verbose output |
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::K_1 | ( | const Cell & | face1, |
bool | verbose = false |
||
) | const |
Compute the criticality of the linel and the associated 1-clique.
face1 | linel between two pointels |
verbose | flag for verbose output |
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::K_2 | ( | const Cell & | A, |
const Cell & | B, | ||
bool | verbose = false |
||
) | const |
Compute the criticality of the surfel between A,B voxels and returns the associated 2-clique.
A | Spel (voxel). |
B | Spel (voxel). |
verbose | flag for verbose output |
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::K_2 | ( | const Cell & | face2, |
bool | verbose = false |
||
) | const |
K_2 from a 2-face (surfel)
face2 | surfel between 2 spels |
verbose | flag for verbose output |
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::K_2 | ( | const typename KSpace::Point & | A, |
const typename KSpace::Point & | B, | ||
bool | verbose = false |
||
) | const |
K_2 from two DigitalSet Points (uCoords)
A | voxel point |
B | voxel point |
verbose | flag for verbose output |
std::pair< bool, Clique > DGtal::VoxelComplex< TKSpace, TCellContainer >::K_3 | ( | const Cell & | input_spel, |
bool | verbose = false |
||
) | const |
Compute the criticality of the spel and the associated 3-clique. It uses isSimple to check criticality.
input_spel | input spel |
verbose | bool flag |
Clique DGtal::VoxelComplex< TKSpace, TCellContainer >::Kneighborhood | ( | const Cell & | input_cell | ) | const |
Get a clique holding the K-neighborhood of the input cell. The K-neighborhood is calculated first, getting the pointels from input_cell (
input_cell | input cell from which get the surrounding spels. |
std::set< Cell > DGtal::VoxelComplex< TKSpace, TCellContainer >::neighborhoodVoxels | ( | const Cell & | input_cell | ) | const |
Return the neighbor spels of input_cell
input_cell | center of the neighborhood |
Self & DGtal::VoxelComplex< TKSpace, TCellContainer >::operator= | ( | const Self & | other | ) |
Assignment.
other | the object to copy. |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::pointelsFromCell | ( | std::set< Cell > & | pointels_out, |
const Cell & | input_cell | ||
) | const |
Get pointels that are Faces of input_cell.
pointels_out | in/out pointels. |
input_cell | input cell from which get the surrounding pointels. |
|
protected |
pointToMask map, used internally in VoxelComplex::isSimple for functions::getSpelNeighborhoodConfigurationOccupancy
std::set< Cell > DGtal::VoxelComplex< TKSpace, TCellContainer >::properNeighborhoodVoxels | ( | const Cell & | input_cell | ) | const |
Return a set of of voxels forming the properNeighborhood of the inputCell.
input_cell | center of the neighborhood |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::selfDisplay | ( | std::ostream & | out | ) | const |
Writes/Displays the object on an output stream.
out | the output stream where the object is written. |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::setSimplicityTable | ( | const Alias< ConfigMap > | input_table | ) |
Set precomputed look up table for simplicity.
input_table | input table[conf]->bool |
void DGtal::VoxelComplex< TKSpace, TCellContainer >::spelsFromCell | ( | std::set< Cell > & | spels_out, |
const Cell & | input_cell | ||
) | const |
Get spels that are coFaces of input_cell.
spels_out | in/out spels. |
input_cell | input cell from which get the surrounding spels. |
Cell DGtal::VoxelComplex< TKSpace, TCellContainer >::surfelBetweenAdjacentSpels | ( | const Cell & | A, |
const Cell & | B | ||
) | const |
Surfel between two adjacent spels.
A | input spel cell |
B | input spel cell |
const ConfigMap & DGtal::VoxelComplex< TKSpace, TCellContainer >::table | ( | ) | const |
Get const reference to table[conf]->bool for simplicity.
void DGtal::VoxelComplex< TKSpace, TCellContainer >::voxelClose | ( | const Cell & | kcell | ) |
|
friend |
|
friend |
|
static |
The dimension of the embedding space.
Definition at line 109 of file VoxelComplex.h.
Referenced by DGtal::VoxelComplex< TKSpace, TCellContainer >::criticalCliques().
|
protected |
Flag if using a LUT for simplicity.
Definition at line 525 of file VoxelComplex.h.
|
protected |
ConfigurationMask (LUT table).
Definition at line 524 of file VoxelComplex.h.
|
protected |
Look Up Table to speed computations of isSimple.
Definition at line 522 of file VoxelComplex.h.