OPAL (Object Oriented Parallel Accelerator Library)  2.2.0
OPAL
Public Member Functions | Private Attributes | List of all members
VarRadiusGeometry Class Reference

#include <VarRadiusGeometry.h>

Inheritance diagram for VarRadiusGeometry:
Inheritance graph
[legend]
Collaboration diagram for VarRadiusGeometry:
Collaboration graph
[legend]

Public Member Functions

 VarRadiusGeometry (double length, double rho, double s_0, double lambda_left, double lambda_right)
 
 VarRadiusGeometry (const VarRadiusGeometry &right)
 
virtual ~VarRadiusGeometry ()
 
const VarRadiusGeometryoperator= (const VarRadiusGeometry &right)
 
virtual double getArcLength () const
 
virtual double getElementLength () const
 
virtual void setElementLength (double length)
 
double getRadius () const
 
void setRadius (const double &rho)
 
double getS0 () const
 
void setS0 (const double &s_0)
 
double getLambdaLeft () const
 
void setLambdaLeft (const double &lambda_left)
 
double getLambdaRight () const
 
void setLambdaRight (const double &lambda_right)
 
virtual Euclid3D getTransform (double fromS, double toS) const
 
virtual Euclid3D getEntranceFrame () const
 
virtual Euclid3D getExitFrame () const
 
- Public Member Functions inherited from BGeometryBase
 BGeometryBase ()
 
 BGeometryBase (const BGeometryBase &right)
 
virtual ~BGeometryBase ()
 
const BGeometryBaseoperator= (const BGeometryBase &right)
 
virtual double getOrigin () const
 Get origin position. More...
 
virtual double getEntrance () const
 Get entrance position. More...
 
virtual double getExit () const
 Get exit position. More...
 
virtual Euclid3D getTransform (double s) const
 Get transform. More...
 
virtual Euclid3D getTotalTransform () const
 Get transform. More...
 
virtual Euclid3D getEntrancePatch () const
 Get patch. More...
 
virtual Euclid3D getExitPatch () const
 Get patch. More...
 

Private Attributes

double length_m
 
double rho_m
 
double s_0_m
 
double lambda_left_m
 
double lambda_right_m
 

Detailed Description


VarRadiusGeometry represents a Geometry with variable radius. Assuming
a Tanh model for fringe fields, the radius of curvature varies inversely
proportional with the fringe field. Such a magnet will follow the
trajectory of the reference particle. The origin is defined at the centre and extends from -length / 2 to
+length / 2. Transformations are calculated using a CoordinateTransformation object,
which integrates to find the reference trajectory.


Class category: AbsBeamline
$Author: Martin Duy Tat, Chris Rogers



Definition at line 55 of file VarRadiusGeometry.h.

Constructor & Destructor Documentation

VarRadiusGeometry::VarRadiusGeometry ( double  length,
double  rho,
double  s_0,
double  lambda_left,
double  lambda_right 
)
inline

Build VarRadiusGeometry with given length, centre radius of curvature and fringe field

Parameters
length-> Length of geometry
rho-> Centre radius of curvature of geometry
s_0-> Length of central fringe field
lambda_left-> Length of left end fringe field
lambda_right-> Length of right end fringe field

Definition at line 134 of file VarRadiusGeometry.h.

VarRadiusGeometry::VarRadiusGeometry ( const VarRadiusGeometry right)
inline

Copy constructor

Definition at line 144 of file VarRadiusGeometry.h.

VarRadiusGeometry::~VarRadiusGeometry ( )
inlinevirtual

Destructor

Definition at line 162 of file VarRadiusGeometry.h.

Member Function Documentation

double VarRadiusGeometry::getArcLength ( ) const
inlinevirtual

Arc length along the design arc

Implements BGeometryBase.

Definition at line 165 of file VarRadiusGeometry.h.

References length_m.

double VarRadiusGeometry::getElementLength ( ) const
inlinevirtual

Get element length measured along hte design arc

Implements BGeometryBase.

Definition at line 169 of file VarRadiusGeometry.h.

References length_m.

Euclid3D VarRadiusGeometry::getEntranceFrame ( ) const
inlinevirtual

Transform of the local coordinate system from the origin to the entrance of the element Equivalent to getTransform(0.0, getEntrance())

Reimplemented from BGeometryBase.

Definition at line 209 of file VarRadiusGeometry.h.

References BGeometryBase::getEntrance(), BGeometryBase::getOrigin(), and getTransform().

Here is the call graph for this function:

Euclid3D VarRadiusGeometry::getExitFrame ( ) const
inlinevirtual

