TTK
Loading...
Searching...
No Matches
ttkPersistenceDiagramDictionaryDecoding Class Reference

TTK processing package for the computation of a Dictionary of Persistence Diagrams and barycentric weights to approximate an ensemble of Persistence Diagrams. More...

#include <ttkPersistenceDiagramDictionaryDecoding.h>

Inheritance diagram for ttkPersistenceDiagramDictionaryDecoding:
ttkAlgorithm ttk::PersistenceDiagramDictionaryDecoding ttk::Debug ttk::Debug ttk::BaseClass ttk::BaseClass

Public Types

typedef ttkAlgorithm Superclass
 
- Public Types inherited from ttkAlgorithm
typedef vtkAlgorithm Superclass
 

Public Member Functions

virtual const char * GetClassName ()
 
virtual int IsA (const char *type)
 
virtual double GetSpacing ()
 
virtual void SetSpacing (double)
 
virtual int GetShowAtoms ()
 
virtual void SetShowAtoms (int)
 
virtual int GetProgBarycenter ()
 
virtual void SetProgBarycenter (int)
 
virtual void SetProjMet (int _arg)
 
virtual void SetProjMet (BACKEND)
 
virtual BACKEND GetProjMet () const
 
- Public Member Functions inherited from ttkAlgorithm
void UpdateThreadNumber ()
 
void SetThreadNumber (int threadNumber)
 
void SetUseAllCores (bool useAllCores)
 
void SetDebugLevel (int debugLevel)
 
void SetCompactTriangulationCacheSize (float cacheSize)
 
vtkDataArray * GetOptionalArray (const bool &enforceArrayIndex, const int &arrayIndex, const std::string &arrayName, vtkDataSet *const inputData, const int &inputPort=0)
 
vtkDataArray * GetOrderArray (vtkDataSet *const inputData, const int scalarArrayIdx, ttk::Triangulation *triangulation, const bool getGlobalOrder=false, const int orderArrayIdx=0, const bool enforceOrderArrayIdx=false)
 
vtkDataArray * checkForGlobalAndComputeOrderArray (vtkDataSet *const inputData, vtkDataArray *scalarArray, const int scalarArrayIdx, const bool getGlobalOrder, vtkDataArray *orderArray, ttk::Triangulation *triangulation, const bool enforceOrderArrayIdx)
 
vtkDataArray * ComputeOrderArray (vtkDataSet *const inputData, vtkDataArray *scalarArray, const int scalarArrayIdx, const bool getGlobalOrder, vtkDataArray *oldOrderArray, ttk::Triangulation *triangulation)
 
ttk::SimplexIdGetIdentifierArrayPtr (const bool &enforceArrayIndex, const int &arrayIndex, const std::string &arrayName, vtkDataSet *const inputData, std::vector< ttk::SimplexId > &spareStorage, const int inputPort=0, const bool printErr=true)
 
ttk::TriangulationGetTriangulation (vtkDataSet *dataSet)
 
int ProcessRequest (vtkInformation *request, vtkInformationVector **inputVectors, vtkInformationVector *outputVector) override
 
vtkDataSet * GetOutput ()
 
vtkDataSet * GetOutput (int)
 
void SetInputData (vtkDataSet *)
 
void SetInputData (int, vtkDataSet *)
 
void AddInputData (vtkDataSet *)
 
void AddInputData (int, vtkDataSet *)
 
template<typename inputType>
int checkEmptyMPIInput (inputType *input)
 This method tests whether the input is a nullptr. If the computation is being done on multiple processes, it is possible that the domain of one process or more is empty, but not others, therefore in that particular case the rest of the filter will not be computed but an error message will not be sent.
 
- Public Member Functions inherited from ttk::Debug
 Debug ()
 
 ~Debug () override
 
virtual int setDebugLevel (const int &debugLevel)
 
int setWrapper (const Wrapper *wrapper) override
 
int printMsg (const std::string &msg, const debug::Priority &priority=debug::Priority::INFO, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cout) const
 
int printMsg (const std::vector< std::string > &msgs, const debug::Priority &priority=debug::Priority::INFO, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cout) const
 
int printErr (const std::string &msg, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cerr) const
 
int printWrn (const std::string &msg, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cerr) const
 
int printMsg (const std::string &msg, const double &progress, const double &time, const int &threads, const double &memory, const debug::LineMode &lineMode=debug::LineMode::NEW, const debug::Priority &priority=debug::Priority::PERFORMANCE, std::ostream &stream=std::cout) const
 
