Code indexing in gitaly is broken and leads to code not being visible to the user. We work on the issue with highest priority.

Skip to content
Snippets Groups Projects
Commit de4f5f1f authored by kraus's avatar kraus
Browse files

remove endField_m

parent 5c83e306
No related branches found
No related tags found
1 merge request!336Resolve "OrbitThreader::computeMaximalImplicitDrift not yielding correct results"
...@@ -304,4 +304,64 @@ void ElementBase::setCurrentSCoordinate(double s) { ...@@ -304,4 +304,64 @@ void ElementBase::setCurrentSCoordinate(double s) {
elementEdge_m = actionRange_m.front().first; elementEdge_m = actionRange_m.front().first;
} }
} }
}
bool ElementBase::isInsideTransverse(const Vector_t &r) const
{
double x = aperture_m.second[0];
double y = aperture_m.second[1];
double f = 1.0;
if (aperture_m.first == CONIC_RECTANGULAR ||
aperture_m.first == CONIC_ELLIPTIC) {
Vector_t rRelativeToBegin = getEdgeToBegin().transformTo(r);
double fractionLength = rRelativeToBegin(2) / getElementLength();
f = fractionLength * aperture_m.second[2];
}
switch(aperture_m.first) {
case RECTANGULAR:
return (std::abs(r[0]) < aperture_m.second[0] && std::abs(r[1]) < aperture_m.second[1]);
case ELLIPTICAL:
return (std::pow(r[0] / aperture_m.second[0], 2) + std::pow(r[1] / aperture_m.second[1], 2) < 1.0);
case CONIC_RECTANGULAR:
return (std::abs(r[0]) < f * aperture_m.second[0] && std::abs(r[1]) < f * aperture_m.second[1]);
case CONIC_ELLIPTICAL:
return (std::pow(r[0] / (f * aperture_m.second[0]), 2) + std::pow(r[1] / (f * aperture_m.second[1]), 2) < 1.0);
default:
return false;
}
}
BoundaryBox getBoundaryBoxInLabCoords() const {
CoordinateSystemTrafo toBegin = getEdgeToBegin() * csTrafoGlobal2Local_m;
CoordinateSystemTrafo toEnd = getEdgeToEnd() * csTrafoGlobal2Local_m;
double &x = aperture_m.second[0];
double &y = aperture_m.second[1];
double &f = aperture_m.second[2];
std::vector<Vector_t> corners(8);
for (int i = -1; i < 2; i += 2) {
for (int j = -1; j < 2; j += 2) {
unsigned int idx = (i + 1)/2 + (j + 1);
corners[idx] = toBegin.transformFrom(Vector_t(i * x, j * y, 0.0));
corners[idx + 4] = toEnd.transformFrom(Vector_t(i * f * x, j * f * y, 0.0));
}
}
BoundingBox bb;
bb.lowerLeftCorner = bb.upperRightCorner = corners[0];
for (unsigned int i = 1; i < 8u; ++ i) {
for (unsigned int d; d < 3u; ++ d) {
if (bb.lowerLeftCorner(d) > corners[i](d)) {
bb.lowerLeftCorner(d) = corners[i](d);
}
if (bb.upperLeftCorner(d) < corners[i](d)) {
bb.upperLeftCorner(d) = corners[i](d);
}
}
}
return bb;
} }
\ No newline at end of file
...@@ -79,6 +79,12 @@ class BoundaryGeometry; ...@@ -79,6 +79,12 @@ class BoundaryGeometry;
class Channel; class Channel;
class ConstChannel; class ConstChannel;
class ElementImage; class ElementImage;
struct BoundaryBox {
Vector_t lowerLeftEdge;
Vector_t upperRightEdge;
};
class ParticleMatterInteractionHandler; class ParticleMatterInteractionHandler;
class WakeFunction; class WakeFunction;
...@@ -353,6 +359,8 @@ public: ...@@ -353,6 +359,8 @@ public:
void setRotationAboutZ(double rotation); void setRotationAboutZ(double rotation);
double getRotationAboutZ() const; double getRotationAboutZ() const;
virtual BoundaryBox getBoundaryBoxInLabCoords() const;
protected: protected:
bool isInsideTransverse(const Vector_t &r, double f = 1) const; bool isInsideTransverse(const Vector_t &r, double f = 1) const;
...@@ -525,24 +533,7 @@ inline ...@@ -525,24 +533,7 @@ inline
bool ElementBase::isInside(const Vector_t &r) const bool ElementBase::isInside(const Vector_t &r) const
{ {
const double length = getElementLength(); const double length = getElementLength();
return isInsideTransverse(r, r(2) / length * aperture_m.second[2]) && r(2) >= 0.0 && r(2) < length; return r(2) >= 0.0 && r(2) < length && isInsideTransverse(r);
}
inline
bool ElementBase::isInsideTransverse(const Vector_t &r, double f) const
{
switch(aperture_m.first) {
case RECTANGULAR:
return (std::abs(r[0]) < aperture_m.second[0] && std::abs(r[1]) < aperture_m.second[1]);
case ELLIPTICAL:
return (std::pow(r[0] / aperture_m.second[0], 2) + std::pow(r[1] / aperture_m.second[1], 2) < 1.0);
case CONIC_RECTANGULAR:
return (std::abs(r[0]) < f * aperture_m.second[0] && std::abs(r[1]) < f * aperture_m.second[1]);
case CONIC_ELLIPTICAL:
return (std::pow(r[0] / (f * aperture_m.second[0]), 2) + std::pow(r[1] / (f * aperture_m.second[1]), 2) < 1.0);
default:
return false;
}
} }
inline inline
...@@ -611,5 +602,4 @@ inline ...@@ -611,5 +602,4 @@ inline
bool ElementBase::isElementPositionSet() const bool ElementBase::isElementPositionSet() const
{ return elemedgeSet_m; } { return elemedgeSet_m; }
#endif // CLASSIC_ElementBase_HH
#endif // CLASSIC_ElementBase_HH
\ No newline at end of file
...@@ -513,4 +513,4 @@ CoordinateSystemTrafo RFCavity::getEdgeToEnd() const { ...@@ -513,4 +513,4 @@ CoordinateSystemTrafo RFCavity::getEdgeToEnd() const {
return ret; return ret;
} }
#endif // CLASSIC_RFCavity_HH #endif // CLASSIC_RFCavity_HH
\ No newline at end of file
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment