CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Classes | Typedefs | Functions | Variables
Basic3DVectorLD.h File Reference
#include "extBasic3DVector.h"

Go to the source code of this file.

Classes

class  Basic3DVector< long double >
 

Typedefs

typedef Basic3DVector< long
double > 
Basic3DVectorLD
 
typedef
Geom::Cylindrical2Cartesian< T
Cylindrical
 
typedef Basic3DVector< TMathVector
 
typedef Spherical Polar
 
typedef T ScalarType
 
typedef
Geom::Spherical2Cartesian< T
Spherical
 
typedef long double T
 

Functions

template<>
class Basic3DVector< long double > __attribute__ ((aligned(16)))
 
T barePhi () const
 
T bareTheta () const
 
 Basic3DVector ()
 
 Basic3DVector (const Basic3DVector &p)
 Copy constructor from same type. Should not be needed but for gcc bug 12685. More...
 
template<class U >
 Basic3DVector (const Basic3DVector< U > &p)
 Copy constructor and implicit conversion from Basic3DVector of different precision. More...
 
 Basic3DVector (const Basic2DVector< T > &p)
 constructor from 2D vector (X and Y from 2D vector, z set to zero) More...
 
template<class OtherPoint >
 Basic3DVector (const OtherPoint &p)
 
 Basic3DVector (const T &x, const T &y, const T &z)
 construct from cartesian coordinates More...
 
template<typename U >
 Basic3DVector (const Geom::Theta< U > &theta, const Geom::Phi< U > &phi, const T &r)
 
Basic3DVector cross (const Basic3DVector &v) const
 Vector product, or "cross" product, with a vector of same type. More...
 
template<class U >
Basic3DVector< typename
PreciseFloatType< T, U >::Type > 
cross (const Basic3DVector< U > &v) const
 
T dot (const Basic3DVector &v) const
 Scalar product, or "dot" product, with a vector of same type. More...
 
template<class U >
PreciseFloatType< T, U >::Type dot (const Basic3DVector< U > &v) const
 
T eta () const
 
T mag () const
 The vector magnitude. Equivalent to sqrt(vec.mag2()) More...
 
T mag2 () const
 The vector magnitude squared. Equivalent to vec.dot(vec) More...
 
long double operator* (const Basic3DVector< long double > &v1, const Basic3DVector< long double > &v2)
 scalar product of vectors of same precision More...
 
template<class U >
PreciseFloatType< long double,
U >::Type 
operator* (const Basic3DVector< long double > &v1, const Basic3DVector< U > &v2)
 scalar product of vectors of different precision More...
 
template<class U >
PreciseFloatType< long double,
U >::Type 
operator* (const Basic3DVector< U > &v1, const Basic3DVector< long double > &v2)
 
Basic3DVector< long double > operator* (const Basic3DVector< long double > &v, long double t)
 
Basic3DVector< long double > operator* (long double t, const Basic3DVector< long double > &v)
 Same as operator*( Vector, Scalar) More...
 
template<typename S >
Basic3DVector< long double > operator* (S t, const Basic3DVector< long double > &v)
 
template<typename S >
Basic3DVector< long double > operator* (const Basic3DVector< long double > &v, S t)
 
Basic3DVectoroperator*= (T t)
 Scaling by a scalar value (multiplication) More...
 
Basic3DVector< long double > operator+ (const Basic3DVector< long double > &a, const Basic3DVector< long double > &b)
 vector sum and subtraction of vectors of possibly different precision More...
 
template<class U >
Basic3DVector< typename
PreciseFloatType< long double,
U >::Type > 
operator+ (const Basic3DVector< long double > &a, const Basic3DVector< U > &b)
 
template<class U >
Basic3DVector< typename
PreciseFloatType< long double,
U >::Type > 
operator+ (const Basic3DVector< U > &a, const Basic3DVector< long double > &b)
 
template<class U >
Basic3DVectoroperator+= (const Basic3DVector< U > &p)
 
Basic3DVector operator- () const
 Unary minus, returns a vector with components (-x(),-y(),-z()) More...
 
Basic3DVector< long double > operator- (const Basic3DVector< long double > &a, const Basic3DVector< long double > &b)
 
template<class U >
Basic3DVector< typename
PreciseFloatType< long double,
U >::Type > 
operator- (const Basic3DVector< long double > &a, const Basic3DVector< U > &b)
 
template<class U >
Basic3DVector< typename
PreciseFloatType< long double,
U >::Type > 
operator- (const Basic3DVector< U > &a, const Basic3DVector< long double > &b)
 
template<class U >
Basic3DVectoroperator-= (const Basic3DVector< U > &p)
 
template<typename S >
Basic3DVector< long double > operator/ (const Basic3DVector< long double > &v, S s)
 
Basic3DVectoroperator/= (T t)
 Scaling by a scalar value (division) More...
 
bool operator== (const Basic3DVector &rh) const
 
T perp () const
 Magnitude of transverse component. More...
 
T perp2 () const
 Squared magnitude of transverse component. More...
 
Geom::Phi< Tphi () const
 
Geom::Theta< Ttheta () const
 
T transverse () const
 Another name for perp() More...
 
Basic3DVector unit () const
 
T x () const
 Cartesian x coordinate. More...
 
Basic2DVector< Txy () const
 
T y () const
 Cartesian y coordinate. More...
 
T z () const
 Cartesian z coordinate. More...
 

Variables

T theW
 
T theX
 
T theY
 
T theZ
 

Typedef Documentation

typedef Basic3DVector<long double> Basic3DVectorLD

Definition at line 307 of file Basic3DVectorLD.h.

Definition at line 50 of file Basic3DVectorLD.h.

Definition at line 54 of file Basic3DVectorLD.h.

typedef Spherical Polar

Definition at line 52 of file Basic3DVectorLD.h.

typedef T ScalarType

Definition at line 49 of file Basic3DVectorLD.h.

Definition at line 51 of file Basic3DVectorLD.h.

typedef long double T

Definition at line 48 of file Basic3DVectorLD.h.

