You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
194 lines
6.1 KiB
194 lines
6.1 KiB
/*=========================================================================
|
|
|
|
Program: Visualization Toolkit
|
|
Module: $RCSfile: vtkAVSucdReader.h,v $
|
|
|
|
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
|
|
All rights reserved.
|
|
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
PURPOSE. See the above copyright notice for more information.
|
|
|
|
=========================================================================*/
|
|
// .NAME vtkAVSucdReader - reads a dataset in AVS "UCD" format
|
|
// .SECTION Description
|
|
// vtkAVSucdReader creates an unstructured grid dataset. It reads binary or
|
|
// ASCII files stored in UCD format, with optional data stored at the nodes
|
|
// or at the cells of the model. A cell-based fielddata stores the material
|
|
// id. The class can automatically detect the endian-ness of the binary files.
|
|
|
|
// .SECTION Thanks
|
|
// Thanks to Guenole Harel and Emmanuel Colin (Supelec engineering school,
|
|
// France) and Jean M. Favre (CSCS, Switzerland) who co-developed this class.
|
|
// Thanks to Isabelle Surin (isabelle.surin at cea.fr, CEA-DAM, France) who
|
|
// supervised the internship of the first two authors. Thanks to Daniel
|
|
// Aguilera (daniel.aguilera at cea.fr, CEA-DAM, France) who contributed code
|
|
// and advice. Please address all comments to Jean Favre (jfavre at cscs.ch)
|
|
|
|
// .SECTION See Also
|
|
// vtkGAMBITReader
|
|
|
|
#ifndef __vtkAVSucdReader_h
|
|
#define __vtkAVSucdReader_h
|
|
|
|
#include "vtkUnstructuredGridAlgorithm.h"
|
|
|
|
class vtkIntArray;
|
|
class vtkFloatArray;
|
|
class vtkIdTypeArray;
|
|
class vtkDataArraySelection;
|
|
|
|
class VTK_IO_EXPORT vtkAVSucdReader : public vtkUnstructuredGridAlgorithm
|
|
{
|
|
public:
|
|
static vtkAVSucdReader *New();
|
|
vtkTypeRevisionMacro(vtkAVSucdReader,vtkUnstructuredGridAlgorithm);
|
|
void PrintSelf(ostream& os, vtkIndent indent);
|
|
|
|
// Description:
|
|
// Specify file name of AVS UCD datafile to read
|
|
vtkSetStringMacro(FileName);
|
|
vtkGetStringMacro(FileName);
|
|
|
|
// Description:
|
|
// Is the file to be read written in binary format (as opposed to ascii).
|
|
vtkSetMacro(BinaryFile, int);
|
|
vtkGetMacro(BinaryFile, int);
|
|
vtkBooleanMacro(BinaryFile, int);
|
|
|
|
// Description:
|
|
// Get the total number of cells.
|
|
vtkGetMacro(NumberOfCells,int);
|
|
|
|
// Description:
|
|
// Get the total number of nodes.
|
|
vtkGetMacro(NumberOfNodes,int);
|
|
|
|
// Description:
|
|
// Get the number of data fields at the nodes.
|
|
vtkGetMacro(NumberOfNodeFields,int);
|
|
|
|
// Description:
|
|
// Get the number of data fields at the cell centers.
|
|
vtkGetMacro(NumberOfCellFields,int);
|
|
|
|
// Description:
|
|
// Get the number of data fields for the model. Unused because VTK
|
|
// has no methods for it.
|
|
vtkGetMacro(NumberOfFields,int);
|
|
|
|
// Description:
|
|
// Get the number of data components at the nodes and cells.
|
|
vtkGetMacro(NumberOfNodeComponents,int);
|
|
vtkGetMacro(NumberOfCellComponents,int);
|
|
|
|
// Description:
|
|
// Set/Get the endian-ness of the binary file.
|
|
void SetByteOrderToBigEndian();
|
|
void SetByteOrderToLittleEndian();
|
|
const char *GetByteOrderAsString();
|
|
|
|
vtkSetMacro(ByteOrder, int);
|
|
vtkGetMacro(ByteOrder, int);
|
|
|
|
// Description:
|
|
// The following methods allow selective reading of solutions fields. by
|
|
// default, ALL data fields are the nodes and cells are read, but this can
|
|
// be modified.
|
|
int GetNumberOfPointArrays();
|
|
int GetNumberOfCellArrays();
|
|
const char* GetPointArrayName(int index);
|
|
const char* GetCellArrayName(int index);
|
|
int GetPointArrayStatus(const char* name);
|
|
int GetCellArrayStatus(const char* name);
|
|
void SetPointArrayStatus(const char* name, int status);
|
|
void SetCellArrayStatus(const char* name, int status);
|
|
|
|
void DisableAllCellArrays();
|
|
void EnableAllCellArrays();
|
|
void DisableAllPointArrays();
|
|
void EnableAllPointArrays();
|
|
|
|
// get min and max value for the index-th value of a cell component
|
|
// index varies from 0 to (veclen - 1)
|
|
void GetCellDataRange(int cellComp, int index, float *min, float *max);
|
|
|
|
// get min and max value for the index-th value of a node component
|
|
// index varies from 0 to (veclen - 1)
|
|
void GetNodeDataRange(int nodeComp, int index, float *min, float *max);
|
|
|
|
protected:
|
|
vtkAVSucdReader();
|
|
~vtkAVSucdReader();
|
|
int RequestInformation(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
|
|
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
|
|
|
|
char *FileName;
|
|
int BinaryFile;
|
|
|
|
int NumberOfNodes;
|
|
int NumberOfCells;
|
|
int NumberOfNodeFields;
|
|
int NumberOfNodeComponents;
|
|
int NumberOfCellComponents;
|
|
int NumberOfCellFields;
|
|
int NumberOfFields;
|
|
int NlistNodes;
|
|
|
|
ifstream *FileStream;
|
|
|
|
vtkDataArraySelection* PointDataArraySelection;
|
|
vtkDataArraySelection* CellDataArraySelection;
|
|
|
|
int DecrementNodeIds;
|
|
int ByteOrder;
|
|
int GetLabel(char *string, int number, char *label);
|
|
//BTX
|
|
enum
|
|
{
|
|
FILE_BIG_ENDIAN=0,
|
|
FILE_LITTLE_ENDIAN=1
|
|
};
|
|
enum UCDCell_type
|
|
{
|
|
PT = 0,
|
|
LINE = 1,
|
|
TRI = 2,
|
|
QUAD = 3,
|
|
TET = 4,
|
|
PYR = 5,
|
|
PRISM = 6,
|
|
HEX = 7
|
|
};
|
|
|
|
struct DataInfo {
|
|
long foffset; // offset in binary file
|
|
int veclen; // number of components in the node or cell variable
|
|
float min[3]; // pre-calculated data minima (max size 3 for vectors)
|
|
float max[3]; // pre-calculated data maxima (max size 3 for vectors)
|
|
};
|
|
//ETX
|
|
|
|
DataInfo *NodeDataInfo;
|
|
DataInfo *CellDataInfo;
|
|
|
|
private:
|
|
void ReadFile(vtkUnstructuredGrid *output);
|
|
void ReadGeometry(vtkUnstructuredGrid *output);
|
|
void ReadNodeData(vtkUnstructuredGrid *output);
|
|
void ReadCellData(vtkUnstructuredGrid *output);
|
|
|
|
int ReadFloatBlock(int n, float *block);
|
|
int ReadIntBlock(int n, int *block);
|
|
void ReadXYZCoords(vtkFloatArray *coords);
|
|
void ReadBinaryCellTopology(vtkIntArray *material, int *types,
|
|
vtkIdTypeArray *listcells);
|
|
void ReadASCIICellTopology(vtkIntArray *material, vtkUnstructuredGrid *output);
|
|
|
|
vtkAVSucdReader(const vtkAVSucdReader&); // Not implemented.
|
|
void operator=(const vtkAVSucdReader&); // Not implemented.
|
|
};
|
|
|
|
#endif
|
|
|