vtkAMRDataSetCache.h 3.66 KB
Newer Older
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
/*=========================================================================

 Program:   Visualization Toolkit
 Module:    vtkAMRDataSetCache.h

 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 vtkAMRDataSetCache.h -- A cache for AMR blocks and block data
//
// .SECTION Description
//  A concrete implementation of vtkObject that provides functionality for
//  caching AMR blocks. The primary intent of this class is to be used by the
//  AMR reader infrastructure for caching blocks/data in memory to minimize
//  out-of-core operations.

#ifndef VTKAMRDATASETCACHE_H_
#define VTKAMRDATASETCACHE_H_

#include "vtkObject.h"
27
#include <map> // For STL map used as the data-structure for the cache.
28
29
30
31
32
33
34
35
36

class vtkUniformGrid;
class vtkDataArray;

class VTK_AMR_EXPORT vtkAMRDataSetCache : public vtkObject
{
  public:
    static vtkAMRDataSetCache* New();
    vtkTypeMacro( vtkAMRDataSetCache, vtkObject );
37
    void PrintSelf(ostream &os, vtkIndent indent );
38
39
40

    // Description:
    // Inserts an AMR block to the cache
41
    void InsertAMRBlock(int compositeIdx,vtkUniformGrid *amrGrid);
42
43
44
45
46

    // Description:
    // Inserts a point data array to an already cached block
    // NOTE: this->HasAMRBlock( compositeIdx ) == true
    void InsertAMRBlockPointData(
47
        int compositeIdx, vtkDataArray *dataArray );
48
49
50
51
52

    // Description:
    // Inserts a cell data array to an already cached block
    // NOTE: this->HasAMRBlock( compositeIdx ) == true
    void InsertAMRBlockCellData(
53
        int compositeIdx, vtkDataArray *dataArray );
54
55
56
57
58
59

    // Description:
    // Given the name of the cell array and AMR block composite index, this
    // method returns a pointer to the cell data array.
    // NOTE: Null is returned if the cell array and/or block is not cached.
    vtkDataArray* GetAMRBlockCellData(
60
        int compositeIdx, const char *dataName );
61
62
63
64
65
66

    // Description:
    // Given the name of the point array and AMR block composite index, this
    // method returns a pointer to the point data array.
    // NOTE: Null is returend if the point array and /or block is not cached.
    vtkDataArray* GetAMRBlockPointData(
67
        int compositeIdx, const char *dataName );
68
69
70
71

    // Description:
    // Given the composite index, this method returns the AMR block.
    // NOTE: Null is returned if the AMR block does not exist in the cache.
72
    vtkUniformGrid* GetAMRBlock(int compositeIdx );
73
74
75
76

    // Description:
    // Checks if the cell data array, associated with the provided name, has
    // been cached for the AMR block with the given composite index.
77
    bool HasAMRBlockCellData(int compositeIdx, const char *name);
78
79
80
81

    // Description:
    // Checks if the point data array, associated with the provided name, has
    // been cached for the AMR block with the given composite index.
82
    bool HasAMRBlockPointData(int compositeIdx, const char *name);
83
84
85
86
87
88
89
90
91

    // Description:
    // Checks if the AMR block associated with the given composite is cached.
    bool HasAMRBlock( const int compositeIdx );

  protected:
    vtkAMRDataSetCache();
    virtual ~vtkAMRDataSetCache();

92
//BTX
93
    typedef std::map< int, vtkUniformGrid* > AMRCacheType;
94
95
    AMRCacheType Cache;
//ETX
96
97
98
99
100
101
102

  private:
    vtkAMRDataSetCache( const vtkAMRDataSetCache& ); // Not implemented
    void operator=( const vtkAMRDataSetCache& ); // Not implemented
};

#endif /* VTKAMRDATASETCACHE_H_ */