OPAL (Object Oriented Parallel Accelerator Library) 2024.2
OPAL
OpalDegrader.cpp
Go to the documentation of this file.
1//
2// Class OpalDegrader
3// The DEGRADER element.
4//
5// Copyright (c) 200x - 2023, Paul Scherrer Institut, Villigen PSI, Switzerland
6// All rights reserved
7//
8// This file is part of OPAL.
9//
10// OPAL is free software: you can redistribute it and/or modify
11// it under the terms of the GNU General Public License as published by
12// the Free Software Foundation, either version 3 of the License, or
13// (at your option) any later version.
14//
15// You should have received a copy of the GNU General Public License
16// along with OPAL. If not, see <https://www.gnu.org/licenses/>.
17//
22
23
25 OpalElement(SIZE, "DEGRADER",
26 "The \"DEGRADER\" element defines a degrader."),
27 parmatint_m(nullptr) {
29 ("XSIZE", "Horizontal axis of the transverse elliptical shape [m]", 1E6);
30
32 ("YSIZE", "Vertical axis of the transverse elliptical shape [m]", 1E6);
33
35
36 setElement(new DegraderRep("DEGRADER"));
37}
38
39
40OpalDegrader::OpalDegrader(const std::string& name, OpalDegrader* parent):
41 OpalElement(name, parent),
42 parmatint_m(nullptr) {
44}
45
46
51
52
54 return new OpalDegrader(name, this);
55}
56
57
60
61 DegraderRep* deg = dynamic_cast<DegraderRep*>(getElement());
62
63 double length = Attributes::getReal(itsAttr[LENGTH]);
64 double xsize = Attributes::getReal(itsAttr[XSIZE]);
65 double ysize = Attributes::getReal(itsAttr[YSIZE]);
66
67 deg->setElementLength(length);
68 deg->setDimensions(xsize, ysize);
69
71 const std::string matterDescriptor = Attributes::getString(itsAttr[PARTICLEMATTERINTERACTION]);
73 parmatint_m = orig->clone(matterDescriptor);
74 parmatint_m->initParticleMatterInteractionHandler(*deg);
75 deg->setParticleMatterInteraction(parmatint_m->handler_m);
76 }
77
78 // Transmit "unknown" attributes.
80}
const std::string name
double getReal(const Attribute &attr)
Return real value.
Attribute makeReal(const std::string &name, const std::string &help)
Make real attribute.
std::string getString(const Attribute &attr)
Get string value.
ElementBase * getElement() const
Return the embedded CLASSIC element.
Definition Element.h:120
void setElement(ElementBase *)
Assign new CLASSIC element.
Definition Element.h:125
std::vector< Attribute > itsAttr
The object attributes.
Definition Object.h:216
OpalDegrader()
Exemplar constructor.
virtual OpalDegrader * clone(const std::string &name)
Make clone.
ParticleMatterInteraction * parmatint_m
virtual ~OpalDegrader()
virtual void update()
Update the embedded CLASSIC collimator.
@ PARTICLEMATTERINTERACTION
Definition OpalElement.h:39
virtual void updateUnknown(ElementBase *)
Transmit the ``unknown'' (not known to OPAL) attributes to CLASSIC.
virtual void update()
Update the embedded CLASSIC element.
OpalElement(int size, const char *name, const char *help)
Exemplar constructor.
void registerOwnership() const
virtual ParticleMatterInteraction * clone(const std::string &name)
Make clone.
static ParticleMatterInteraction * find(const std::string &name)
Find named PARTICLEMATTERINTERACTION.