80 csTrafoGlobal2Local_m(right.csTrafoGlobal2Local_m),
81 misalignment_m(right.misalignment_m),
82 aperture_m(right.aperture_m),
83 elementEdge_m(right.elementEdge_m),
84 rotationZAxis_m(right.rotationZAxis_m),
85 elementID(right.elementID),
86 userAttribs(right.userAttribs),
88 bgeometry_m(right.bgeometry_m),
89 parmatint_m(right.parmatint_m),
90 positionIsFixed(right.positionIsFixed),
91 elementPosition_m(right.elementPosition_m),
92 elemedgeSet_m(right.elemedgeSet_m),
93 outputfn_m(right.outputfn_m)
108 csTrafoGlobal2Local_m(),
111 rotationZAxis_m(0.0),
117 positionIsFixed(false),
118 elementPosition_m(0.0),
119 elemedgeSet_m(false),
156 if (aChannel != NULL) {
157 double val = *aChannel;
169 if (aChannel != NULL) {
186 if (aChannel != NULL && aChannel->
isSettable()) {
190 std::cout <<
"Channel NULL or not Settable" <<
std::endl;
211 return "CCollimator";
247 return "TravelingWave";
248 #ifdef ENABLE_OPAL_FEL
255 return "VariableRFCavity";
258 return "'unknown' type";
314 factor = fractionLength *
aperture_m.second[2];
323 return (
std::abs(r[0]) < factor * xLimit &&
std::abs(r[1]) < factor * yLimit);
325 return (
std::pow(r[0] / (factor * xLimit), 2) +
std::pow(r[1] / (factor * yLimit), 2) < 1.0);
332 const Vector_t & point = points.front();
334 for (
const Vector_t & point: points) {
336 result.getCombinedBoundingBox(tmp);
343 Vector_t relativePosition = position - lowerLeftCorner;
344 Vector_t diagonal = upperRightCorner - lowerLeftCorner;
346 for (
unsigned int d = 0; d < 3; ++ d) {
347 if (relativePosition[d] < 0.0 ||
348 relativePosition[d] > diagonal[d]) {
356 boost::optional<Vector_t>
359 Vector_t relativePosition = lowerLeftCorner - position;
360 Vector_t diagonal = upperRightCorner - lowerLeftCorner;
363 for (
int i : {-1, 1}) {
364 for (
unsigned int d = 0; d < 3; ++ d) {
365 double projectedDirection = normalizedDirection[d];
366 if (
std::abs(projectedDirection) < 1
e-10) {
370 double distanceNearestPoint = relativePosition[d];
371 double tau = distanceNearestPoint / projectedDirection;
375 Vector_t delta = tau * normalizedDirection;
376 Vector_t relativeIntersectionPoint = i * (relativePosition - delta);
378 if (relativeIntersectionPoint[(d + 1) % 3] < 0.0 ||
379 relativeIntersectionPoint[(d + 1) % 3] > diagonal[(d + 1) % 3] ||
380 relativeIntersectionPoint[(d + 2) % 3] < 0.0 ||
381 relativeIntersectionPoint[(d + 2) % 3] > diagonal[(d + 2) % 3]) {
385 return position + delta;
387 relativePosition = upperRightCorner - position;
401 std::vector<Vector_t> corners(8);
402 for (
int i = -1; i < 2; i += 2) {
403 for (
int j = -1; j < 2; j += 2) {
404 unsigned int idx = (i + 1)/2 + (j + 1);
413 for (
unsigned int i = 1; i < 8u; ++ i) {
414 for (
unsigned int d = 0; d < 3u; ++ d) {
428 const Vector_t & ll = lowerLeftCorner;
429 const Vector_t & ur = upperRightCorner;
431 Vector_t dX(diagonal(0), 0, 0), dY(0, diagonal(1), 0), dZ(0, 0, diagonal(2));
433 std::vector<Vector_t> corners{ll, ll + dX, ll + dX + dY, ll + dY, ur, ur - dX, ur - dX - dY, ur - dY};
434 std::vector<std::vector<unsigned int>> paths{{0, 1, 2, 3}, {0, 1, 7, 6}, {1, 2, 4, 7}, {2, 3, 5, 4}, {3, 0, 6, 5}, {4, 5, 6, 7}};
436 out << std::setprecision(8);
437 for (
const std::vector<unsigned int>& path: paths) {
438 for (
unsigned int i : {0, 1, 2, 3, 0}) {
439 const Vector_t & corner = corners[path[i]];
440 out << std::setw(16) << corner(0)
441 << std::setw(16) << corner(1)
442 << std::setw(16) << corner(2)
Tps< T > pow(const Tps< T > &x, int y)
Integer power.
T euclidean_norm(const Vector< T > &)
Euclidean norm.
PETE_TUTree< FnAbs, typename T::PETE_Expr_t > abs(const PETE_Expr< T > &l)
Inform & endl(Inform &inf)
constexpr double e
The value of.
boost::function< boost::tuple< double, bool >arguments_t)> type
Map of std::string versus double value.
void removeAttribute(const std::string &aKey)
Remove an existing attribute.
const_iterator begin() const
Iterator accessing first member.
NameMap::const_iterator const_iterator
An iterator for a map of name versus value.
Channel * getChannel(const std::string &aKey, bool create=false)
Construct a read/write channel.
const_iterator end() const
Iterator marking the end of the list.
virtual void setBoundaryGeometry(BoundaryGeometry *geo)
virtual Channel * getChannel(const std::string &aKey, bool create=false)
Construct a read/write channel.
virtual void setName(const std::string &name)
Set element name.
virtual const std::string & getName() const
Get element name.
virtual void removeAttribute(const std::string &aKey)
Remove an existing attribute.
virtual double getElementLength() const
Get design length.
bool update(const AttributeSet &)
Update element.
ParticleMatterInteractionHandler * parmatint_m
virtual const ConstChannel * getConstChannel(const std::string &aKey) const
Construct a read-only channel.
virtual void setAttribute(const std::string &aKey, double val)
Set value of an attribute.
virtual BoundingBox getBoundingBoxInLabCoords() const
bool isInsideTransverse(const Vector_t &r) const
std::string getOutputFN() const
Get output filename.
void setOutputFN(std::string fn)
Set output filename.
std::pair< ApertureType, std::vector< double > > aperture_m
virtual void setParticleMatterInteraction(ParticleMatterInteractionHandler *spys)
virtual void makeSharable()
Set sharable flag.
virtual bool hasAttribute(const std::string &aKey) const
Test for existence of an attribute.
std::queue< std::pair< double, double > > actionRange_m
virtual CoordinateSystemTrafo getEdgeToBegin() const
std::string getTypeString() const
virtual ElementBase * clone() const =0
Return clone.
virtual ElementBase * copyStructure()
Make a structural copy.
BoundaryGeometry * bgeometry_m
bool isSharable() const
Test if the element can be shared.
void setCurrentSCoordinate(double s)
virtual double getAttribute(const std::string &aKey) const
Get attribute value.
virtual CoordinateSystemTrafo getEdgeToEnd() const
virtual void setWake(WakeFunction *wf)
attach a wake field to the element
CoordinateSystemTrafo csTrafoGlobal2Local_m
bool isInside(const Vector_t &) const
Vector_t upperRightCorner
static BoundingBox getBoundingBox(const std::vector< Vector_t > &points)
void print(std::ostream &) const
boost::optional< Vector_t > getPointOfIntersection(const Vector_t &position, const Vector_t &direction) const
Vector_t transformFrom(const Vector_t &r) const
Vector_t transformTo(const Vector_t &r) const
Abstract interface for read/write access to variable.
virtual bool isSettable() const
Test if settable.
Abstract interface for read-only access to variable.
Abstract base class for reference counted objects.
void updateElement(ElementBase *newref)
void updateElement(ElementBase *element)
Vektor< double, 3 > Vector_t