-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathcatalyst_adaptor.h
89 lines (69 loc) · 3.01 KB
/
catalyst_adaptor.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
83
84
85
86
87
88
89
#ifndef CATALYST_ADAPTOR_H
#define CATALYST_ADAPTOR_H
#include <vtkUniformGrid.h>
#include <vtkNonOverlappingAMR.h>
#include <vtkCPProcessor.h>
#include <vtkSmartPointer.h>
#include <unordered_map>
// We need this struct to store both a pointer to the
// VTK grid object for a patch and its AMR refinement level
struct gridPatch
{
int level;
vtkSmartPointer<vtkUniformGrid> VTKGrid;
};
// This class is implemented using the "singleton" design pattern,
// to make sure that Catalyst is only initialised in a single
// instance (it is unclear if multiple instances are supported),
// and to get global access to this instance
class catalystAdaptor
{
public:
// Replaces the constructor to obtain "singleton" behaviour
static catalystAdaptor& getInstance();
~catalystAdaptor();
// Catalyst can run in two modes - full visualisation using Python script,
// or just output in VTK file format. Note that only one can be used
// in a given simulation run.
int initialiseWithPython(const std::string& scriptName);
int initialiseVTKOutput(const int frequency, const double time, const std::string& fileName);
// Add a new vtkUniformGrid patch with given parameters
// Patch IDs must be handled by the simulation program
// to make sure that they are consistent with grid
// patches used by the solver
int addPatch(const int patchId, const int level,
const int nx, const int ny,
const double dx, const double dy,
const double x0, const double y0);
// Remove patch with given ID
int removePatch(const int patchId);
// Update simulation data - must be called in each time step and before
// running the coprocessor
// IMPORTANT: These methods use "zero copy", Catalyst will access the
// original data array for visualisation. "data" must therefore still
// be in scope and in consistent state!
int updateFieldSingle(const int patchId, const std::string& name, float* data);
int updateFieldDouble(const int patchId, const std::string& name, double* data);
// Check if coprocessor should be run at this time/time step
bool requestDataDescription(const double time, const unsigned int timeStep);
// Run the visualisation pipeline
int runCoprocessor();
// Prevent copying and moving
catalystAdaptor(const catalystAdaptor&) = delete;
catalystAdaptor(catalystAdaptor&&) = delete;
catalystAdaptor& operator=(const catalystAdaptor&) = delete;
catalystAdaptor& operator=(catalystAdaptor&&) = delete;
private:
// Constructor is private to obtain singleton behaviour
catalystAdaptor();
// Construct VTK AMR grid container out of the grid patches
void setAMRPatches(vtkSmartPointer<vtkNonOverlappingAMR> AMRGrid);
// Stores grid patches, to avoid having to reconstruct them in every
// refinement step
std::unordered_map<int,gridPatch> patches;
// Pointers to the Catalyst processor and the data structure
// that describes simulation grid and field data
vtkCPProcessor* Processor;
vtkCPDataDescription* dataDescription;
};
#endif