Skip to content

Commit

Permalink
Add clustering and calibration customization functions
Browse files Browse the repository at this point in the history
  • Loading branch information
jbsauvan committed Feb 11, 2018
1 parent 5dd214f commit aa74213
Show file tree
Hide file tree
Showing 3 changed files with 92 additions and 10 deletions.
20 changes: 20 additions & 0 deletions L1Trigger/L1THGCal/python/customCalibration.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
import FWCore.ParameterSet.Config as cms
import hgcalLayersCalibrationCoefficients_cfi as layercalibparam


def custom_cluster_calibration_global(process,
factor=1.084
):
parameters_c2d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C2d_parameters
parameters_c2d.calibSF_cluster = cms.double(factor)
parameters_c2d.applyLayerCalibration = cms.bool(False)
return process


def custom_cluster_calibration_layers(process,
weights=layercalibparam.TrgLayer_weights
):
parameters_c2d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C2d_parameters
parameters_c2d.layerWeights = weights
parameters_c2d.applyLayerCalibration = cms.bool(True)
return process
61 changes: 61 additions & 0 deletions L1Trigger/L1THGCal/python/customClustering.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
import FWCore.ParameterSet.Config as cms


def custom_2dclustering_distance(process,
distance=6.,# cm
seed_threshold=5.,# MipT
cluster_threshold=2.# MipT
):
parameters_c2d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C2d_parameters
parameters_c2d.seeding_threshold_silicon = cms.double(seed_threshold)
parameters_c2d.seeding_threshold_scintillator = cms.double(seed_threshold)
parameters_c2d.clustering_threshold_silicon = cms.double(cluster_threshold)
parameters_c2d.clustering_threshold_scintillator = cms.double(cluster_threshold)
parameters_c2d.dR_cluster = cms.double(distance)
parameters_c2d.clusterType = cms.string('dRC2d')
return process

def custom_2dclustering_topological(process,
seed_threshold=5.,# MipT
cluster_threshold=2.# MipT
):
parameters_c2d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C2d_parameters
parameters_c2d.seeding_threshold_silicon = cms.double(seed_threshold) # MipT
parameters_c2d.seeding_threshold_scintillator = cms.double(seed_threshold) # MipT
parameters_c2d.clustering_threshold_silicon = cms.double(cluster_threshold) # MipT
parameters_c2d.clustering_threshold_scintillator = cms.double(cluster_threshold) # MipT
parameters_c2d.clusterType = cms.string('NNC2d')
return process

def custom_2dclustering_constrainedtopological(process,
distance=6.,# cm
seed_threshold=5.,# MipT
cluster_threshold=2.# MipT
):
parameters_c2d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C2d_parameters
parameters_c2d.seeding_threshold_silicon = cms.double(seed_threshold) # MipT
parameters_c2d.seeding_threshold_scintillator = cms.double(seed_threshold) # MipT
parameters_c2d.clustering_threshold_silicon = cms.double(cluster_threshold) # MipT
parameters_c2d.clustering_threshold_scintillator = cms.double(cluster_threshold) # MipT
parameters_c2d.dR_cluster = cms.double(distance) # cm
parameters_c2d.clusterType = cms.string('dRNNC2d')
return process

def custom_3dclustering_distance(process,
distance=0.01
):
parameters_c3d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C3d_parameters
parameters_c3d.dR_multicluster = cms.double(distance)
parameters_c3d.type_multicluster = cms.string('dRC3d')
return process


def custom_3dclustering_dbscan(process,
distance=0.005,
min_points=3
):
parameters_c3d = process.hgcalTriggerPrimitiveDigiProducer.BEConfiguration.algorithms[0].C3d_parameters
parameters_c3d.dist_dbscan_multicluster = cms.double(distance)
parameters_c3d.minN_dbscan_multicluster = cms.uint32(min_points)
parameters_c3d.type_multicluster = cms.string('DBSCAN3d')
return process
21 changes: 11 additions & 10 deletions L1Trigger/L1THGCal/python/hgcalTriggerPrimitiveDigiProducer_cfi.py
Original file line number Diff line number Diff line change
Expand Up @@ -61,21 +61,22 @@
seeding_threshold_scintillator = cms.double(5), # MipT
clustering_threshold_silicon = cms.double(2), # MipT
clustering_threshold_scintillator = cms.double(2), # MipT
dR_cluster = cms.double(6.), # in cm
clusterType = cms.string('NNC2d'), # clustering type: dRC2d--> Geometric-dR clustering; NNC2d-->Nearest Neighbors clustering; dRNNC2d-->Limited Nearest Neighbors clustering
# clusterType = cms.string('dRC2d') # clustering type: dRC2d--> Geometric-dR clustering; NNC2d-->Nearest Neighbors clustering; dRNNC2d-->Limited Nearest Neighbors clustering
# clusterType = cms.string('dRNNC2d') # clustering type: dRC2d--> Geometric-dR clustering; NNC2d-->Nearest Neighbors clustering; dRNNC2d-->Limited Nearest Neighbors clustering
calibSF_cluster = cms.double(1.084),
clusterType = cms.string('NNC2d'),
applyLayerCalibration = cms.bool(True),
layerWeights = layercalibparam.TrgLayer_weights
layerWeights = layercalibparam.TrgLayer_weights,
# Parameters not used by this clustering
dR_cluster=cms.double(0.),
calibSF_cluster=cms.double(0.)
)

C3d_parValues = cms.PSet( dR_multicluster = cms.double(0.01), # dR in normalized plane used to clusterize C2d
minPt_multicluster = cms.double(0.5), # minimum pt of the multicluster (GeV)
type_multicluster = cms.string('dRC3d'), #'DBSCANC3d' for the DBSCAN algorithm
dist_dbscan_multicluster = cms.double(0.005),
minN_dbscan_multicluster = cms.uint32(3)
)
type_multicluster = cms.string('dRC3d'),
# Parameters not used by this clustering
dist_dbscan_multicluster=cms.double(0.),
minN_dbscan_multicluster=cms.uint32(0)
)

cluster_algo = cms.PSet( AlgorithmName = cms.string('HGCClusterAlgoThreshold'),
FECodec = fe_codec.clone(),
calib_parameters = calib_parValues.clone(),
Expand Down

0 comments on commit aa74213

Please sign in to comment.