OPAL (Object Oriented Parallel Accelerator Library)  2021.1.99
OPAL
GridLBalWriter.h
Go to the documentation of this file.
1 //
2 // Class GridLBalWriter
3 // This class writes a SDDS file with AMR grid load balancing information.
4 //
5 // Copyright (c) 2019, Matthias Frey, Paul Scherrer Institut, Villigen PSI, Switzerland
6 // All rights reserved
7 //
8 // Implemented as part of the PhD thesis
9 // "Precise Simulations of Multibunches in High Intensity Cyclotrons"
10 //
11 // This file is part of OPAL.
12 //
13 // OPAL is free software: you can redistribute it and/or modify
14 // it under the terms of the GNU General Public License as published by
15 // the Free Software Foundation, either version 3 of the License, or
16 // (at your option) any later version.
17 //
18 // You should have received a copy of the GNU General Public License
19 // along with OPAL. If not, see <https://www.gnu.org/licenses/>.
20 //
21 #ifndef OPAL_GRID_LBAL_WRITER_H
22 #define OPAL_GRID_LBAL_WRITER_H
23 
24 #include "SDDSWriter.h"
25 
26 class GridLBalWriter : public SDDSWriter {
27 
28 public:
29  GridLBalWriter(const std::string& fname, bool restart);
30 
31  void write(PartBunchBase<double, 3> *beam);
32 
33 private:
34  void fillHeader(const PartBunchBase<double, 3> *beam);
35 };
36 
37 #endif
void write(PartBunchBase< double, 3 > *beam)
GridLBalWriter(const std::string &fname, bool restart)
void fillHeader(const PartBunchBase< double, 3 > *beam)