CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Functions | Variables
geometryDiff Namespace Reference

Functions

def loopover
 
def matrixmult
 
def rotFromEuler
 
def rotFromPhi
 
def transpose
 

Variables

int epsilon = 1
 
tuple geom1 = MuonGeometry(file(args[0]))
 
tuple geom2 = MuonGeometry(file(args[1]))
 
tuple opts = dict(opts)
 
tuple sqrtepsilon = sqrt(epsilon)
 
string usage = "Usage: geometryDiff.py [-h|--help] [-e|--epsilon epsilon] geometry1.xml geometry2.xml"
 

Function Documentation

def geometryDiff.loopover (   which)

Definition at line 62 of file geometryDiff.py.

References funct.abs(), matrixmult(), print(), rotFromEuler(), rotFromPhi(), str, and transpose().

62 
63 def loopover(which):
64  if which == "DT":
65  keys = geom1.dt.keys()
66  keys.sort(dtorder)
67 
68  elif which == "CSC":
69  keys = geom1.csc.keys()
70  keys.sort(cscorder)
71 
72  else: raise Exception
73 
74  for key in keys:
75  if which == "DT":
76  g1 = geom1.dt[key]
77  g2 = geom2.dt[key]
78  else:
79  g1 = geom1.csc[key]
80  g2 = geom2.csc[key]
81 
82  if g1.relativeto != g2.relativeto:
83  print("%s %s relativeto=\"%s\" versus relativeto=\"%s\"" % (which, str(key), g1.relativeto, g2.relativeto))
84 
85  if abs(g1.x - g2.x) > epsilon or abs(g1.y - g2.y) > epsilon or abs(g1.z - g2.z) > epsilon:
86  print("%s %s position difference: (%g, %g, %g) - (%g, %g, %g) = (%g, %g, %g)" % \
87  (which, str(key), g1.x, g1.y, g1.z, g2.x, g2.y, g2.z, g1.x - g2.x, g1.y - g2.y, g1.z - g2.z))
88 
89  if "phix" in g1.__dict__:
90  g1type = "phi"
91  g1a, g1b, g1c = g1.phix, g1.phiy, g1.phiz
92  g1rot = rotFromPhi(g1)
93  else:
94  g1type = "euler"
95  g1a, g1b, g1c = g1.alpha, g1.beta, g1.gamma
96  g1rot = rotFromEuler(g1)
97 
98  if "phix" in g2.__dict__:
99  g2type = "phi"
100  g2a, g2b, g2c = g2.phix, g2.phiy, g2.phiz
101  g2rot = rotFromPhi(g2)
102  else:
103  g2type = "euler"
104  g2a, g2b, g2c = g2.alpha, g2.beta, g2.gamma
105  g2rot = rotFromEuler(g2)
106 
107  diff = matrixmult(g1rot, transpose(g2rot))
108  if abs(diff[0][0] - 1.) > sqrtepsilon or abs(diff[1][1] - 1.) > sqrtepsilon or abs(diff[2][2] - 1.) > sqrtepsilon or \
109  abs(diff[0][1]) > epsilon or abs(diff[0][2]) > epsilon or abs(diff[1][2]) > epsilon:
110  print("%s %s rotation difference: %s(%g, %g, %g) - %s(%g, %g, %g) = %s" % \
111  (which, str(key), g1type, g1a, g1b, g1c, g2type, g2a, g2b, g2c, str(diff)))
112 
113 loopover("DT")
114 loopover("CSC")
115 
116 
void print(TMatrixD &m, const char *label=nullptr, bool mathematicaFormat=false)
Definition: Utilities.cc:47
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
#define str(s)
def geometryDiff.matrixmult (   a,
  b 
)

Definition at line 36 of file geometryDiff.py.

References ComparisonHelper.zip().

Referenced by loopover(), and rotFromPhi().

36 
37 def matrixmult(a, b):
38  return [[sum([i*j for i, j in zip(row, col)]) for col in zip(*b)] for row in a]
OutputIterator zip(InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp)
def geometryDiff.rotFromEuler (   g)

Definition at line 55 of file geometryDiff.py.

References funct.cos(), and funct.sin().

Referenced by loopover().

55 
56 def rotFromEuler(g):
57  s1, s2, s3 = sin(g.alpha), sin(g.beta), sin(g.gamma)
58  c1, c2, c3 = cos(g.alpha), cos(g.beta), cos(g.gamma)
59  return [[c2 * c3, c1 * s3 + s1 * s2 * c3, s1 * s3 - c1 * s2 * c3,],
60  [-c2 * s3, c1 * c3 - s1 * s2 * s3, s1 * c3 + c1 * s2 * s3,],
61  [s2, -s1 * c2, c1 * c2, ]]
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
def geometryDiff.rotFromPhi (   g)

Definition at line 42 of file geometryDiff.py.

References funct.cos(), matrixmult(), and funct.sin().

Referenced by loopover().