Transform of the local coordinate system from the origin to the exit of the element Equivalent to getTransform(0.0, getExit())

Reimplemented from BGeometryBase.

Definition at line 213 of file VarRadiusGeometry.h.

References BGeometryBase::getExit(), BGeometryBase::getOrigin(), and getTransform().

Here is the call graph for this function:

double VarRadiusGeometry::getLambdaLeft ( ) const
inline

Get left end fringe field length

Definition at line 193 of file VarRadiusGeometry.h.

References lambda_left_m.

double VarRadiusGeometry::getLambdaRight ( ) const
inline

Get right end fringe field length

Definition at line 201 of file VarRadiusGeometry.h.

References lambda_right_m.

double VarRadiusGeometry::getRadius ( ) const
inline

Get centre radius of curvature

Definition at line 177 of file VarRadiusGeometry.h.

References rho_m.

double VarRadiusGeometry::getS0 ( ) const
inline

Get central fringe field length

Definition at line 185 of file VarRadiusGeometry.h.

References s_0_m.

Euclid3D VarRadiusGeometry::getTransform ( double  fromS,
double  toS 
) const
virtual

Transform of the local coordinate system

Parameters
fromS-> Transform from this position
toS-> Transform to this position

Implements BGeometryBase.

Definition at line 34 of file VarRadiusGeometry.cpp.

References acos(), coordinatetransform::CoordinateTransform::calcReferenceTrajectory(), coordinatetransform::CoordinateTransform::getUnitTangentVector(), lambda_left_m, lambda_right_m, rho_m, s_0_m, Euclid3D::setX(), Euclid3D::setZ(), and Euclid3D::YRotation().

Referenced by getEntranceFrame(), and getExitFrame().

Here is the call graph for this function:

const VarRadiusGeometry & VarRadiusGeometry::operator= ( const VarRadiusGeometry right)
inline

Assigment operator

Definition at line 152 of file VarRadiusGeometry.h.

References lambda_left_m, lambda_right_m, length_m, rho_m, and s_0_m.

void VarRadiusGeometry::setElementLength ( double  length)
inlinevirtual

Set arc length

Parameters
length-> Length of element

Reimplemented from BGeometryBase.

Definition at line 173 of file VarRadiusGeometry.h.

References length_m.

Referenced by MultipoleTCurvedVarRadius::initialise().

void VarRadiusGeometry::setLambdaLeft ( const double &  lambda_left)
inline

Set left end fringe field length

Parameters
lambda_left-> Left end fringe field length

Definition at line 197 of file VarRadiusGeometry.h.

References lambda_left_m.

Referenced by MultipoleTCurvedVarRadius::initialise().

void VarRadiusGeometry::setLambdaRight ( const double &  lambda_right)
inline

Set right end fringe field length

Parameters
lambda_right-> Right end fringe field length

Definition at line 205 of file VarRadiusGeometry.h.

References lambda_right_m.

Referenced by MultipoleTCurvedVarRadius::initialise().

void VarRadiusGeometry::setRadius ( const double &  rho)
inline

Set centre radius of curvature

Parameters
rho-> Central radius of curvature

Definition at line 181 of file VarRadiusGeometry.h.

References rho_m.

Referenced by MultipoleTCurvedVarRadius::initialise().

void VarRadiusGeometry::setS0 ( const double &  s_0)
inline

Set central fringe field length

Parameters
s_0-> Central fringe field length

Definition at line 189 of file VarRadiusGeometry.h.

References s_0_m.

Referenced by MultipoleTCurvedVarRadius::initialise().

Member Data Documentation

double VarRadiusGeometry::lambda_left_m
private

Definition at line 127 of file VarRadiusGeometry.h.

Referenced by getLambdaLeft(), getTransform(), operator=(), and setLambdaLeft().

double VarRadiusGeometry::lambda_right_m
private

Definition at line 128 of file VarRadiusGeometry.h.

Referenced by getLambdaRight(), getTransform(), operator=(), and setLambdaRight().

double VarRadiusGeometry::length_m
private

Definition at line 124 of file VarRadiusGeometry.h.

Referenced by getArcLength(), getElementLength(), operator=(), and setElementLength().

double VarRadiusGeometry::rho_m
private

Definition at line 125 of file VarRadiusGeometry.h.

Referenced by getRadius(), getTransform(), operator=(), and setRadius().

double VarRadiusGeometry::s_0_m
private

Definition at line 126 of file VarRadiusGeometry.h.

Referenced by getS0(), getTransform(), operator=(), and setS0().


The documentation for this class was generated from the following files: