From d0c2a129a0fbf9077a19e78ecf58cc6760eafec5 Mon Sep 17 00:00:00 2001 From: mmusich Date: Fri, 11 Mar 2022 14:11:40 +0100 Subject: [PATCH] introduce real data unit test for pede --- .../test/BuildFile.xml | 5 + .../test/TestDriver.cpp | 2 + .../test/test_pede.py | 100 ++++++++++++++++++ .../test/test_pede.sh | 32 ++++++ 4 files changed, 139 insertions(+) create mode 100644 Alignment/MillePedeAlignmentAlgorithm/test/TestDriver.cpp create mode 100644 Alignment/MillePedeAlignmentAlgorithm/test/test_pede.py create mode 100755 Alignment/MillePedeAlignmentAlgorithm/test/test_pede.sh diff --git a/Alignment/MillePedeAlignmentAlgorithm/test/BuildFile.xml b/Alignment/MillePedeAlignmentAlgorithm/test/BuildFile.xml index b5cf58f8993be..a6d954d927ad8 100644 --- a/Alignment/MillePedeAlignmentAlgorithm/test/BuildFile.xml +++ b/Alignment/MillePedeAlignmentAlgorithm/test/BuildFile.xml @@ -5,3 +5,8 @@ + + + + + diff --git a/Alignment/MillePedeAlignmentAlgorithm/test/TestDriver.cpp b/Alignment/MillePedeAlignmentAlgorithm/test/TestDriver.cpp new file mode 100644 index 0000000000000..2f0e0c40064da --- /dev/null +++ b/Alignment/MillePedeAlignmentAlgorithm/test/TestDriver.cpp @@ -0,0 +1,2 @@ +#include "FWCore/Utilities/interface/TestHelper.h" +RUNTEST() diff --git a/Alignment/MillePedeAlignmentAlgorithm/test/test_pede.py b/Alignment/MillePedeAlignmentAlgorithm/test/test_pede.py new file mode 100644 index 0000000000000..262094bf569a5 --- /dev/null +++ b/Alignment/MillePedeAlignmentAlgorithm/test/test_pede.py @@ -0,0 +1,100 @@ +import FWCore.ParameterSet.Config as cms +process = cms.Process("Alignment") + +process.Tracer = cms.Service("Tracer") + +setupGlobaltag = "121X_mcRun3_2021_realistic_forpp900GeV_v6" +setupCollection = "ALCARECOTkAlCosmicsCosmicTF0T" +setupCosmicsDecoMode = True +setupCosmicsZeroTesla = False +setupPrimaryWidth = -1.0 +setupJson = "placeholder_json" +setupRunStartGeometry = 1 +setupAlgoMode = "pede" +setupMonitorFile = "millePedeMonitorISN.root" +setupBinaryFile = "milleBinaryISN.dat" +readFiles = cms.untracked.vstring() + +import Alignment.MillePedeAlignmentAlgorithm.alignmentsetup.GeneralSetup as generalSetup +generalSetup.setup(process, setupGlobaltag, setupCosmicsZeroTesla) + + +################################################################################ +# setup alignment producer +################################################################################ +import Alignment.MillePedeAlignmentAlgorithm.alignmentsetup.ConfigureAlignmentProducer as confAliProducer + +confAliProducer.setConfiguration(process, + collection = setupCollection, + mode = setupAlgoMode, + monitorFile = setupMonitorFile, + binaryFile = setupBinaryFile, + primaryWidth = setupPrimaryWidth, + cosmicsZeroTesla = setupCosmicsZeroTesla) + + +################################################################################ +# Overwrite some conditions in global tag +################################################################################ +import Alignment.MillePedeAlignmentAlgorithm.alignmentsetup.SetCondition as tagwriter + +################################################################################ +# insert Startgeometry +################################################################################ +# You can use tagwriter.setCondition() to overwrite conditions in globaltag + +################################################################################ +# insert Alignables +################################################################################ +process.AlignmentProducer.ParameterBuilder.parameterTypes = ["SelectorRigid,RigidBody"] + +################################################################################ +# Define the high-level structure alignables +################################################################################ +process.AlignmentProducer.ParameterBuilder.SelectorRigid = cms.PSet( + alignParams = cms.vstring( + "TrackerP1PXBHalfBarrel,111111", + "TrackerP1PXECHalfCylinder,111111", + "TrackerTIBHalfBarrel,111111", + "TrackerTOBHalfBarrel,rrrrrr", + "TrackerTIDEndcap,111111", + "TrackerTECEndcap,111111", + ) +) + +################################################################################ +# insert Pedesettings +################################################################################ +import Alignment.MillePedeAlignmentAlgorithm.alignmentsetup.helper as helper +helper.set_pede_option(process, "skipemptycons") + +################################################################################ +# Mille-procedure +################################################################################ +if setupAlgoMode == "mille": + import Alignment.MillePedeAlignmentAlgorithm.alignmentsetup.MilleSetup as mille + mille.setup(process, + input_files = readFiles, + collection = setupCollection, + json_file = setupJson, + cosmics_zero_tesla = setupCosmicsZeroTesla, + cosmics_deco_mode = setupCosmicsDecoMode) + +################################################################################ +# Pede-procedure +################################################################################ +else: + merge_binary_files = [ + 'milleBinary001.dat', + 'milleBinary002.dat', + 'milleBinary003.dat'] + merge_tree_files = [ + 'treeFile001.root', + 'treeFile002.root', + 'treeFile003.root'] + + import Alignment.MillePedeAlignmentAlgorithm.alignmentsetup.PedeSetup as pede + pede.setup(process, + binary_files = merge_binary_files, + tree_files = merge_tree_files, + run_start_geometry = setupRunStartGeometry) diff --git a/Alignment/MillePedeAlignmentAlgorithm/test/test_pede.sh b/Alignment/MillePedeAlignmentAlgorithm/test/test_pede.sh new file mode 100755 index 0000000000000..3683ba50ce54e --- /dev/null +++ b/Alignment/MillePedeAlignmentAlgorithm/test/test_pede.sh @@ -0,0 +1,32 @@ +#!/bin/bash +function die { echo $1: status $2; exit $2; } + +if [ "${SCRAM_TEST_NAME}" != "" ] ; then + mkdir ${SCRAM_TEST_NAME} + cd ${SCRAM_TEST_NAME} +fi + +if test -f "milleBinary00*"; then + echo "cleaning the local test area" + rm -fr milleBinary00* + rm -fr pedeSteer* +fi + +pwd +echo " testing Aligment/MillePedeAlignmentAlgorithm" + +REMOTE="/store/group/alca_global/tkal_millepede_tests/" +TESTPACKAGE="test_pede_package.tar" +COMMMAND=`xrdfs cms-xrd-global.cern.ch locate ${REMOTE}${TESTPACKAGE}` +STATUS=$? +echo "xrdfs command status = "$STATUS +if [ $STATUS -eq 0 ]; then + echo "Using file ${TESTPACKAGE}. Running in ${LOCAL_TEST_DIR}." + xrdcp root://cms-xrd-global.cern.ch/${REMOTE}${TESTPACKAGE} ${LOCAL_TEST_DIR} + tar -xvf ${LOCAL_TEST_DIR}/${TESTPACKAGE} + gunzip milleBinary00* + (cmsRun ${LOCAL_TEST_DIR}/test_pede.py) || die 'failed running test_pede.py' $? + echo -e "\n MillePede Exit Status: "`cat millepede.end` +else + die "SKIPPING test, file ${TESTPACKAGE} not found" 0 +fi