File: FEDriver.cxx

package info (click to toggle)
paraview 5.13.2%2Bdfsg-3
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 544,220 kB
  • sloc: cpp: 3,374,605; ansic: 1,332,409; python: 150,381; xml: 122,166; sql: 65,887; sh: 7,317; javascript: 5,262; yacc: 4,417; java: 3,977; perl: 2,363; lex: 1,929; f90: 1,397; makefile: 170; objc: 153; tcl: 59; pascal: 50; fortran: 29
file content (121 lines) | stat: -rw-r--r-- 3,357 bytes parent folder | download
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
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
// SPDX-FileCopyrightText: Copyright (c) Kitware Inc.
// SPDX-License-Identifier: BSD-3-Clause
/**
An example catalyst pipeline that includes temporal processing.
The "simulation" has a number of particles bouncing around in a cube.
Unlike other Catalyst examples in this caseCatalyst maintains a configurably sized cache of the most
recent timesteps worth of produced data. The cache is suitable
for ParaView's time varying filters and for ex post facto / backtracking
analysis. Here the pipeline fully flows only when some
interesting event happens. When it does, the pipelne has access
to more than just the current timestep to perform analysis on.

The command line arguments are:

-DIMS K J I // size of the volume, defaut is 70, 60, 44
-TSTEPS t //number of simulation timesteps, default is 30
-NUMPARTICLES p // number of particles in the box
-CACHESIZE c // number of timesteps to cache
-HOME // When ParaView is compiles with PARAVIEW_USE_MEMKIND, a directory to memory map the cache
in, ideal Optane with -o dax
-ENABLECXXPIPELINE // runs the default C++ Catalyst Pipeline in addition to provided python ones
PythonPipeline... //One or more Catalyst Python Pipelines
*/

#ifdef USE_CATALYST
#include "FEAdaptor.h"
#endif
#include "FEDataStructures.h"

#include <mpi.h>

#include <vtkSmartPointer.h>
#include <vtkTimerLog.h>

int main(int argc, char* argv[])
{
  MPI_Init(&argc, &argv);
  unsigned int numPoints[3] = { 70, 60, 44 };
  unsigned int numberOfTimeSteps = 20;
  unsigned int delay = 1000;
  int numparticles = 2;
  int ac = 0;
  char** av = new char*[argc];
  for (int i = 0; i < argc; i++)
  {
    if (!strcmp(argv[i], "-DIMS"))
    {
      for (int j = 0; j < 3; j++)
      {
        numPoints[j] = atoi(argv[i + j + 1]);
      }
      i += 3;
    }
    else if (!strcmp(argv[i], "-TSTEPS"))
    {
      numberOfTimeSteps = atoi(argv[i + 1]);
      i += 1;
    }
    else if (!strcmp(argv[i], "-DELAY"))
    {
      delay = atoi(argv[i + 1]);
      i += 1;
    }
    else if (!strcmp(argv[i], "-NUMPARTICLES"))
    {
      numparticles = atoi(argv[i + 1]);
      i += 1;
    }
    else
    {
      // pass unmatched arguments through for FEAdaptor to use
      av[ac] = argv[i];
      ac++;
    }
  }

  double spacing[3] = { 1, 1.1, 1.3 };

  Grid grid;
  grid.Initialize(numPoints, spacing);

  Attributes attributes(numparticles);
  attributes.Initialize(&grid);

#ifdef USE_CATALYST
  // The first argument is the program name
  FEAdaptor::Initialize(ac - 1, av + 1);
#endif

  double tsim = 0.0;
#ifdef USE_CATALYST
  double tcop = 0.0;
#endif
  auto tlog = vtkSmartPointer<vtkTimerLog>::New();
  for (unsigned int timeStep = 0; timeStep < numberOfTimeSteps; timeStep++)
  {
    // use a time step length of 0.1
    cout << "timeStep " << timeStep << endl;
    double time = timeStep * 0.1;
    tlog->StartTimer();
    attributes.UpdateFields(time);
    tlog->StopTimer();
    tsim += tlog->GetElapsedTime();
#ifdef USE_CATALYST
    tlog->StartTimer();
    FEAdaptor::CoProcess(grid, attributes, time, timeStep, timeStep == numberOfTimeSteps - 1);
    tlog->StopTimer();
    tcop += tlog->GetElapsedTime();
#endif
  }

  cout << "Elapsed Simulation time " << tsim << endl;
#ifdef USE_CATALYST
  cout << "Elapsed CoProcessing time " << tcop << endl;
  FEAdaptor::Finalize();
#endif
  MPI_Finalize();

  delete[] av;
  return 0;
}