BDSIM
BDSIM is a Geant4 extension toolkit for simulation of particle transport in accelerator beamlines.
BDSArrayOperatorValueFlip.hh
1/*
2Beam Delivery Simulation (BDSIM) Copyright (C) Royal Holloway,
3University of London 2001 - 2022.
4
5This file is part of BDSIM.
6
7BDSIM is free software: you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published
9by the Free Software Foundation version 3 of the License.
10
11BDSIM is distributed in the hope that it will be useful, but
12WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with BDSIM. If not, see <http://www.gnu.org/licenses/>.
18*/
19#ifndef BDSARRAYOPERATORVALUEFLIP_H
20#define BDSARRAYOPERATORVALUEFLIP_H
21#include "BDSArrayOperatorValue.hh"
22#include "BDSFieldValue.hh"
23
24#include "G4String.hh"
25#include "G4Types.hh"
26
27#include <array>
28#include <string>
29
37{
38public:
40 BDSArrayOperatorValue("Flip(None)"),
41 multiplier{1.0,1.0,1.0,1.0}
42 {;}
43 explicit BDSArrayOperatorValueFlip(const std::array<G4bool,4>& xyztIn):
45 {
46 for (G4int i = 0; i < 4; i++)
47 {multiplier[i] = xyztIn[i] ? -1.0 : 1.0;}
48
49 G4String newName = "Flip(";
50 for (const auto& v : multiplier)
51 {newName += std::to_string(v < 0);}
52 newName += ")";
53 name = newName;
54 }
56
58 G4int /*xInd*/,
59 G4int /*yInd*/ = 0,
60 G4int /*zInd*/ = 0,
61 G4int /*tInd*/ = 0) const
62 {
63 return BDSFieldValue(v.x()*multiplier[0], v.y()*multiplier[1], v.z()*multiplier[2]);
64 }
65
66private:
69 std::array<FIELDTYPET,4> multiplier;
70};
71
72#endif
Flip field component in individual dimensions if out of original array bounds.
std::array< FIELDTYPET, 4 > multiplier
virtual BDSFieldValue Apply(BDSFieldValue v, G4int, G4int=0, G4int=0, G4int=0) const
Interface for modifying field values.
const T & z() const
Accessor by name.
const T & x() const
Accessor by name.
const T & y() const
Accessor by name.