@@ -50,8 +50,10 @@ add_QC_JSON() {
5050 OUTPUT_SUFFIX+=" -$1 "
5151}
5252
53+ JSON_TEMP_FILES=" ()"
54+
5355QC_CONFIG=
54- QC_CONFIG_OVERRIDE=
56+ : ${ QC_CONFIG_OVERRIDE:= } # set to empty string only if not already set externally
5557: ${QC_DETECTOR_CONFIG_OVERRIDE:= } # set to empty string only if not already set externally
5658if [[ -z ${QC_JSON_FROM_OUTSIDE:- } && ! -z ${GEN_TOPO_QC_JSON_FILE:- } && -f $GEN_TOPO_QC_JSON_FILE ]]; then
5759 QC_JSON_FROM_OUTSIDE=$GEN_TOPO_QC_JSON_FILE
@@ -266,7 +268,61 @@ elif [[ -z ${QC_JSON_FROM_OUTSIDE:-} ]]; then
266268 DET_JSON_FILE=" QC_JSON_GLO_$i "
267269 if has_matching_qc $i && [ ! -z " ${! DET_JSON_FILE:- } " ]; then
268270 if [[ $i == " PRIMVTX" ]] && ! has_detector_reco ITS; then continue ; fi
269- if [[ $i == " ITSTPC" ]] && ! has_detectors_reco ITS TPC; then continue ; fi
271+ if [[ $i == " ITSTPC" ]] ; then
272+ if ! has_detectors_reco ITS TPC; then continue
273+ else
274+ # replace the input sources depending on the detector compostition and matching detectors
275+ ITSTPCMatchQuery=" trackITSTPC:GLO/TPCITS/0;trackITSTPCABREFS:GLO/TPCITSAB_REFS/0;trackITSTPCABCLID:GLO/TPCITSAB_CLID/0;trackTPC:TPC/TRACKS;trackTPCClRefs:TPC/CLUSREFS/0;trackITS:ITS/TRACKS/0;trackITSROF:ITS/ITSTrackROF/0;trackITSClIdx:ITS/TRACKCLSID/0;alpparITS:ITS/ALPIDEPARAM/0?lifetime=condition&ccdb-path=ITS/Config/AlpideParam;SVParam:GLO/SVPARAM/0?lifetime=condition&ccdb-path=GLO/Config/SVertexerParam"
276+ if [[ $SYNCMODE == 1 ]] || [[ $EPNSYNCMODE == 1 ]] ; then
277+ HAS_K0_ENABLED=$( jq -r .qc.tasks.MTCITSTPC.taskParameters.doK0QC " ${! DET_JSON_FILE} " )
278+ else
279+ HAS_K0_ENABLED=$( jq -r .qc.tasks.GLOMatchTrITSTPC.taskParameters.doK0QC " ${! DET_JSON_FILE} " )
280+ fi
281+ TRACKSOURCESK0=" ITS,TPC,ITS-TPC"
282+ if [[ $HAS_K0_ENABLED == " true" ]]; then
283+ ITSTPCMatchQuery+=" ;p2decay3body:GLO/PVTX_3BODYREFS/0;decay3body:GLO/DECAYS3BODY/0;decay3bodyIdx:GLO/DECAYS3BODY_IDX/0;p2cascs:GLO/PVTX_CASCREFS/0;cascs:GLO/CASCS/0;cascsIdx:GLO/CASCS_IDX/0;p2v0s:GLO/PVTX_V0REFS/0;v0s:GLO/V0S/0;v0sIdx:GLO/V0S_IDX/0;pvtx_tref:GLO/PVTX_TRMTCREFS/0;pvtx_trmtc:GLO/PVTX_TRMTC/0;pvtx:GLO/PVTX/0;clusTPCoccmap:TPC/TPCOCCUPANCYMAP/0;clusTPC:TPC/CLUSTERNATIVE;clusTPCshmap:TPC/CLSHAREDMAP/0;trigTPC:TPC/TRIGGERWORDS/0"
284+ if has_secvtx_source ITS-TPC-TRD ; then
285+ ITSTPCMatchQuery+=" ;trigITSTPCTRD:TRD/TRGREC_ITSTPC/0;trackITSTPCTRD:TRD/MATCH_ITSTPC/0"
286+ TRACKSOURCESK0+=" ,ITS-TPC-TRD"
287+ fi
288+ if has_secvtx_source ITS-TPC-TOF ; then
289+ ITSTPCMatchQuery+=" ;matchITSTPCTOF:TOF/MTC_ITSTPC/0"
290+ TRACKSOURCESK0+=" ,ITS-TPC-TOF"
291+ fi
292+ if has_secvtx_source ITS-TPC-TRD-TOF ; then
293+ ITSTPCMatchQuery+=" ;matchITSTPCTRDTOF:TOF/MTC_ITSTPCTRD/0"
294+ TRACKSOURCESK0+=" ,ITS-TPC-TRD-TOF"
295+ fi
296+ if has_secvtx_source TPC-TRD ; then
297+ ITSTPCMatchQuery+=" ;trigTPCTRD:TRD/TRGREC_TPC/0;trackTPCTRD:TRD/MATCH_TPC/0"
298+ TRACKSOURCESK0+=" ,TPC-TRD"
299+ fi
300+ if has_secvtx_source TPC-TOF ; then
301+ ITSTPCMatchQuery+=" ;matchTPCTOF:TOF/MTC_TPC/0;trackTPCTOF:TOF/TOFTRACKS_TPC/0"
302+ TRACKSOURCESK0+=" ,TPC-TOF"
303+ fi
304+ if has_secvtx_source TPC-TRD-TOF ; then
305+ ITSTPCMatchQuery+=" ;matchTPCTRDTOF/TOF/MTC_TPCTRD/0"
306+ TRACKSOURCESK0+=" ,TPC-TRD-TOF"
307+ fi
308+ if has_secvtx_source TOF ; then
309+ ITSTPCMatchQuery+=" ;tofcluster:TOF/CLUSTERS/0"
310+ TRACKSOURCESK0+=" ,TOF"
311+ fi
312+ if has_secvtx_source TRD ; then
313+ TRACKSOURCESK0+=" ,TRD"
314+ fi
315+ fi
316+ TEMP_FILE=$( mktemp " ${i} " _XXXXXXX)
317+ if [[ $SYNCMODE == 1 ]] || [[ $EPNSYNCMODE == 1 ]] ; then
318+ cat " ${! DET_JSON_FILE} " | jq " (.dataSamplingPolicies[] | select(.id == \" ITSTPCmSampK0\" ) | .query) = \" $ITSTPCMatchQuery \" | .qc.tasks.MTCITSTPC.taskParameters.trackSourcesK0 = \" $TRACKSOURCESK0 \" " > " $TEMP_FILE "
319+ else
320+ cat " ${! DET_JSON_FILE} " | jq " .qc.tasks.GLOMatchTrITSTPC.dataSource.query = \" $ITSTPCMatchQuery \" | .qc.tasks.GLOMatchTrITSTPC.taskParameters.trackSourcesK0 = \" $TRACKSOURCESK0 \" " > " $TEMP_FILE "
321+ fi
322+ DET_JSON_FILE=TEMP_FILE
323+ JSON_TEMP_FILES+=(" $TEMP_FILE " )
324+ fi
325+ fi
270326 add_QC_JSON GLO_$i ${! DET_JSON_FILE}
271327 fi
272328 done
@@ -324,6 +380,11 @@ elif [[ -z ${QC_JSON_FROM_OUTSIDE:-} ]]; then
324380 fi
325381 MERGED_JSON_FILENAME=$( realpath $MERGED_JSON_FILENAME )
326382
383+ # Clean up: delete the temporary files after use
384+ for tf in " ${JSON_TEMP_FILES[@]} " ; do
385+ rm -f " $tf "
386+ done
387+
327388 if [[ " ${QC_REDIRECT_MERGER_TO_LOCALHOST:- } " == " 1" ]]; then
328389 sed -i.bak -E ' s/( *)"remoteMachine" *: *".*"(,?) *$/\1"remoteMachine": "127.0.0.1"\2/' $MERGED_JSON_FILENAME
329390 unlink $MERGED_JSON_FILENAME .bak
@@ -362,7 +423,9 @@ if [[ ! -z "${QC_JSON_FROM_OUTSIDE:-}" ]]; then
362423 QC_CONFIG_PARAM=" --local-batch=QC.root"
363424 fi
364425 fi
426+
365427 add_W o2-qc " --config json://$QC_JSON_FROM_OUTSIDE ${QC_CONFIG_PARAM} ${QC_CONFIG} "
428+
366429fi
367430
368431if [[ ! -z ${GEN_TOPO_QC_JSON_FILE:- } ]]; then
0 commit comments