Function Documentation

template<>
class Basic3DVector< long double > __attribute__ ( (aligned(16))  )
T __attribute__::barePhi ( ) const

Azimuthal angle. The value is returned in radians, in the range (-pi,pi]. Same precision as the system atan2(x,y) function. The return type is Geom::Phi<T>, see it's documentation.

Definition at line 142 of file Basic3DVectorLD.h.

Referenced by MuonAlignmentAnalyzer::analyze(), SeedForPhotonConversionFromQuadruplets::bubbleReverseSortVsPhi(), and SeedForPhotonConversionFromQuadruplets::bubbleSortVsPhi().

150 {
T __attribute__::bareTheta ( ) const

Polar angle. The value is returned in radians, in the range [0,pi] Same precision as the system atan2(x,y) function. The return type is Geom::Phi<T>, see it's documentation.

Definition at line 149 of file Basic3DVectorLD.h.

150 {
__attribute__::Basic3DVector ( )

default constructor uses default constructor of T to initialize the components. For built-in floating-point types this means initialization to zero??? (force init to 0)

Definition at line 60 of file Basic3DVectorLD.h.

61 : theX(x), theY(y), theZ(z), theW(0) {}
T theZ
T theY
T theW
float float float z
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
T theX
Basic3DVector ( const Basic3DVector p)

Copy constructor from same type. Should not be needed but for gcc bug 12685.

Definition at line 63 of file Basic3DVectorLD.h.

template<class U >
__attribute__::Basic3DVector ( const Basic3DVector< U > &  p)

Copy constructor and implicit conversion from Basic3DVector of different precision.

Definition at line 67 of file Basic3DVectorLD.h.

__attribute__::Basic3DVector ( const Basic2DVector< T > &  p)

constructor from 2D vector (X and Y from 2D vector, z set to zero)

Definition at line 70 of file Basic3DVectorLD.h.

76 { return theX; }
T theX
template<class OtherPoint >
__attribute__::Basic3DVector ( const OtherPoint &  p)
explicit

Explicit constructor from other (possibly unrelated) vector classes The only constraint on the argument type is that it has methods x(), y() and z(), and that these methods return a type convertible to T. Examples of use are
construction from a Basic3DVector with different precision
construction from a Hep3Vector
construction from a coordinate system converter

Definition at line 81 of file Basic3DVectorLD.h.

82 { return theZ; }
T theZ
__attribute__::Basic3DVector ( const T x,
const T y,
const T z 
)

construct from cartesian coordinates

Definition at line 95 of file Basic3DVectorLD.h.

96 { return x() * x() + y() * y(); }
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
template<typename U >
__attribute__::Basic3DVector ( const Geom::Theta< U > &  theta,
const Geom::Phi< U > &  phi,
const T r 
)

Deprecated construct from polar coordinates, use
Basic3DVector<T>( Basic3DVector<T>::Polar( theta, phi, r)) instead.

Definition at line 102 of file Basic3DVectorLD.h.

References Basic3DVector< T >::perp().

102  { return perp(); }
103 
T perp() const
Magnitude of transverse component.
Basic3DVector __attribute__::cross ( const Basic3DVector v) const
template<class U >
Basic3DVector<typename PreciseFloatType<T, U>::Type> __attribute__::cross ( const Basic3DVector< U > &  v) const

Vector (or cross) product with a vector of different precision. The product is computed without loss of precision. The type of the returned vector is the more precise of the types of the two vectors.

Definition at line 235 of file Basic3DVectorLD.h.

236  {
238  return RT(a.x() + b.x(), a.y() + b.y(), a.z() + b.z());
double b
Definition: hdecay.h:118
double a
Definition: hdecay.h:119
T __attribute__::dot ( const Basic3DVector v) const
template<class U >
PreciseFloatType<T, U>::Type __attribute__::dot ( const Basic3DVector< U > &  v) const

Scalar (or dot) product with a vector of different precision. The product is computed without loss of precision. The type of the returned scalar is the more precise of the scalar types of the two vectors.

Definition at line 220 of file Basic3DVectorLD.h.

222  {
T __attribute__::eta ( ) const

Pseudorapidity. Does not check for zero transverse component; in this case the behavior is as for divide-by zero, i.e. system-dependent.

Definition at line 157 of file Basic3DVectorLD.h.

158 { return Basic3DVector(-x(), -y(), -z()); }
float float float z
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
Basic3DVector()
T __attribute__::mag ( ) const

The vector magnitude. Equivalent to sqrt(vec.mag2())

Definition at line 127 of file Basic3DVectorLD.h.

Referenced by Phase2TrackerDigitizerAlgorithm::accumulateSimHits(), SiPixelDigitizerAlgorithm::accumulateSimHits(), SiStripDigitizerAlgorithm::accumulateSimHits(), ReferenceTrajectory::addMaterialEffectsBrl(), MonopoleTransportation::AlongStepGetPhysicalInteractionLength(), DTChamberEfficiencyTask::analyze(), MuonTrackResidualAnalyzer::analyze(), TestHits::analyze(), TestSmoothHits::analyze(), MuonDTDigis::analyze(), SiStripElectronAnalyzer::analyze(), IPTagPlotter< Container, Base >::analyzeTag(), GlobalTrackerMuonAlignment::analyzeTrackTrack(), GlobalTrackerMuonAlignment::analyzeTrackTrajectory(), reco::GhostTrackState::axisDistance(), btagbtvdeep::TrackPairInfoBuilder::buildTrackPairInfo(), ThirdHitPrediction::calculateRangesBarrel(), CaloCellCrossing::CaloCellCrossing(), TkGluedMeasurementDet::checkHitProjection(), GlobalMuonRefitter::checkMuonHits(), MuonTrajectoryCleaner::clean(), TkAccumulatingSensitiveDetector::closeHit(), HGCalMulticlusteringImpl::clusterizeDR(), HGCalClusteringImpl::clusterizeDRNN(), Phase1PixelBlade::computeCrossings(), GlobalMuonTrackMatcher::convertToTSOSMuHit(), GlobalMuonTrackMatcher::convertToTSOSTkHit(), fastsim::TrackerSimHitProducer::createHitOnDetector(), fireworks::createSegment(), CaloDetIdAssociator::crossedElement(), TangentCircle::curvatureError(), OptOMirror::detailedDeviatesLightRay(), TangentCircle::direction(), RK4PreciseStep::distance(), l1t::HGCalClusterT< l1t::HGCalCluster >::distance(), L1EGCrystalClusterEmulatorProducer::SimpleCaloHit::distanceTo(), SignedImpactParameter3D::distanceWithJetAxis(), HGCalHistoClusteringImpl::dR(), DTDigitizer::dumpHit(), HLTDQMTagAndProbeEff< TagType, TagCollType, ProbeType, ProbeCollType >::fill(), CSCTimingExtractor::fillTiming(), DTTimingExtractor::fillTiming(), Phase1PixelBlade::findBin2(), HGCalMulticlusteringImpl::findNeighbor(), AdaptiveVertexFitter::fit(), Trajectory::geometricalInnermostState(), BTVHLTOfflineSource::getOfflineBTagTracks(), TrackAssociatorByPositionImpl::getState(), FlatHexagon::getTransform(), TruncatedPyramid::getTransform(), FlatTrd::getTransform(), CaloCellGeometry::getTransform(), MuonShowerInformationFiller::hitsFromSegments(), PixelBrickedDigitizerAlgorithm::induce_signal(), Pixel3DDigitizerAlgorithm::induce_signal(), Phase2TrackerDigitizerAlgorithm::induce_signal(), IdealObliquePrism::initCorners(), MaterialAccountingGroup::inside(), HGCalTriggerClusterInterpretationEM::interpret(), DD4hep_MaterialAccountingGroup::isInside(), CalibrationTrackSelector::isIsolated(), AlignmentTrackSelector::isIsolated(), MuonCosmicCompatibilityFiller::isOverlappingMuon(), HGCalMulticlusteringImpl::isPertinent(), IPTools::jetTrackDistance(), egHLT::ParticlePair< T >::mass(), GlobalCosmicMuonTrajectoryBuilder::match(), GlobalMuonTrackMatcher::match_D(), GlobalMuonTrackMatcher::match_d(), MatcherUsingTracksAlgorithm::matchByDirectComparison(), MatcherUsingTracksAlgorithm::matchWithPropagation(), NuclearTester::meanHitDistance(), TracksClusteringFromDisplacedSeed::nearTracks(), DTTTrigSyncTOFCorr::offset(), DTTTrigSyncFromDB::offset(), LinTrackCache::Vicinity::operator()(), RKCurvilinearDistance< T, N >::operator()(), RKCylindricalDistance< T, N >::operator()(), RKCartesianDistance::operator()(), RecHitLessByDet::operator()(), MuonTrackResidualAnalyzer::RadiusComparatorInOut::operator()(), MuonShowerInformationFiller::LessMag::operator()(), HGCalShowerShape::pass(), egHLT::EgTagProbeCut< T >::pass(), egHLT::EgTrigTagProbeCut::pass(), egHLT::EgTrigTagProbeCut_New::pass(), egHLT::EgTrigTagProbeCut_NewPho::pass(), EgammaIsoDetIdCollectionProducer< T1 >::produce(), SeedGeneratorFromL1TTracksEDProducer::produce(), SoftPFElectronTagInfoProducer::produce(), SoftPFMuonTagInfoProducer::produce(), reco::modules::CosmicTrackSplitter::produce(), SteppingHelixPropagator::propagate(), SteppingHelixPropagator::propagateWithPath(), TrackAssociatorByPositionImpl::quality(), GenericTripletGenerator::qualityFilter(), SteppingHelixPropagator::refToDest(), CosmicRegionalSeedGenerator::regions(), SoftLepton::relativeEta(), HGCalClusteringImpl::removeUnconnectedTCinCluster(), TrackInfoProducerAlgorithm::run(), DigiSimLinkAlgorithm::run(), magneticfield::BaseVolumeHandle::sameSurface(), btagbtvdeep::seedingTracksToFeatures(), SeedGeneratorForCosmics::seeds(), trackerDTC::SensorModule::SensorModule(), FWMagField::setFFFieldMag(), DDErrorDetection::so(), DynamicTruncation::sort(), SETSeedFinder::sortByLayer(), GlobalCosmicMuonTrajectoryBuilder::sortHits(), CosmicMuonSmoother::sortHitsAlongMom(), SeedFromNuclearInteraction::stateWithError(), TangentCircle::TangentCircle(), TangentHelix::TangentHelix(), DTSegtoRPC::thePoints(), SiLinearChargeDivider::TimeResponse(), ThirdHitPredictionFromCircle::transverseIP(), CheckSecondary::update(), and MultiVertexFitter::updateSeeds().

128 {
T __attribute__::mag2 ( ) const
long double operator* ( const Basic3DVector< long double > &  v1,
const Basic3DVector< long double > &  v2 
)
inline

scalar product of vectors of same precision

Definition at line 257 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::dot().

257  {
258  return v1.dot(v2);
259 }
T dot(const Basic3DVector &v) const
Scalar product, or &quot;dot&quot; product, with a vector of same type.
template<class U >
PreciseFloatType<long double, U>::Type operator* ( const Basic3DVector< long double > &  v1,
const Basic3DVector< U > &  v2 
)
inline

scalar product of vectors of different precision

Definition at line 263 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::x(), Basic3DVector< T >::x(), Basic3DVector< long double >::y(), Basic3DVector< T >::y(), Basic3DVector< long double >::z(), and Basic3DVector< T >::z().

264  {
265  return v1.x() * v2.x() + v1.y() * v2.y() + v1.z() * v2.z();
266 }
T y() const
Cartesian y coordinate.
T x() const
Cartesian x coordinate.
T x() const
Cartesian x coordinate.
T z() const
Cartesian z coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
PreciseFloatType<long double, U>::Type operator* ( const Basic3DVector< U > &  v1,
const Basic3DVector< long double > &  v2 
)
inline

Definition at line 269 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::x(), Basic3DVector< T >::x(), Basic3DVector< long double >::y(), Basic3DVector< T >::y(), Basic3DVector< long double >::z(), and Basic3DVector< T >::z().

270  {
271  return v1.x() * v2.x() + v1.y() * v2.y() + v1.z() * v2.z();
272 }
T y() const
Cartesian y coordinate.
T x() const
Cartesian x coordinate.
T x() const
Cartesian x coordinate.
T z() const
Cartesian z coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
Basic3DVector<long double> operator* ( const Basic3DVector< long double > &  v,
long double  t 
)
inline

Multiplication by scalar, does not change the precision of the vector. The return type is the same as the type of the vector argument.

Definition at line 278 of file Basic3DVectorLD.h.

References submitPVValidationJobs::t, Basic3DVector< long double >::x(), Basic3DVector< long double >::y(), and Basic3DVector< long double >::z().

278  {
279  return Basic3DVector<long double>(v.x() * t, v.y() * t, v.z() * t);
280 }
T x() const
Cartesian x coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
Basic3DVector<long double> operator* ( long double  t,
const Basic3DVector< long double > &  v 
)
inline

Same as operator*( Vector, Scalar)

Definition at line 284 of file Basic3DVectorLD.h.

References submitPVValidationJobs::t, Basic3DVector< long double >::x(), Basic3DVector< long double >::y(), and Basic3DVector< long double >::z().

284  {
285  return Basic3DVector<long double>(v.x() * t, v.y() * t, v.z() * t);
286 }
T x() const
Cartesian x coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<typename S >
Basic3DVector<long double> operator* ( S  t,
const Basic3DVector< long double > &  v 
)
inline

Definition at line 289 of file Basic3DVectorLD.h.

References submitPVValidationJobs::t.

289  {
290  return static_cast<long double>(t) * v;
291 }
template<typename S >
Basic3DVector<long double> operator* ( const Basic3DVector< long double > &  v,
S  t 
)
inline

Definition at line 294 of file Basic3DVectorLD.h.

References submitPVValidationJobs::t.

294  {
295  return static_cast<long double>(t) * v;
296 }
Basic3DVector& __attribute__::operator*= ( T  t)

Scaling by a scalar value (multiplication)

Definition at line 195 of file Basic3DVectorLD.h.

Basic3DVector<long double> operator+ ( const Basic3DVector< long double > &  a,
const Basic3DVector< long double > &  b 
)
inline

vector sum and subtraction of vectors of possibly different precision

Definition at line 218 of file Basic3DVectorLD.h.

218  {
219  typedef Basic3DVector<long double> RT;
220  return RT(a.x() + b.x(), a.y() + b.y(), a.z() + b.z());
221 }
T x() const
Cartesian x coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
Basic3DVector<typename PreciseFloatType<long double, U>::Type> operator+ ( const Basic3DVector< long double > &  a,
const Basic3DVector< U > &  b 
)
inline

Definition at line 228 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::x(), Basic3DVector< T >::x(), Basic3DVector< long double >::y(), Basic3DVector< T >::y(), Basic3DVector< long double >::z(), and Basic3DVector< T >::z().

229  {
231  return RT(a.x() + b.x(), a.y() + b.y(), a.z() + b.z());
232 }
T y() const
Cartesian y coordinate.
T x() const
Cartesian x coordinate.
T x() const
Cartesian x coordinate.
T z() const
Cartesian z coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
Basic3DVector<typename PreciseFloatType<long double, U>::Type> operator+ ( const Basic3DVector< U > &  a,
const Basic3DVector< long double > &  b 
)
inline

Definition at line 235 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::x(), Basic3DVector< T >::x(), Basic3DVector< long double >::y(), Basic3DVector< T >::y(), Basic3DVector< long double >::z(), and Basic3DVector< T >::z().

236  {
238  return RT(a.x() + b.x(), a.y() + b.y(), a.z() + b.z());
239 }
T y() const
Cartesian y coordinate.
T x() const
Cartesian x coordinate.
T x() const
Cartesian x coordinate.
T z() const
Cartesian z coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
Basic3DVector& __attribute__::operator+= ( const Basic3DVector< U > &  p)

Operator += with a Basic3DVector of possibly different precision.

Definition at line 174 of file Basic3DVectorLD.h.

178  { return x() * v.x() + y() * v.y() + z() * v.z(); }
179 
float float float z
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
Basic3DVector __attribute__::operator- ( ) const

Unary minus, returns a vector with components (-x(),-y(),-z())

Definition at line 192 of file Basic3DVectorLD.h.

Basic3DVector<long double> operator- ( const Basic3DVector< long double > &  a,
const Basic3DVector< long double > &  b 
)
inline

Definition at line 222 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::x(), Basic3DVector< long double >::y(), and Basic3DVector< long double >::z().

222  {
223  typedef Basic3DVector<long double> RT;
224  return RT(a.x() - b.x(), a.y() - b.y(), a.z() - b.z());
225 }
T x() const
Cartesian x coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
Basic3DVector<typename PreciseFloatType<long double, U>::Type> operator- ( const Basic3DVector< long double > &  a,
const Basic3DVector< U > &  b 
)
inline

Definition at line 242 of file Basic3DVectorLD.h.

243  {
245  return RT(a.x() - b.x(), a.y() - b.y(), a.z() - b.z());
246 }
T y() const
Cartesian y coordinate.
T x() const
Cartesian x coordinate.
T x() const
Cartesian x coordinate.
T z() const
Cartesian z coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
Basic3DVector<typename PreciseFloatType<long double, U>::Type> operator- ( const Basic3DVector< U > &  a,
const Basic3DVector< long double > &  b 
)
inline

Definition at line 249 of file Basic3DVectorLD.h.

References Basic3DVector< long double >::x(), Basic3DVector< T >::x(), Basic3DVector< long double >::y(), Basic3DVector< T >::y(), Basic3DVector< long double >::z(), and Basic3DVector< T >::z().

250  {
252  return RT(a.x() - b.x(), a.y() - b.y(), a.z() - b.z());
253 }
T y() const
Cartesian y coordinate.
T x() const
Cartesian x coordinate.
T x() const
Cartesian x coordinate.
T z() const
Cartesian z coordinate.
T y() const
Cartesian y coordinate.
T z() const
Cartesian z coordinate.
template<class U >
Basic3DVector& __attribute__::operator-= ( const Basic3DVector< U > &  p)

Operator -= with a Basic3DVector of possibly different precision.

Definition at line 184 of file Basic3DVectorLD.h.

186  {
187  return x() * v.x() + y() * v.y() + z() * v.z();
188  }
189 
float float float z
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
template<typename S >
Basic3DVector<long double> operator/ ( const Basic3DVector< long double > &  v,
S  s 
)
inline

Division by scalar, does not change the precision of the vector. The return type is the same as the type of the vector argument.

Definition at line 302 of file Basic3DVectorLD.h.

References alignCSCRings::s, and submitPVValidationJobs::t.

302  {
303  long double t = 1 / s;
304  return v * t;
305 }
Basic3DVector& __attribute__::operator/= ( T  t)

Scaling by a scalar value (division)

Definition at line 203 of file Basic3DVectorLD.h.

206  :
207  T theX;
208  T theY;
209  T theZ;
T theZ
T theY
T theX
long double T
bool __attribute__::operator== ( const Basic3DVector rh) const

Definition at line 121 of file Basic3DVectorLD.h.

123 { return detailsBasic3DVector::eta(x(), y(), z()); } // correct
float float float z
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
T __attribute__::perp ( ) const

Magnitude of transverse component.

Definition at line 133 of file Basic3DVectorLD.h.

Referenced by CMSTopTagger::_find_min_mass(), ElectronMcSignalValidator::analyze(), DrellYanValidation::analyze(), MBUEandQCDValidation::analyze(), MuonAlignmentAnalyzer::analyze(), TOBLayerBuilder::build(), Phase2OTBarrelRodBuilder::build(), TBLayer::computeCrossings(), PixelBlade::computeCrossings(), DD4hep_MaterialAccountingGroup::DD4hep_MaterialAccountingGroup(), ZeeCalibration::fillEleInfo(), HcalHardcodeGeometryLoader::fillHE(), HcalFlexiHardcodeGeometryLoader::fillHE(), HcalHardcodeGeometryLoader::fillHF(), HcalFlexiHardcodeGeometryLoader::fillHF(), GlobalHitsProdHist::fillMuon(), GlobalHitsAnalyzer::fillMuon(), GlobalHitsProducer::fillMuon(), GlobalHitsProdHist::fillTrk(), GlobalHitsAnalyzer::fillTrk(), GlobalHitsProducer::fillTrk(), TIDLayer::findClosest(), TIDLayer::findNextIndex(), MuonShowerInformationFiller::findPerpCluster(), Phase2EndcapLayer::findThreeClosest(), Trajectory::geometricalInnermostState(), CaloGeometryHelper::getClosestCell(), TrackFitter::getCotThetaAndUpdateZip(), TkLasBeamFitter::getLasBeams(), reco::GhostTrackPrediction::GhostTrackPrediction(), GlobalCoordsObtainer::GlobalCoordsObtainer(), TkLasBeamFitter::globalTrackPoint(), SimpleDiskBounds::inside(), DiskSectorBounds::inside(), TrackingRecHitLessFromGlobalPosition::insideOutLess(), MaterialAccountingGroup::MaterialAccountingGroup(), ThirdHitZPrediction::operator()(), CompareTwoTracksVectors::operator()(), TangentApproachInRPhi::perpdist(), EgammaIsoDetIdCollectionProducer< T1 >::produce(), RKPropagatorInS::propagateParametersOnCylinder(), AnalyticalPropagator::propagateParametersOnPlane(), SoftLepton::refineJetAxis(), CATopJetAlgorithm::run(), cms::CATopJetProducer::runAlgorithm(), and cms::HTTTopJetProducer::runAlgorithm().

140 {
T __attribute__::perp2 ( ) const
Geom::Phi<T> __attribute__::phi ( ) const

Definition at line 143 of file Basic3DVectorLD.h.

150 {
Geom::Theta<T> __attribute__::theta ( ) const

Definition at line 150 of file Basic3DVectorLD.h.

References Basic3DVector< T >::theX, Basic3DVector< T >::theY, Basic3DVector< T >::theZ, Basic3DVector< T >::x(), Basic3DVector< T >::y(), and Basic3DVector< T >::z().

Referenced by GflashTrajectory::_refreshCache(), Hector::addPartToHepMC(), fireworks::addStraightLineSegment(), algorithm(), ElectronTagProbeAnalyzer::analyze(), HCALRecHitAnalyzer::analyze(), EcalEBTrigPrimAnalyzer::analyze(), TrackerHitAnalyzer::analyze(), edm::FlatEGunASCIIWriter::analyze(), TrackBuildingAnalyzer::analyze(), StandaloneTrackMonitor::analyze(), EcalTrigPrimAnalyzer::analyze(), MuonDTDigis::analyze(), EcalTPGParamBuilder::analyze(), BaseProtonTransport::ApplyBeamCorrection(), BremsstrahlungSimulator::brem(), fastsim::Bremsstrahlung::brem(), MuonBremsstrahlungSimulator::brem(), fastsim::MuonBremsstrahlung::brem(), FWTracksterProxyBuilder::build(), FWConvTrackHitsDetailView::build(), FWMET3DProxyBuilder::build(), FWTauProxyBuilderBase::buildBaseTau(), FWECALCaloDataDetailViewBuilder::buildCaloData(), SeedingOTEDProducer::buildInitialTSOS(), FWPFClusterRPZUtils::buildRhoZClusterLineSet(), FWMETProxyBuilder::buildViewType(), FWJetProxyBuilder::buildViewType(), TFitParticleESpher::calc4Vec(), TFitParticleEtThetaPhi::calc4Vec(), TFitParticleSpher::calc4Vec(), TFitParticleMCSpher::calc4Vec(), TFitParticleMCPInvSpher::calc4Vec(), emtf::calc_theta_deg_from_int(), emtf::calc_theta_int(), emtf::calc_theta_int_rpc(), emtf::calc_theta_rad_from_eta(), PtAssignmentEngineAux2017::calcTrackTheta(), CSCHaloAlgo::Calculate(), PtAssignmentEngine2016::calculate_address(), PtAssignmentEngine2017::calculate_address(), AngleCalculation::calculate_angles(), PtAssignmentEngine2016::calculate_pt_xml(), PtAssignmentEngine2017::calculate_pt_xml(), CandidatePointSeededTrackingRegionsProducer::CandidatePointSeededTrackingRegionsProducer(), TwoBodyDecayModel::cartesianSecondaryMomenta(), SSDigitizerAlgorithm::cbc3PulsePolarExpansion(), MultipleScatteringSimulator::compute(), NuclearInteractionSimulator::compute(), AnalyticalCurvilinearJacobian::computeFullJacobian(), HDRShower::computeShower(), DTDigitizer::computeTime(), EcalHitMaker::configureGeometry(), DDHCalEndcapAlgo::constructInsideModule(), HCalEndcapAlgo::constructInsideModule(), DDHCalEndcapAlgo::constructInsideModule0(), HCalEndcapAlgo::constructInsideModule0(), ElectronEnergyCalibrator::correctLinearity(), TSCPBuilderNoMaterial::createFTSatTransverseImpactPointNeutral(), DDHGCalNoTaperEndcap::createQuarter(), fireworks::createSegment(), Decay3Body::doDecay(), CSCValidation::doSegments(), Pixel3DDigitizerAlgorithm::drift(), DTDigitizer::driftTimeFromParametrization(), DTBtiChip::DTBtiChip(), egammaTools::ecalEta(), tauImpactParameter::MultiProngTauSolver::estimateNu(), metsig::SignAlgoResolutions::eval(), DDAngular::execute(), DDTrackerAngular::execute(), DDTrackerPhiAlgo::execute(), DDTrackerPhiAltAlgo::execute(), DDTIDRingAlgo::execute(), DDHCalTestBeamAlgo::execute(), DDTECOptoHybAlgo::execute(), DDTECPhiAlgo::execute(), DDTECPhiAltAlgo::execute(), DDTIDAxialCableAlgo::execute(), DDHCalAngular::execute(), DDHCalXtalAlgo::execute(), DDHCalTBZposAlgo::execute(), DDTIBLayerAlgo::execute(), DDEcalBarrelAlgo::execute(), DDEcalBarrelNewAlgo::execute(), DDTrackerRingAlgo::execute(), KinematicPerigeeConversions::extendedPerigeeFromKinematicParameters(), CTPPSFastTrackingProducer::FastReco(), HcalTestAnalysis::fill(), SimG4HcalValidation::fill(), HcalTB04Analysis::fillBuffer(), GenSpecificAlgo::fillCommonMETData(), TrackerHitProducer::fillG4MC(), tadqm::TrackAnalyzer::fillHistosForState(), reco::Mustache::FillMustacheVar(), NtupleManager::FillOptObjects(), EopVariables::fillVariables(), SETFilter::find3MoreStartingPoints(), spr::findDetIdECAL(), spr::findDetIdHCAL(), SETFilter::findMinChi2(), MuonShowerInformationFiller::findThetaCluster(), tauImpactParameter::TauA1NuConstrainedFitter::fit(), LocalTrackFitter::fitAndRemoveOutliers(), OutInConversionSeedFinder::fixPointRadius(), PerigeeConversions::ftsToPerigeeParameters(), gen::Py8PtAndDxyGun::generatePartonsAndHadronize(), PPSTools::Get_t_and_xi(), calib::CalibElectron::getCalibModulesWeights(), EcalDeadCellTriggerPrimitiveFilter::getChannelStatusMaps(), EcalDeadCellDeltaRFilter::getChannelStatusMaps(), L1TMuon::TriggerPrimitive::getCMSGlobalPoint(), TFitParticleESpher::getDerivative(), TFitParticleEtThetaPhi::getDerivative(), TFitParticleSpher::getDerivative(), TFitParticleMCSpher::getDerivative(), TFitParticleMCPInvSpher::getDerivative(), HcalDDDSimConstants::getDetEta(), ZdcSD::getEnergyDeposit(), PtAssignmentEngineAux2016::getEtaFromThetaInt(), PythiaFilterIsolatedTrack::GetEtaPhiAtEcal(), IsolatedPixelTrackCandidateProducer::GetEtaPhiAtEcal(), IsolatedPixelTrackCandidateL1TProducer::GetEtaPhiAtEcal(), IsoTrig::GetEtaPhiAtEcal(), CastorSD::getFromLibrary(), PtAssignmentEngineAux::getGMTEta(), reco::TauMassTagInfo::getInvariantMass(), CastorShowerLibraryMaker::GetKinematics(), CastorShowerLibrary::getShowerHits(), DDHCalBarrelAlgo::getTheta(), CaloCellId::getThetaCell(), HcalDDDRecConstants::getThickActive(), HcalBarrelAlgo::HcalBarrelAlgo(), PPSTools::HectorParticle2LorentzVector(), DDHCalTestBeamAlgo::initialize(), DDHCalTBZposAlgo::initialize(), FastTimeDDDConstants::initialize(), fastsim::Bremsstrahlung::interact(), fastsim::MultipleScattering::interact(), fastsim::MuonBremsstrahlung::interact(), fastsim::NuclearInteraction::interact(), MuonMesh::isClusteredWith(), MuonMesh::isDuplicateOf(), riemannFit::lineFit(), edm::RandomtXiGunProducer::make_particle(), HcalDDDGeometryLoader::makeCell(), Multi5x5BremRecoveryClusterAlgo::makeIslandSuperClusters(), ticl::SeedingRegionByHF::makeRegions(), fireworks::makeRhoZSuperCluster(), FinalTreeBuilder::momentumPart(), CosmicGenFilterHelix::monitorStart(), heppy::Davismt2::mt2_massless(), muonisolation::CaloExtractor::MuonAtCaloPosition(), FWGUIManager::open3DRegion(), SimpleConeBounds::openingAngle(), SimG4HcalHitCluster::operator+=(), reco::PreshowerCluster::operator<(), DD4hep_ListGroups::overlayEtaReferences(), ListGroups::overlayEtaReferences(), DDLTrapezoid::processElement(), edm::GaussRandomPThetaGunProducer::produce(), edm::RandomMultiParticlePGunProducer::produce(), edm::FlatRandomEThetaGunProducer::produce(), edm::FileRandomMultiParticlePGunProducer::produce(), edm::FlatRandomMultiParticlePGunProducer::produce(), edm::FlatRandomPtThetaGunProducer::produce(), edm::FileRandomKEThetaGunProducer::produce(), ShallowTracksProducer::produce(), edm::FlatRandomOneOverPtGunProducer::produce(), edm::FlatRandomEGunProducer::produce(), edm::FlatRandomPtGunProducer::produce(), edm::MultiParticleInConeGunProducer::produce(), edm::ExpoRandomPtGunProducer::produce(), edm::BeamMomentumGunProducer::produce(), edm::ExpoRandomPGunProducer::produce(), ShallowSimTracksProducer::produce(), L1TTwinMuxProducer::produce(), pf2pat::PFMETAlgo::produce(), HLTL1TMuonSelector::produce(), HLTL1MuonSelector::produce(), L2MuonSeedGeneratorFromL1T::produce(), L2MuonSeedGenerator::produce(), L2MuonSeedGeneratorFromL1TkMu::produce(), TrackKinematicStatePropagator::propagateToTheTransversePCANeutral(), AsciiNeutronReader::readNextEvent(), heppy::Hemisphere::Reconstruct(), SteppingHelixPropagator::refToDest(), PointSeededTrackingRegionsProducer::regions(), CandidatePointSeededTrackingRegionsProducer::regions(), heppy::Hemisphere::RejectISR(), PFSpecificAlgo::run(), KFBasedPixelFitter::run(), EcalRecHitWorkerRecover::run(), RecoTracktoTP::s_eta(), TPtoRecoTrack::s_eta(), riemannFit::scatter_cov_rad(), CTPPSFastTrackingProducer::SearchTrack(), EcalDeadCellTriggerPrimitiveFilter::setEvtRecHitstatus(), TFitParticleEtThetaPhi::setIni4Vec(), TFitParticleESpher::setIni4Vec(), TFitParticleSpher::setIni4Vec(), TFitParticleMCSpher::setIni4Vec(), TFitParticleMCPInvSpher::setIni4Vec(), HcalForwardAnalysis::setPhotons(), tauImpactParameter::MultiProngTauSolver::setTauDirectionatThetaGJMax(), L1TMuon::TriggerPrimitive::setThetaBend(), EcalSelectiveReadoutValidation::setTtEtSums(), EcalSelectiveReadoutSuppressor::setTtFlags(), DTRecHitQuality::simHitImpactAngle(), smearFunctionBase::smearEta(), tauImpactParameter::TauA1NuConstrainedFitter::SolveAmbiguityAnalytically(), tauImpactParameter::TauA1NuConstrainedFitter::SolveAmbiguityAnalyticallywithRot(), tauImpactParameter::MultiProngTauSolver::solveByRotation(), reco::ForwardProton::t(), TangentCircle::TangentCircle(), tauImpactParameter::TauA1NuConstrainedFitter::TauRot(), kinem::theta(), HDRShower::thetaFunction(), HcalTestAnalysis::timeOfFlight(), HcalTB04Analysis::timeOfFlight(), spr::timeOfFlight(), SiStripFineDelayTOF::timeOfFlightBeamB(), SiStripFineDelayTOF::timeOfFlightCosmicB(), MuonNavigableLayer::trackingRange(), HectorTransport::transportProton(), InvariantMassFromVertex::uncertainty(), HcalTestAnalysis::update(), HcalTB02Analysis::update(), CastorTestAnalysis::update(), DoCastorAnalysis::update(), FW3DViewBase::updateClipPlanes(), MagGeoBuilderFromDDD::volumeHandle::volumeHandle(), magneticfield::volumeHandle::volumeHandle(), and ECALRecHitAnalyzer::WriteECALRecHits().

150 {
T __attribute__::transverse ( ) const

Another name for perp()

Definition at line 136 of file Basic3DVectorLD.h.

Referenced by SequentialVertexFitter< N >::fit().

140 {
Basic3DVector __attribute__::unit ( ) const

Unit vector parallel to this. If mag() is zero, a zero vector is returned.

Definition at line 162 of file Basic3DVectorLD.h.

Referenced by AlignableDet::AlignableDet(), FWME0SegmentProxyBuilder::build(), FWCSCSegmentProxyBuilder::build(), DTCombinatorialExtendedPatternReco::buildSegments(), DTCombinatorialPatternReco::buildSegments(), btagbtvdeep::TrackPairInfoBuilder::buildTrackPairInfo(), FWGEMSegmentProxyBuilder::buildViewType(), FWDTSegmentProxyBuilder::buildViewType(), PhiMemoryImage::check_input(), PhiMemoryImage::clear_bit(), AnalyticalCurvilinearJacobian::computeInfinitesimalJacobian(), ForwardDiskSectorBuilderFromWedges::computeRotation(), ForwardDiskSectorBuilderFromDet::computeRotation(), converter::SuperClusterToCandidate::convert(), CaloDetIdAssociator::crossedElement(), CSCFileReader::CSCFileReader(), Line::distance(), SignedImpactParameter3D::distance(), SignedImpactParameter3D::distanceWithJetAxis(), TransverseImpactPointExtrapolator::doExtrapolation(), GlobalHitsProdHist::fillG4MC(), GlobalHitsAnalyzer::fillG4MC(), GlobalHitsProducer::fillG4MC(), PhiMemoryImage::get_word(), StubPtConsistency::getConsistency(), DDG4Builder::getDouble(), HcalDDDRecConstants::getEtaPhi(), HcalDDDRecConstants::getHCID(), FlatHexagon::getTransform(), TruncatedPyramid::getTransform(), FlatTrd::getTransform(), CaloCellGeometry::getTransform(), HcalObjRepresent::HcalDataContainer< Items, Item >::GetUnit(), HcalDDDSimConstants::HcalCellTypes(), HcalDDDRecConstants::HcalCellTypes(), HcalTopology::HcalTopology(), HcalDDDRecConstants::initialize(), DTChamberEfficiencyTask::interpolate(), IPTools::jetTrackDistance(), IPTools::linearImpactParameter(), TracksClusteringFromDisplacedSeed::nearTracks(), TransverseBoundPlaneFactory::operator()(), PerpendicularBoundPlaneBuilder::operator()(), operator<<(), HcalTopology::phiBin(), FullModelHadronicProcess::PostStepDoIt(), SiStripFedCabling::printSummary(), SimPFProducer::produce(), GoodSeedProducer::produce(), TemplatedInclusiveVertexFinder< InputContainer, VTX >::produce(), LowPtGsfElectronSeedProducer::propagateTrackToCalo(), regressionTest_first(), SeedFromNuclearInteraction::rotationMatrix(), SeedFromGenericPairOrTriplet::seedFromPair(), PhiMemoryImage::set_bit(), PhiMemoryImage::set_word(), l1tVertexFinder::Stub::setModuleInfo(), CSCSegFit::setOutFromIP(), MuonSegFit::setOutFromIP(), GEMCSCSegFit::setOutFromIP(), PhiMemoryImage::test_bit(), npstat::BoxND< Numeric >::unitBox(), and AlignableDet::update().

169  {
T __attribute__::x ( ) const

Cartesian x coordinate.

Definition at line 110 of file Basic3DVectorLD.h.

115 { return std::atan2(perp(), z()); }
float float float z
T perp() const
Magnitude of transverse component.
Basic2DVector<T> __attribute__::xy ( ) const

Definition at line 118 of file Basic3DVectorLD.h.

Referenced by Phase1PixelSummaryMap::addNamedBins(), MuonCSCChamberResidual::addResidual(), HGCGeometryValidation::analyze(), HGCalHitValidation::analyzeHGCalSimHit(), HGCalSimHitStudy::analyzeHits(), HGCalSimHitValidation::analyzeHits(), HGCalTBAnalyzer::analyzeSimHits(), TrackerSectorStruct::bookCorrHists(), CSCPairResidualsConstraint::calculatePhi(), HGCalDDDConstants::cellInLayer(), HFNoseNumberingScheme::checkPosition(), HGCalNumberingScheme::checkPosition(), MonitorTrackResidualsBase< pixel_or_strip >::createMEs(), CaloDetIdAssociator::crossedElement(), EcalTBMCInfoProducer::EcalTBMCInfoProducer(), HGCMouseBite::exclude(), MuonGeometryArrange::fillTree(), HGCalGeometry::get8Corners(), HGCalGeometry::getCorners(), NtupleManager::GetGlobalAngles(), MEEBGeom::getGraphBoundary(), HGCalGeometry::getNewCorners(), HGCalGeometry::getPosition(), HLTScalersClient::getSlope_(), HGCalWaferType::getType(), CachedTrajectory::getWideTrajectory(), fastTrackingUtilities::hitLocalError(), HGCalDDDConstants::isValidCell8(), HGCalGeomParameters::loadGeometryHexagon(), GEMStripTopology::localError(), CSCRadialStripTopology::localError(), TkRadialStripTopology::localError(), HGCalDDDConstants::localToGlobal8(), HGCalDDDConstants::locateCell(), FastTrackerRecHitMatcher::match(), SiStripRecHitMatcher::match(), GlobalErrorBase< double, ErrorMatrixTag >::phierr(), GlobalErrorBaseExtended< double, ErrorMatrixTag >::phierr(), CaloGeometryDBEP< T, U >::produceAligned(), gen::PtYDistributor::PtYDistributor(), CocoaAnalyzer::readXMLFile(), GlobalErrorBase< double, ErrorMatrixTag >::rerr(), GlobalErrorBaseExtended< double, ErrorMatrixTag >::rerr(), PixelFitterByConformalMappingAndLine::run(), ROOT::Math::Transform3DPJ::SetComponents(), LinkByRecHit::testECALAndPSByRecHit(), HGCalDDDConstants::waferFromPosition(), HGCalDDDConstants::waferLocal2Global(), HGCalDDDConstants::waferPosition(), HGCalDDDConstants::waferPositionNoRot(), HGCalWaferMask::waferXY(), and Basic3DVector< align::Scalar >::xy().

123 { return detailsBasic3DVector::eta(x(), y(), z()); } // correct
float float float z
uint16_t const *__restrict__ x
Definition: gpuClustering.h:39
T __attribute__::y ( ) const

Cartesian y coordinate.

Definition at line 113 of file Basic3DVectorLD.h.

115 { return std::atan2(perp(), z()); }
float float float z
T perp() const
Magnitude of transverse component.
T __attribute__::z ( ) const

Cartesian z coordinate.

Definition at line 116 of file Basic3DVectorLD.h.

References Basic3DVector< T >::perp(), and Basic3DVector< T >::z().

116 { return Geom::Theta<T>(std::atan2(perp(), z())); }
float float float z
T perp() const
Magnitude of transverse component.

Variable Documentation

T theW

Definition at line 244 of file Basic3DVectorLD.h.

Referenced by align::diffAlignables().

T theX

Definition at line 241 of file Basic3DVectorLD.h.

T theY

Definition at line 242 of file Basic3DVectorLD.h.

T theZ

Definition at line 243 of file Basic3DVectorLD.h.

Referenced by LaserAlignment::testRoutine().