TTK
Loading...
Searching...
No Matches
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | List of all members
ttkTopologicalCompressionWriter Class Reference

VTK-filter that wraps the topologicalCompressionWriter processing package. More...

#include <ttkTopologicalCompressionWriter.h>

Inheritance diagram for ttkTopologicalCompressionWriter:
ttkAlgorithm ttk::TopologicalCompression 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 void SetFileName (const char *)
 
virtual char * GetFileName ()
 
virtual double GetTolerance ()
 
virtual void SetTolerance (double)
 
virtual double GetMaximumError ()
 
virtual void SetMaximumError (double)
 
virtual double GetZFPTolerance ()
 
virtual void SetZFPTolerance (double)
 
virtual bool GetZFPOnly ()
 
virtual void SetZFPOnly (bool)
 
virtual int GetCompressionType ()
 
virtual void SetCompressionType (int)
 
virtual int GetNbSegments ()
 
virtual void SetNbSegments (int)
 
virtual int GetNbVertices ()
 
virtual void SetNbVertices (int)
 
virtual std::string GetSQMethod ()
 
virtual void SetSQMethod (const std::string &)
 
virtual void SetSubdivide (bool)
 
virtual bool GetSubdivide ()
 
virtual void SetUseTopologicalSimplification (bool)
 
virtual bool GetUseTopologicalSimplification ()
 
void SetSQMethodPV (int c)
 
int Write ()
 
vtkDataObject * GetInput ()
 
void SetInputData (vtkDataObject *input)
 
- 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 ttkTopologicalCompressionWriterNew ()
 
static int IsTypeOf (const char *type)
 