int printMsg (const std::string &msg, const double &progress, const double &time, const debug::LineMode &lineMode=debug::LineMode::NEW, const debug::Priority &priority=debug::Priority::PERFORMANCE, std::ostream &stream=std::cout) const
 
int printMsg (const std::string &msg, const double &progress, const double &time, const int &threads, const debug::LineMode &lineMode=debug::LineMode::NEW, const debug::Priority &priority=debug::Priority::PERFORMANCE, std::ostream &stream=std::cout) const
 
int printMsg (const std::string &msg, const double &progress, const debug::LineMode &lineMode=debug::LineMode::NEW, const debug::Priority &priority=debug::Priority::PERFORMANCE, std::ostream &stream=std::cout) const
 
int printMsg (const std::string &msg, const double &progress, const debug::Priority &priority, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cout) const
 
int printMsg (const std::vector< std::vector< std::string > > &rows, const debug::Priority &priority=debug::Priority::INFO, const bool hasHeader=true, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cout) const
 
int printMsg (const debug::Separator &separator, const debug::LineMode &lineMode=debug::LineMode::NEW, const debug::Priority &priority=debug::Priority::INFO, std::ostream &stream=std::cout) const
 
int printMsg (const debug::Separator &separator, const debug::Priority &priority, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cout) const
 
int printMsg (const std::string &msg, const debug::Separator &separator, const debug::LineMode &lineMode=debug::LineMode::NEW, const debug::Priority &priority=debug::Priority::INFO, std::ostream &stream=std::cout) const
 
void setDebugMsgPrefix (const std::string &prefix)
 
- Public Member Functions inherited from ttk::BaseClass
 BaseClass ()
 
virtual ~BaseClass ()=default
 
int getThreadNumber () const
 
virtual int setThreadNumber (const int threadNumber)
 

Static Public Member Functions

static ttkPersistenceDiagramDictionaryDecodingNew ()
 
static int IsTypeOf (const char *type)
 
static ttkPersistenceDiagramDictionaryDecodingSafeDownCast (vtkObject *o)
 
- Static Public Member Functions inherited from ttkAlgorithm
static ttkAlgorithmNew ()
 
static int IsTypeOf (const char *type)
 
static ttkAlgorithmSafeDownCast (vtkObject *o)
 
static std::string GetOrderArrayName (vtkDataArray *const array)
 
static vtkInformationIntegerKey * SAME_DATA_TYPE_AS_INPUT_PORT ()
 

Protected Member Functions

 ttkPersistenceDiagramDictionaryDecoding ()
 
 ~ttkPersistenceDiagramDictionaryDecoding () override=default
 
int FillInputPortInformation (int port, vtkInformation *info) override
 
int FillOutputPortInformation (int port, vtkInformation *info) override
 
void GetOutputDiagrams (vtkMultiBlockDataSet *output, vtkTable *output_coordinates, const std::vector< ttk::DiagramType > &diags, std::vector< ttk::DiagramType > &atoms, vtkTable *weights_vtk, const std::vector< std::vector< double > > &weights, const double spacing, const double maxPersistence) const
 