42 
43 def rotFromPhi(g):
44  phix, phiy, phiz = g.phix, g.phiy, g.phiz
45  rotX = [[1., 0., 0., ],
46  [0., cos(phix), sin(phix),],
47  [0., -sin(phix), cos(phix),]]
48  rotY = [[cos(phiy), 0., -sin(phiy),],
49  [0., 1., 0., ],
50  [sin(phiy), 0., cos(phiy),]]
51  rotZ = [[cos(phiz), sin(phiz), 0., ],
52  [-sin(phiz), cos(phiz), 0., ],
53  [0., 0., 1., ]]
54  return matrixmult(rotX, matrixmult(rotY, rotZ))
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
def geometryDiff.transpose (   a)

Definition at line 39 of file geometryDiff.py.

References sistrip::SpyUtilities.range().

Referenced by AlignmentCorrelationsStore.correlations(), AlignmentExtendedCorrelationsStore.correlations(), AlignmentCorrelationsStore.correlationsAvailable(), AlignmentExtendedCorrelationsStore.correlationsAvailable(), AlignmentExtendedCorrelationsStore.getCorrelations(), loopover(), AlignmentCorrelationsStore.setCorrelations(), AlignmentExtendedCorrelationsStore.setCorrelations(), and npstat::ArrayND< Numeric, StackLen, StackDim >.transpose().

39 
40 def transpose(a):
41  return [[a[j][i] for j in range(len(a[i]))] for i in range(len(a))]
const uint16_t range(const Frame &aFrame)

Variable Documentation

int geometryDiff.epsilon = 1

Definition at line 26 of file geometryDiff.py.

Referenced by ReferenceTrajectory.addMaterialEffectsCurvlinGbl(), ReferenceTrajectory.addMaterialEffectsLocalGbl(), almost_equal(), angle_units::operators.almostEqual(), GlobalTrackerMuonAlignment.analyzeTrackTrack(), GlobalTrackerMuonAlignment.analyzeTrackTrajectory(), trklet::TrackletCalculatorDisplaced.approxprojdisk(), GeneralBinFinderInPhi< T >.binIndex(), magneticfield::bSlab.bSlab(), TrackWithHistory.checkAtEnd(), computePFMEtSignificance(), TauDiscriminantCutMultiplexerT< TauType, TauTypeRef, ParentClass >.discriminate(), CMSCGEN.dNdEmudEnu(), IntegralOverPhiFunction.DoEval(), IntegrandThetaFunction.DoEval(), DTSegment4DQuality.dqmAnalyze(), TMultiDimFet.EvalControl(), KinematicPerigeeConversions.extendedPerigeeFromKinematicParameters(), DAClusterizerInZ_vect.fill(), DAClusterizerInZT_vect.fill(), Thrust.finalAxis(), PerigeeConversions.ftsToPerigeeParameters(), GEMEfficiencyAnalyzer.GEMEfficiencyAnalyzer(), PixelInactiveAreaFinder.getPhiSpanBarrel(), PixelInactiveAreaFinder.getPhiSpanEndcap(), ConversionProducer.getTrackImpactPosition(), initBarrel(), initCylinder(), initNegative(), initPositive(), SmartPropagator.initTkVolume(), HiPuRhoProducer.inputTowers(), VirtualJetProducer.inputTowers(), CSCLayerGeometry.inside(), SimpleNavigationSchool.linkNextLargerLayer(), SimpleNavigationSchool.linkNextLayerInGroup(), angle0to2pi.make0To2pi(), DTTopology.onWhichBorder(), DTTopology.onWhichBorder_old(), CMSInsideOutAlgorithm::ListIteratorLesserByDeltaR.operator()(), NumericSafeLessByEt< T >.operator()(), NumericSafeLessByPt< T >.operator()(), NumericSafeGreaterByEt< T >.operator()(), NumericSafeGreaterByPt< T >.operator()(), PFMEtSignInterfaceBase.operator()(), DTSegmentCand.operator==(), SimpleNavigationSchool.outerRadiusIncrease(), placeAssembly(), RecHitPropagator.propagate(), tauImpactParameter::ErrorMatrixPropagator.propagateError(), SiLinearChargeDivider.readPulseShape(), FixedFlatOccupancy1d.set_epsilon_max(), CSC01.set_epsilon_max(), FixedFlatOccupancy1d.set_epsilon_min(), SiPixelRecHitQuality::Packing.setProbabilityQ(), SiPixelRecHitQuality::Packing.setProbabilityXY(), NAEquationSolver< Function >.SetTolerance(), DAClusterizerInZ.split(), DAClusterizerInZ_vect.split(), DAClusterizerInZ.splitAll(), muonisolation::NominalEfficiencyThresholds.thresholdValueForEfficiency(), trklet::VarAdjustK.VarAdjustK(), and trklet::VarAdjustKR.VarAdjustKR().

tuple geometryDiff.geom1 = MuonGeometry(file(args[0]))

Definition at line 30 of file geometryDiff.py.

tuple geometryDiff.geom2 = MuonGeometry(file(args[1]))

Definition at line 31 of file geometryDiff.py.

tuple geometryDiff.opts = dict(opts)

Definition at line 20 of file geometryDiff.py.

Referenced by edm::service::TriggerNamesService.TriggerNamesService().

tuple geometryDiff.sqrtepsilon = sqrt(epsilon)

Definition at line 34 of file geometryDiff.py.

string geometryDiff.usage = "Usage: geometryDiff.py [-h|--help] [-e|--epsilon epsilon] geometry1.xml geometry2.xml"

Definition at line 8 of file geometryDiff.py.