Files
ThirdParty-6/ParaView-5.0.1/VTK/IO/AMR/vtkAMRFlashReader.cxx

276 lines
7.8 KiB
C++

/*=========================================================================
Program: Visualization Toolkit
Module: vtkAMRFlashReader.cxx
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.
=========================================================================*/
#include "vtkAMRFlashReader.h"
#include "vtkObjectFactory.h"
#include "vtkOverlappingAMR.h"
#include "vtkByteSwap.h"
#include "vtkUniformGrid.h"
#include "vtkDataArraySelection.h"
#include "vtkAMRBox.h"
#include "vtkDataSet.h"
#include "vtkCellData.h"
#include "vtkIntArray.h"
#include "vtkLongArray.h"
#include "vtkShortArray.h"
#include "vtkFloatArray.h"
#include "vtkDoubleArray.h"
#include "vtkLongLongArray.h"
#include "vtkUnsignedIntArray.h"
#include "vtkUnsignedCharArray.h"
#include "vtkUnsignedShortArray.h"
#include <cassert>
#include <vector>
#include <map>
#include <float.h>
#define H5_USE_16_API
#include "vtk_hdf5.h"
#include "vtkAMRFlashReaderInternal.h"
vtkStandardNewMacro(vtkAMRFlashReader);
//------------------------------------------------------------------------------
vtkAMRFlashReader::vtkAMRFlashReader()
{
this->IsReady = false;
this->Internal = new vtkFlashReaderInternal;
this->Initialize();
}
//------------------------------------------------------------------------------
vtkAMRFlashReader::~vtkAMRFlashReader()
{
delete [] this->FileName;
this->FileName = NULL;
delete this->Internal;
this->Internal = NULL;
}
//-----------------------------------------------------------------------------
void vtkAMRFlashReader::PrintSelf( std::ostream &os, vtkIndent indent )
{
this->Superclass::PrintSelf( os, indent );
}
//-----------------------------------------------------------------------------
void vtkAMRFlashReader::SetFileName( const char* fileName )
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
if( fileName && strcmp(fileName,"") &&
( ( this->FileName == NULL ) || strcmp( fileName, this->FileName ) ) )
{
if( this->FileName )
{
delete [] this->FileName;
this->FileName = NULL;
this->Internal->SetFileName( NULL );
}
this->FileName = new char[ strlen(fileName)+1 ];
strcpy( this->FileName, fileName );
this->FileName[ strlen( fileName ) ] = '\0';
this->IsReady = true;
this->Internal->SetFileName( this->FileName );
this->LoadedMetaData = false;
this->SetUpDataArraySelections();
this->InitializeArraySelections();
}
this->Modified();
}
//-----------------------------------------------------------------------------
void vtkAMRFlashReader::ReadMetaData()
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
this->Internal->ReadMetaData();
}
//-----------------------------------------------------------------------------
int vtkAMRFlashReader::GetBlockLevel( const int blockIdx )
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
if( !this->IsReady )
{
return(-1);
}
this->Internal->ReadMetaData();
if( blockIdx < 0 || blockIdx >= this->Internal->NumberOfBlocks )
{
vtkErrorMacro( "Block Index (" << blockIdx << ") is out-of-bounds!" );
return( -1 );
}
return( this->Internal->Blocks[ blockIdx ].Level-1 );
}
//-----------------------------------------------------------------------------
int vtkAMRFlashReader::GetNumberOfBlocks()
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
if( !this->IsReady )
{
return 0;
}
this->Internal->ReadMetaData();
return( this->Internal->NumberOfBlocks );
}
//-----------------------------------------------------------------------------
int vtkAMRFlashReader::GetNumberOfLevels()
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
if( !this->IsReady )
{
return 0;
}
this->Internal->ReadMetaData();
return( this->Internal->NumberOfLevels );
}
void vtkAMRFlashReader::ComputeStats(vtkFlashReaderInternal* internal, std::vector<int>& numBlocks, double min[3])
{
min[0] = min[1] = min[2] = DBL_MAX;
numBlocks.resize( this->Internal->NumberOfLevels, 0 );
for( int i=0; i < internal->NumberOfBlocks; ++i )
{
Block &theBlock = internal->Blocks[ i ];
double* gridMin = theBlock.MinBounds;
if( gridMin[0] < min[0] )
{
min[0] = gridMin[0];
}
if( gridMin[1] < min[1] )
{
min[1] = gridMin[1];
}
if( gridMin[2] < min[2] )
{
min[2] = gridMin[2];
}
int level = theBlock.Level-1;
numBlocks[level]++;
}
}
//-----------------------------------------------------------------------------
int vtkAMRFlashReader::FillMetaData( )
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
assert( "pre: metadata object is NULL" && (this->Metadata != NULL) );
this->Internal->ReadMetaData();
double origin[3];
std::vector<int> blocksPerLevel;
this->ComputeStats(this->Internal, blocksPerLevel, origin);
this->Metadata->Initialize(static_cast<int>(blocksPerLevel.size()), &blocksPerLevel[0]);
this->Metadata->SetGridDescription(VTK_XYZ_GRID);
this->Metadata->SetOrigin(origin);
std::vector< int > b2level;
b2level.resize( this->Internal->NumberOfLevels+1, 0 );
for( int i=0; i < this->Internal->NumberOfBlocks; ++i )
{
Block &theBlock = this->Internal->Blocks[i];
// Start numbering levels from 0!
int level = this->Internal->Blocks[ i ].Level-1;
int id = b2level[level];
int internalIdx = i;
int* dims = this->Internal->BlockGridDimensions;
//compute spacing
double spacing[3];
for(int d=0; d<3; ++d)
{
spacing[d] = (dims[d] > 1)?(theBlock.MaxBounds[d]-theBlock.MinBounds[d])/(dims[d]-1.0):1.0;
}
//compute AMRBox
vtkAMRBox box(theBlock.MinBounds, dims, spacing, origin,VTK_XYZ_GRID);
this->Metadata->SetSpacing(level, spacing);
this->Metadata->SetAMRBox(level, id, box);
this->Metadata->SetAMRBlockSourceIndex(level,id, internalIdx);
b2level[ level ]++;
} // END for all blocks
return( 1 );
}
//-----------------------------------------------------------------------------
vtkUniformGrid* vtkAMRFlashReader::GetAMRGrid( const int blockIdx )
{
if( !this->IsReady )
{
return NULL;
}
double blockMin[3];
double blockMax[3];
double spacings[3];
for( int i=0; i < 3; ++i )
{
blockMin[i] = this->Internal->Blocks[ blockIdx ].MinBounds[ i ];
blockMax[i] = this->Internal->Blocks[ blockIdx ].MaxBounds[ i ];
spacings[i] = (this->Internal->BlockGridDimensions[i]>1)?
(blockMax[i]-blockMin[i])/
(this->Internal->BlockGridDimensions[i]-1.0) : 1.0;
}
vtkUniformGrid *ug = vtkUniformGrid::New();
ug->SetDimensions( this->Internal->BlockGridDimensions );
ug->SetOrigin( blockMin[0], blockMin[1], blockMin[2] );
ug->SetSpacing( spacings );
return( ug );
}
//-----------------------------------------------------------------------------
void vtkAMRFlashReader::GetAMRGridData(
const int blockIdx, vtkUniformGrid *block, const char *field)
{
assert( "pre: AMR block is NULL" && (block != NULL) );
this->Internal->GetBlockAttribute( field, blockIdx, block );
}
//-----------------------------------------------------------------------------
void vtkAMRFlashReader::SetUpDataArraySelections()
{
assert( "pre: Internal Flash Reader is NULL" && (this->Internal != NULL) );
this->Internal->ReadMetaData();
int numAttrs = static_cast< int >( this->Internal->AttributeNames.size() );
for( int i=0; i < numAttrs; ++i )
{
this->CellDataArraySelection->AddArray(
this->Internal->AttributeNames[ i ].c_str() );
}
}