static ttkTopologicalCompressionWriterSafeDownCast (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

 ttkTopologicalCompressionWriter ()
 
int FillInputPortInformation (int port, vtkInformation *info) 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::TopologicalCompression
 TopologicalCompression ()
 
template<class dataType , typename triangulationType = AbstractTriangulation>
int execute (const dataType *const inputData, const SimplexId *const inputOffsets, dataType *outputData, const triangulationType &triangulation)
 
template<class dataType , typename triangulationType >
int computePersistencePairs (std::vector< std::tuple< SimplexId, SimplexId, dataType > > &JTPairs, std::vector< std::tuple< SimplexId, SimplexId, dataType > > &STPairs, const dataType *const inputScalars_, const SimplexId *const inputOffsets, const triangulationType &triangulation)
 
template<typename dataType , typename triangulationType >
int compressForPersistenceDiagram (int vertexNumber, const dataType *const inputData, const SimplexId *const inputOffset, dataType *outputData, const double &tol, const triangulationType &triangulation)
 
int computeOther () const
 
template<typename dataType >
int compressForOther (int vertexNumber, const dataType *const inputData, const SimplexId *const inputOffsets, dataType *outputData, const double &tol) const
 
void setCompressionType (int compressionType)
 
void setSQ (const std::string &sqMethod)
 
void setZFPOnly (bool z)
 
void setSubdivide (bool b)
 
void setMaximumError (double maximumError)
 
void setTolerance (const double data)
 
void setUseTopologicalSimplification (bool useTopologicalSimplification)
 
void setFileName (char *fn)
 
void preconditionTriangulation (AbstractTriangulation *const triangulation)
 
int getNbVertices () const
 
int getNbSegments () const
 
std::vector< int > & getSegmentation ()
 
std::vector< std::tuple< double, int > > & getMapping ()
 
std::vector< std::tuple< int, double, int > > & getCriticalConstraints ()
 
int getCompressionType () const
 
int getSQMethod () const
 
int getDataScalarType () const
 
int * getDataExtent ()
 
double * getDataSpacing ()
 
double * getDataOrigin ()
 
double getTolerance () const
 
double getZFPTolerance () const
 
void relToAbsZFPTolerance (const double zfpRelTol, const std::array< double, 2 > &sfRange)
 Switch from a relative (% of scalar field range) to an absolute ZFP tolerance.
 
bool getZFPOnly () const
 
const std::vector< char > & getDataArrayName () const
 
std::vector< double > & getDecompressedData ()
 
std::vector< SimplexId > & getDecompressedOffsets ()
 
std::vector< SimplexId > & getCompressedOffsets ()
 
template<typename T >
Read (FILE *fm) const
 
template<typename T >
void ReadByteArray (FILE *fm, T *buffer, size_t length) const
 
template<typename T >
void Write (FILE *fm, T data) const
 
template<typename T >
void WriteByteArray (FILE *fm, const T *buffer, size_t length) const
 
int ReadCompactSegmentation (FILE *fm, std::vector< int > &segmentation, int &numberOfVertices, int &numberOfSegments) const
 
int ReadPersistenceIndex (FILE *fm, std::vector< std::tuple< double, int > > &mappings, std::vector< std::tuple< double, int > > &mappingsSortedPerValue, std::vector< std::tuple< int, double, int > > &constraints, double &min, double &max, int &nbConstraints) const
 
int ReadMetaData (FILE *fm)
 
template<typename triangulationType >
int ReadFromFile (FILE *fm, const triangulationType &triangulation)
 
int WriteCompactSegmentation (FILE *fm, const std::vector< int > &segmentation, int numberOfVertices, int numberOfSegments) const
 
int WritePersistenceIndex (FILE *fm, std::vector< std::tuple< double, int > > &mapping, std::vector< std::tuple< int, double, int > > &constraints) const
 
int WriteMetaData (FILE *fp, int compressionType, bool zfpOnly, const char *sqMethod, int dataType, int *dataExtent, double *dataSpacing, double *dataOrigin, double tolerance, double zfpTolerance, const std::string &dataArrayName)
 
int WriteToFile (FILE *fp, int compressionType, bool zfpOnly, const char *sqMethod, int dataType, int *dataExtent, double *dataSpacing, double *dataOrigin, double *data, double tolerance, double zfpTolerance, const std::string &dataArrayName)
 
template<typename dataType >
void CropIntervals (std::vector< std::tuple< dataType, int > > &mappings, std::vector< std::tuple< dataType, int > > &mappingsSortedPerValue, double min, double max, int vertexNumber, double *array, std::vector< int > &Seg) const
 
template<typename dataType >
int compressForOther (int ttkNotUsed(vertexNumber), const dataType *const ttkNotUsed(inputData), const SimplexId *const ttkNotUsed(inputOffsets), dataType *ttkNotUsed(outputData), const double &ttkNotUsed(tol)) const
 

Additional Inherited Members

- Static Protected Member Functions inherited from ttk::TopologicalCompression
static unsigned int log2 (int val)
 
static bool cmp (const std::tuple< double, int > &a, const std::tuple< double, int > &b)
 
static bool cmp2 (const std::tuple< double, int > &a, const std::tuple< double, int > &b)
 
- 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::TopologicalCompression
LegacyTopologicalSimplification topologicalSimplification {}
 
ftm::FTMTreePP ftmTreePP
 
int compressionType_ {}
 
bool ZFPOnly {false}
 
double ZFPTolerance {50}
 
int SQMethodInt {}
 
double Tolerance {10}
 
double MaximumError {10}
 
int CompressionType {static_cast<int>(CompressionType::PersistenceDiagram)}
 
std::string SQMethod {}
 
bool Subdivide {false}
 
bool UseTopologicalSimplification {true}
 
int dataScalarType_ {}
 
int dataExtent_ [6]
 
double dataSpacing_ [3]
 
double dataOrigin_ [3]
 
std::vector< char > dataArrayName_ {}
 
std::vector< int > segmentation_ {}
 
std::vector< std::tuple< double, int > > mapping_ {}
 
std::vector< std::tuple< int, double, int > > criticalConstraints_ {}
 
int NbVertices {0}
 
int NbSegments {0}
 
int rawFileLength {0}
 
std::vector< double > decompressedData_ {}
 
std::vector< SimplexIddecompressedOffsets_ {}
 
std::vector< SimplexIdcompressedOffsets_ {}
 
int vertexNumberRead_ {}
 
char * fileName {}
 
const char * magicBytes_ {"TTKCompressedFileFormat"}
 
const unsigned long formatVersion_ {2}
 
- Static Protected Attributes inherited from ttk::Debug
static COMMON_EXPORTS debug::LineMode lastLineMode = ttk::debug::LineMode::NEW
 

Detailed Description

VTK-filter that wraps the topologicalCompressionWriter processing package.

Author
Maxime Soler soler.nosp@m..max.nosp@m.ime@t.nosp@m.otal.nosp@m..com
Date
21/04/2017

Online examples:

Definition at line 26 of file ttkTopologicalCompressionWriter.h.

Member Typedef Documentation

◆ Superclass

Definition at line 33 of file ttkTopologicalCompressionWriter.h.

Constructor & Destructor Documentation

◆ ttkTopologicalCompressionWriter()

ttkTopologicalCompressionWriter::ttkTopologicalCompressionWriter ( )
protected

Definition at line 17 of file ttkTopologicalCompressionWriter.cpp.

Member Function Documentation

◆ FillInputPortInformation()

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

Definition at line 22 of file ttkTopologicalCompressionWriter.cpp.

◆ GetClassName()

virtual const char * ttkTopologicalCompressionWriter::GetClassName ( )
virtual

Reimplemented from ttkAlgorithm.

◆ GetCompressionType()

virtual int ttkTopologicalCompressionWriter::GetCompressionType ( )
virtual

◆ GetFileName()

virtual char * ttkTopologicalCompressionWriter::GetFileName ( )
virtual

◆ GetInput()

vtkDataObject * ttkTopologicalCompressionWriter::GetInput ( )

Definition at line 120 of file ttkTopologicalCompressionWriter.cpp.

◆ GetMaximumError()

virtual double ttkTopologicalCompressionWriter::GetMaximumError ( )
virtual

◆ GetNbSegments()

virtual int ttkTopologicalCompressionWriter::GetNbSegments ( )
virtual

◆ GetNbVertices()

virtual int ttkTopologicalCompressionWriter::GetNbVertices ( )
virtual

◆ GetSQMethod()

virtual std::string ttkTopologicalCompressionWriter::GetSQMethod ( )
virtual

◆ GetSubdivide()

virtual bool ttkTopologicalCompressionWriter::GetSubdivide ( )
virtual

◆ GetTolerance()

virtual double ttkTopologicalCompressionWriter::GetTolerance ( )
virtual

◆ GetUseTopologicalSimplification()

virtual bool ttkTopologicalCompressionWriter::GetUseTopologicalSimplification ( )
virtual

◆ GetZFPOnly()

virtual bool ttkTopologicalCompressionWriter::GetZFPOnly ( )
virtual

◆ GetZFPTolerance()

virtual double ttkTopologicalCompressionWriter::GetZFPTolerance ( )
virtual

◆ IsA()

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

Reimplemented from ttkAlgorithm.

◆ IsTypeOf()

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

◆ New()

static ttkTopologicalCompressionWriter * ttkTopologicalCompressionWriter::New ( )
static

◆ SafeDownCast()

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

◆ SetCompressionType()

virtual void ttkTopologicalCompressionWriter::SetCompressionType ( int  )
virtual

◆ SetFileName()

virtual void ttkTopologicalCompressionWriter::SetFileName ( const char *  )
virtual

◆ SetInputData()

void ttkTopologicalCompressionWriter::SetInputData ( vtkDataObject *  input)

Definition at line 128 of file ttkTopologicalCompressionWriter.cpp.

◆ SetMaximumError()

virtual void ttkTopologicalCompressionWriter::SetMaximumError ( double  )
virtual

◆ SetNbSegments()

virtual void ttkTopologicalCompressionWriter::SetNbSegments ( int  )
virtual

◆ SetNbVertices()

virtual void ttkTopologicalCompressionWriter::SetNbVertices ( int  )
virtual

◆ SetSQMethod()

virtual void ttkTopologicalCompressionWriter::SetSQMethod ( const std::string &  )
virtual

◆ SetSQMethodPV()

void ttkTopologicalCompressionWriter::SetSQMethodPV ( int  c)
inline

Definition at line 68 of file ttkTopologicalCompressionWriter.h.

◆ SetSubdivide()

virtual void ttkTopologicalCompressionWriter::SetSubdivide ( bool  )
virtual

◆ SetTolerance()

virtual void ttkTopologicalCompressionWriter::SetTolerance ( double  )
virtual

◆ SetUseTopologicalSimplification()

virtual void ttkTopologicalCompressionWriter::SetUseTopologicalSimplification ( bool  )
virtual

◆ SetZFPOnly()

virtual void ttkTopologicalCompressionWriter::SetZFPOnly ( bool  )
virtual

◆ SetZFPTolerance()

virtual void ttkTopologicalCompressionWriter::SetZFPTolerance ( double  )
virtual

◆ Write()

int ttkTopologicalCompressionWriter::Write ( )

Definition at line 31 of file ttkTopologicalCompressionWriter.cpp.


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