9#ifndef TRKVOLUMES_BOUNDARYPLANESURFACE_H
10#define TRKVOLUMES_BOUNDARYPLANESURFACE_H
61 std::shared_ptr<const VolumeArray> outsideArray,
89#include "TrkVolumes/BoundaryPlaneSurface.icc"
Binned Array for avoiding map searches/.
BoundaryPlaneSurface(const Tvol *inside, const Tvol *outside, const PlaneSurface &psf, const Amg::Transform3D &tr)
Copy constructor with a shift.
BoundaryPlaneSurface(std::shared_ptr< const VolumeArray > insideArray, std::shared_ptr< const VolumeArray > outsideArray, const PlaneSurface &psf)
Constructor for a Boundary with two VolumeArrays attached to it.
BoundaryPlaneSurface(const Tvol *inside, const Tvol *outside, const PlaneSurface &psf)
Constructor for a Boundary with exact two Volumes attached to it.
BinnedArray< Tvol > VolumeArray
typedef the BinnedArray
BoundaryPlaneSurface & operator=(const BoundaryPlaneSurface &vol)=default
Assignment operator.
BoundaryPlaneSurface()=default
Default Constructor - needed for pool and inherited classes.
virtual const Surface & surfaceRepresentation() const override final
The Surface Representation of this.
BoundaryPlaneSurface(const BoundaryPlaneSurface< Tvol > &bps)=default
Copy constructor.
virtual ~BoundaryPlaneSurface()=default
Virtual Destructor.
virtual const Tvol * attachedVolume(const TrackParameters &parms, PropDirection dir) const override final
Get the next Volume depending on the TrackParameters and the requested direction, gives back 0 if the...
BoundarySurface()=default
Default Constructor - needed for pool and inherited classes.
PlaneSurface()
Default Constructor - needed for persistency.
Abstract Base Class for tracking surfaces.
Base class for all volumes inside the tracking realm, it defines the interface for inherited Volume c...
Eigen::Affine3d Transform3D
Eigen::Matrix< double, 3, 1 > Vector3D
Ensure that the ATLAS eigen extensions are properly loaded.
PropDirection
PropDirection, enum for direction of the propagation.
ParametersBase< TrackParametersDim, Charged > TrackParameters