-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBOVTimeStepImage.h
82 lines (68 loc) · 1.86 KB
/
BOVTimeStepImage.h
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
/*
____ _ __ ____ __ ____
/ __/___(_) / ___ ____/ __ \__ _____ ___ / /_ / _/__ ____
_\ \/ __/ / _ \/ -_) __/ /_/ / // / -_|_-</ __/ _/ // _ \/ __/
/___/\__/_/_.__/\__/_/ \___\_\_,_/\__/___/\__/ /___/_//_/\__(_)
Copyright 2012 SciberQuest Inc.
*/
#ifndef __BOVTimeStepImage_h
#define __BOVTimeStepImage_h
#ifdef SQTK_WITHOUT_MPI
typedef void * MPI_Comm;
typedef void * MPI_Info;
#else
#include <mpi.h>
#endif
#include <vector>
using std::vector;
#include <iostream>
using std::ostream;
class BOVMetaData;
class BOVScalarImage;
class BOVVectorImage;
class BOVTensorImage;
class BOVSymetricTensorImage;
class BOVScalarImageIterator;
class BOVVectorImageIterator;
class BOVTensorImageIterator;
class BOVSymetricTensorImageIterator;
/// Collection of file handles for a single timestep.
/**
A collection of file handles to the scalar, vector, and tensor
data that together comprise this time step.
*/
class BOVTimeStepImage
{
public:
BOVTimeStepImage(
MPI_Comm comm,
MPI_Info hints,
int stepId,
BOVMetaData *metaData);
~BOVTimeStepImage();
int GetNumberOfImages() const
{
return
this->Scalars.size()+
this->Vectors.size()+
this->Tensors.size()+
this->SymetricTensors.size();
}
private:
vector<BOVScalarImage*> Scalars;
vector<BOVVectorImage*> Vectors;
vector<BOVVectorImage*> Tensors;
vector<BOVVectorImage*> SymetricTensors;
private:
BOVTimeStepImage();
BOVTimeStepImage(const BOVTimeStepImage&);
const BOVTimeStepImage &operator=(const BOVTimeStepImage &);
private:
friend ostream &operator<<(ostream &os, const BOVTimeStepImage &si);
friend class BOVScalarImageIterator;
friend class BOVVectorImageIterator;
friend class BOVTensorImageIterator;
friend class BOVSymetricTensorImageIterator;
};
ostream &operator<<(ostream &os, const BOVTimeStepImage &si);
#endif