int RequestData (vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
 
- Protected Member Functions inherited from ttkAlgorithm
 ttkAlgorithm ()
 
 ~ttkAlgorithm () override
 
void MPIGhostPipelinePreconditioning (vtkDataSet *input)
 
void MPIPipelinePreconditioning (vtkDataSet *input, std::vector< int > &neighbors, std::map< int, int > &neighToId, ttk::Triangulation *triangulation=nullptr)
 
bool checkGlobalIdValidity (ttk::LongSimplexId *globalIds, ttk::SimplexId simplexNumber, unsigned char *ghost, int *rankArray)
 
int GenerateGlobalIds (vtkDataSet *input, std::unordered_map< ttk::SimplexId, ttk::SimplexId > &vertGtoL, std::vector< int > &neighborRanks, std::map< int, int > &neighborsToId)
 
void MPITriangulationPreconditioning (ttk::Triangulation *triangulation, vtkDataSet *input)
 
virtual int RequestDataObject (vtkInformation *request, vtkInformationVector **inputVectors, vtkInformationVector *outputVector)
 
virtual int RequestInformation (vtkInformation *ttkNotUsed(request), vtkInformationVector **ttkNotUsed(inputVectors), vtkInformationVector *ttkNotUsed(outputVector))
 
virtual int RequestUpdateTime (vtkInformation *ttkNotUsed(request), vtkInformationVector **ttkNotUsed(inputVectors), vtkInformationVector *ttkNotUsed(outputVector))
 
virtual int RequestUpdateTimeDependentInformation (vtkInformation *ttkNotUsed(request), vtkInformationVector **ttkNotUsed(inputVectors), vtkInformationVector *ttkNotUsed(outputVector))
 
virtual int RequestUpdateExtent (vtkInformation *ttkNotUsed(request), vtkInformationVector **ttkNotUsed(inputVectors), vtkInformationVector *ttkNotUsed(outputVector))
 
virtual int RequestDataNotGenerated (vtkInformation *ttkNotUsed(request), vtkInformationVector **ttkNotUsed(inputVectors), vtkInformationVector *ttkNotUsed(outputVector))
 
virtual int RequestData (vtkInformation *ttkNotUsed(request), vtkInformationVector **ttkNotUsed(inputVectors), vtkInformationVector *ttkNotUsed(outputVector))
 
int FillInputPortInformation (int ttkNotUsed(port), vtkInformation *ttkNotUsed(info)) override
 
int FillOutputPortInformation (int ttkNotUsed(port), vtkInformation *ttkNotUsed(info)) override
 
- Protected Member Functions inherited from ttk::Debug
int printMsgInternal (const std::string &msg, const std::string &right, const std::string &filler, const debug::Priority &priority=debug::Priority::INFO, const debug::LineMode &lineMode=debug::LineMode::NEW, std::ostream &stream=std::cout) const
 
int printMsgInternal (const std::string &msg, const debug::Priority &priority, const debug::LineMode &lineMode, std::ostream &stream=std::cout) const
 
int welcomeMsg (std::ostream &stream)
 
- Protected Member Functions inherited from ttk::PersistenceDiagramDictionaryDecoding
void computeAtomsCoordinates (std::vector< ttk::DiagramType > &atoms, const std::vector< std::vector< double > > &vectorWeights, std::vector< std::array< double, 3 > > &coords, std::vector< std::array< double, 3 > > &trueCoords, std::vector< double > &xVector, std::vector< double > &yVector, std::vector< double > &zVector, const double spacing, const size_t nAtoms) const
 
 PersistenceDiagramDictionaryDecoding ()
 
void execute (std::vector< DiagramType > &dictDiagrams, std::vector< std::vector< double > > &vectorWeights, std::vector< DiagramType > &Barycenters) const
 

Protected Attributes

double Spacing {}
 
int ShowAtoms {1}
 
bool ComputePoints {false}
 
- Protected Attributes inherited from ttkAlgorithm
float CompactTriangulationCacheSize {0.2f}
 
- Protected Attributes inherited from ttk::Debug
int debugLevel_
 
std::string debugMsgPrefix_
 
std::string debugMsgNamePrefix_
 
- Protected Attributes inherited from ttk::BaseClass
bool lastObject_
 
int threadNumber_
 
Wrapperwrapper_
 
- Protected Attributes inherited from ttk::PersistenceDiagramDictionaryDecoding
BACKEND ProjMet {BACKEND::MDS}
 
bool ProgBarycenter {false}
 

Additional Inherited Members

- Protected Types inherited from ttk::PersistenceDiagramDictionaryDecoding
enum class  BACKEND { MDS = 0 , DICTIONARY = 1 }
 
- Static Protected Attributes inherited from ttk::Debug
static COMMON_EXPORTS debug::LineMode lastLineMode = ttk::debug::LineMode::NEW
 

Detailed Description

TTK processing package for the computation of a Dictionary of Persistence Diagrams and barycentric weights to approximate an ensemble of Persistence Diagrams.

Author
Keanu Sisouk keanu.nosp@m..sis.nosp@m.ouk@l.nosp@m.ip6..nosp@m.fr
Date
February 2026

Related publication
"Wasserstein Dictionaries of Persistence Diagrams"
Keanu Sisouk, Julie Delon and Julien Tierny
IEEE Transactions on Visualization and Computer Graphics, 2024.

See also
PersistenceDiagramDictionaryDecoding

Online examples:

Definition at line 39 of file ttkPersistenceDiagramDictionaryDecoding.h.

Member Typedef Documentation

◆ Superclass

Constructor & Destructor Documentation

◆ ttkPersistenceDiagramDictionaryDecoding()

ttkPersistenceDiagramDictionaryDecoding::ttkPersistenceDiagramDictionaryDecoding ( )
protected

Definition at line 25 of file ttkPersistenceDiagramDictionaryDecoding.cpp.

◆ ~ttkPersistenceDiagramDictionaryDecoding()

ttkPersistenceDiagramDictionaryDecoding::~ttkPersistenceDiagramDictionaryDecoding ( )
overrideprotecteddefault

Member Function Documentation

◆ FillInputPortInformation()

int ttkPersistenceDiagramDictionaryDecoding::FillInputPortInformation ( int port,
vtkInformation * info )
overrideprotected

Definition at line 31 of file ttkPersistenceDiagramDictionaryDecoding.cpp.

◆ FillOutputPortInformation()

int ttkPersistenceDiagramDictionaryDecoding::FillOutputPortInformation ( int port,
vtkInformation * info )
overrideprotected

Definition at line 44 of file ttkPersistenceDiagramDictionaryDecoding.cpp.

◆ GetClassName()

virtual const char * ttkPersistenceDiagramDictionaryDecoding::GetClassName ( )
virtual

Reimplemented from ttkAlgorithm.

◆ GetOutputDiagrams()

void ttkPersistenceDiagramDictionaryDecoding::GetOutputDiagrams ( vtkMultiBlockDataSet * output,
vtkTable * output_coordinates,
const std::vector< ttk::DiagramType > & diags,
std::vector< ttk::DiagramType > & atoms,
vtkTable * weights_vtk,
const std::vector< std::vector< double > > & weights,
const double spacing,
const double maxPersistence ) const
protected

Definition at line 154 of file ttkPersistenceDiagramDictionaryDecoding.cpp.

◆ GetProgBarycenter()

virtual int ttkPersistenceDiagramDictionaryDecoding::GetProgBarycenter ( )
virtual

◆ GetProjMet()

virtual BACKEND ttkPersistenceDiagramDictionaryDecoding::GetProjMet ( ) const
virtual

◆ GetShowAtoms()

virtual int ttkPersistenceDiagramDictionaryDecoding::GetShowAtoms ( )
virtual

◆ GetSpacing()

virtual double ttkPersistenceDiagramDictionaryDecoding::GetSpacing ( )
virtual

◆ IsA()

virtual int ttkPersistenceDiagramDictionaryDecoding::IsA ( const char * type)
virtual

Reimplemented from ttkAlgorithm.

◆ IsTypeOf()

static int ttkPersistenceDiagramDictionaryDecoding::IsTypeOf ( const char * type)
static

◆ New()

static ttkPersistenceDiagramDictionaryDecoding * ttkPersistenceDiagramDictionaryDecoding::New ( )
static

◆ RequestData()

int ttkPersistenceDiagramDictionaryDecoding::RequestData ( vtkInformation * request,
vtkInformationVector ** inputVector,
vtkInformationVector * outputVector )
overrideprotected

Definition at line 57 of file ttkPersistenceDiagramDictionaryDecoding.cpp.

◆ SafeDownCast()

static ttkPersistenceDiagramDictionaryDecoding * ttkPersistenceDiagramDictionaryDecoding::SafeDownCast ( vtkObject * o)
static

◆ SetProgBarycenter()

virtual void ttkPersistenceDiagramDictionaryDecoding::SetProgBarycenter ( int )
virtual

◆ SetProjMet() [1/2]

virtual void ttkPersistenceDiagramDictionaryDecoding::SetProjMet ( BACKEND )
virtual

◆ SetProjMet() [2/2]

virtual void ttkPersistenceDiagramDictionaryDecoding::SetProjMet ( int _arg)
virtual

◆ SetShowAtoms()

virtual void ttkPersistenceDiagramDictionaryDecoding::SetShowAtoms ( int )
virtual

◆ SetSpacing()

virtual void ttkPersistenceDiagramDictionaryDecoding::SetSpacing ( double )
virtual

Member Data Documentation

◆ ComputePoints

bool ttkPersistenceDiagramDictionaryDecoding::ComputePoints {false}
protected

Definition at line 86 of file ttkPersistenceDiagramDictionaryDecoding.h.

◆ ShowAtoms

int ttkPersistenceDiagramDictionaryDecoding::ShowAtoms {1}
protected

Definition at line 85 of file ttkPersistenceDiagramDictionaryDecoding.h.

◆ Spacing

double ttkPersistenceDiagramDictionaryDecoding::Spacing {}
protected

Definition at line 84 of file ttkPersistenceDiagramDictionaryDecoding.h.


The documentation for this class was generated from the following files: