From 3b5fc70442e0165985490dd08de4cde697c7ae64 Mon Sep 17 00:00:00 2001 From: ywkao Date: Fri, 19 Jul 2024 19:43:26 +0200 Subject: [PATCH 1/4] Update for beam test 2024 July --- HGCalRenderPlugin.cc | 47 +++++++++++++++++++++------- hgcal-layouts.py | 74 ++++++++++++++++++++------------------------ workspaces-online.py | 19 ++++-------- 3 files changed, 76 insertions(+), 64 deletions(-) diff --git a/HGCalRenderPlugin.cc b/HGCalRenderPlugin.cc index a62895f..812f72c 100644 --- a/HGCalRenderPlugin.cc +++ b/HGCalRenderPlugin.cc @@ -24,18 +24,19 @@ class HGCalRenderPlugin : public DQMRenderPlugin { public: virtual bool applies(const VisDQMObject &o, const VisDQMImgInfo &) { - if (o.name.find("HGCAL/Digis") != std::string::npos) + if (o.name.find("HGCAL/Modules") != std::string::npos) return true; - if (o.name.find("HGCAL/Maps") != std::string::npos) + else if (o.name.find("HGCAL/Digis") != std::string::npos) return true; - if (o.name.find("HGCAL/Summary") != std::string::npos) - return true; - return false; + else + return false; } virtual void preDraw(TCanvas *c, const VisDQMObject &o, const VisDQMImgInfo &, VisDQMRenderInfo &) { c->cd(); - if (o.name.find("HGCAL/Summary/hex") != std::string::npos) { + c->SetRightMargin(0.15); + + if (o.name.find("HGCAL/Modules/hex") != std::string::npos) { //printf("[DEBUG] HGCAL/Maps/%s is loaded\n", o.name.c_str()); if (dynamic_cast(o.object)) { preDrawHex(o); @@ -77,10 +78,11 @@ class HGCalRenderPlugin : public DQMRenderPlugin { gStyle->SetPaintTextFormat(".0f"); } else { gStyle->SetPaintTextFormat(".2f"); + // gStyle->SetPaintTextFormat(".1e"); } obj->SetMarkerSize(0.7); - obj->SetOption("colztext"); + obj->SetOption("colz"); // colztext obj->SetStats(kFALSE); obj->GetXaxis()->CenterLabels(); obj->GetYaxis()->CenterLabels(); @@ -102,11 +104,13 @@ class HGCalRenderPlugin : public DQMRenderPlugin { gStyle->SetPadBorderSize(0); gStyle->SetOptStat(10); - if (o.name.find("h2d") != std::string::npos) { + if ( (o.name.find("econd") != std::string::npos) || (o.name.find("Quality") != std::string::npos) ) { + gStyle->SetOptStat(10); gStyle->SetPalette(kCherry); TColor::InvertPalette(); - obj->SetStats(kFALSE); + obj->SetStats(kTRUE); } else { + gStyle->SetOptStat(1111); gStyle->SetPalette(1); obj->SetStats(kTRUE); } @@ -133,6 +137,27 @@ class HGCalRenderPlugin : public DQMRenderPlugin { TString name(obj->GetName()); assert(obj); + // printf("[DEBUG-tmp] %s\n", name.Data()); + // Get the palette axis + TPaletteAxis *palette = (TPaletteAxis*)obj->GetListOfFunctions()->FindObject("palette"); + if (palette) { + // Adjust title offset (moves title away from axis) + obj->GetZaxis()->SetTitleOffset(1.2); + + // Rotate the title (angle in degrees) + // obj->GetZaxis()->SetTitleAngle(90); // Vertical title // not working + + // You can also adjust other properties + obj->GetZaxis()->SetTitleFont(42); + obj->GetZaxis()->SetTitleSize(0.035); + + // Force redraw to apply changes + c->Update(); + } + + //-------------------------------------------------- + // Draw auxiliary lines + //-------------------------------------------------- std::vector> x_coords; std::vector> y_coords; @@ -173,7 +198,7 @@ class HGCalRenderPlugin : public DQMRenderPlugin { text.SetTextFont(43); text.SetTextSize(12); - if (name.Contains("HD")) { + if (name.Contains("HD") || name.Contains("MH")) { double theta1 = 0.; double theta2 = 4 * TMath::Pi() / 3.; double theta3 = 2 * TMath::Pi() / 3.; @@ -204,7 +229,7 @@ class HGCalRenderPlugin : public DQMRenderPlugin { text.DrawText(x, y, v_texts[i]); } - } else if (name.Contains("LD")) { // LD + } else if (name.Contains("LD") || name.Contains("ML") || name.Contains("hex")) { // LD double theta1 = -TMath::Pi() / 3.; double theta2 = TMath::Pi() / 3.; double theta3 = TMath::Pi(); diff --git a/hgcal-layouts.py b/hgcal-layouts.py index 4ec70d2..e44bbd5 100644 --- a/hgcal-layouts.py +++ b/hgcal-layouts.py @@ -1,45 +1,39 @@ def hgcallayout(i, p, *rows): i["HGCAL/Layouts/" + p] = DQMItem(layout=rows) ########### define varialbles for frequently used strings ############# -hgcallink = " >>> Description" -summary = "summary map for hgcal, this is NOT an efficiency measurement. Each bin is normalized to 1 considering disconnected chamber" -noise = "Average number of noisy strip per roll, counted if a occupancy of single strip is greater than 3.5 times the average of a chamber" -hgcalevents = "Events processed by the RPC DQM" -fed = "FED Fatal Errors" -top = "RPC TOP Summary Histogram
GREEN - Good Chamber
BLUE - Chamber OFF
YELLOW - Noisy Strip
ORANGE - Noisy Chamber
PINK - Partly Dead Chamber
RED - Fully Dead Chamber
LIGHT BLUE - Bad Occupancy Shape
" -occupancy = "Occupancy " -clsize = "Cluster Size of RPC system" -nrofcl = "Number of clusters, i.e. reconstructed hits." -nrofdigi = "Number of single hits." -bx = "RPC BX distribution " -emtf = "RPC L1T EMTF information. " +hgcallink = " >>> Description" +quality = "summary of module status" +summary = "wafer map for hgcal" +digis = "digis information" ################### Links to TOP Summary Histograms ################################# -#hgcallayout(dqmitems, "00-Summary_Map", -# [{ 'path': "HGCAL/Summary/p_adc", 'description': summary + hgcallink }]) - -hgcallayout(dqmitems, "01-ChannelId-0_1_5_0", - [{ 'path': "HGCAL/Summary/hex_channelId0_1_5_0", 'description': summary + hgcallink }]) -hgcallayout(dqmitems, "02-ChannelId-0_2_5_0", - [{ 'path': "HGCAL/Summary/hex_channelId0_2_5_0", 'description': summary + hgcallink }]) - -hgcallayout(dqmitems, "03-Pedestal-0_1_5_0", - [{ 'path': "HGCAL/Summary/hex_pedestal0_1_5_0", 'description': summary + hgcallink }]) -hgcallayout(dqmitems, "04-Pedestal-0_2_5_0", - [{ 'path': "HGCAL/Summary/hex_pedestal0_2_5_0", 'description': summary + hgcallink }]) - -#hgcallayout(dqmitems, "05-Correlation_Ch22", -# [{ 'path': "HGCAL/Digis/h2d_adc_channel_22", 'description': summary + hgcallink }]) - -##Noisy summary -#hgcallayout(dqmitems, "01-Noisy_summary_Map", -# [{ 'path': "HGCAL/EventInfo/noisySummaryMap", 'description': noise + hgcallink }]) -# -##FED Fatal -#hgcallayout(dqmitems, "02-Fatal_FED_Errors", -# [{ 'path': "HGCAL/FEDIntegrity_EvF/FEDFatal", 'description': fed + hgcallink }]) -# -##HGCAL Events -#hgcallayout(dqmitems, "03-HGCAL_Events", -# [{ 'path': "HGCAL/AllHits/HGCALEvents", 'description': hgcalevents + hgcallink }]) -# +hgcallayout(dqmitems, "01-econdPayload", + [{ 'path': "HGCAL/Digis/econdPayload", 'description': quality + hgcallink }]) +hgcallayout(dqmitems, "02-econdQualityH", + [{ 'path': "HGCAL/Digis/econdQualityH", 'description': quality + hgcallink }]) +hgcallayout(dqmitems, "03-cbQualityH", + [{ 'path': "HGCAL/Digis/cbQualityH", 'description': quality + hgcallink }]) +hgcallayout(dqmitems, "04-Module0-avgadc", + [{ 'path': "HGCAL/Modules/hex_avgadc_module_0", 'description': summary + hgcallink }]) +hgcallayout(dqmitems, "05-Module1-avgadc", + [{ 'path': "HGCAL/Modules/hex_avgadc_module_1", 'description': summary + hgcallink }]) +hgcallayout(dqmitems, "06-Module2-avgadc", + [{ 'path': "HGCAL/Modules/hex_avgadc_module_2", 'description': summary + hgcallink }]) +hgcallayout(dqmitems, "07-Module3-avgadc", + [{ 'path': "HGCAL/Modules/hex_avgadc_module_3", 'description': summary + hgcallink }]) +hgcallayout(dqmitems, "08-Module4-avgadc", + [{ 'path': "HGCAL/Modules/hex_avgadc_module_4", 'description': summary + hgcallink }]) +hgcallayout(dqmitems, "09-Module5-avgadc", + [{ 'path': "HGCAL/Modules/hex_avgadc_module_5", 'description': summary + hgcallink }]) +hgcallayout(dqmitems, "10-digis0-adc", + [{ 'path': "HGCAL/Digis/adc_module_0", 'description': digis + hgcallink }]) +hgcallayout(dqmitems, "11-digis1-adc", + [{ 'path': "HGCAL/Digis/adc_module_1", 'description': digis + hgcallink }]) +hgcallayout(dqmitems, "12-digis2-adc", + [{ 'path': "HGCAL/Digis/adc_module_2", 'description': digis + hgcallink }]) +hgcallayout(dqmitems, "13-digis3-adc", + [{ 'path': "HGCAL/Digis/adc_module_3", 'description': digis + hgcallink }]) +hgcallayout(dqmitems, "14-digis4-adc", + [{ 'path': "HGCAL/Digis/adc_module_4", 'description': digis + hgcallink }]) +hgcallayout(dqmitems, "15-digis5-adc", + [{ 'path': "HGCAL/Digis/adc_module_5", 'description': digis + hgcallink }]) diff --git a/workspaces-online.py b/workspaces-online.py index 9001668..649cd56 100644 --- a/workspaces-online.py +++ b/workspaces-online.py @@ -14,11 +14,14 @@ # (I.e.: Don't make a mess.) # DQM workspaces: -server.workspace('DQMQuality', 0, 'Summaries', 'Summary') +server.workspace('DQMContent', 35, 'Calorimeters', 'HGCAL', '^HGCAL/', '', + 'HGCAL/Layouts/00-Modules', + 'HGCAL/Layouts/01-Digis', + ) +#server.workspace('DQMQuality', 0, 'Summaries', 'Summary') #server.workspace('DQMSummary', 1, 'Summaries', 'Reports') - -server.workspace('DQMShift', 2, 'Summaries', 'Shift') +#server.workspace('DQMShift', 2, 'Summaries', 'Shift') #server.workspace('DQMContent', 3, 'Summaries', 'Info', '^Info/', '', # 'Info/Layouts/1 - HV and Beam Status per LumiSection', @@ -30,12 +33,6 @@ # #server.workspace('DQMContent', 4, 'Summaries', 'Everything', '^', '^') -server.workspace('DQMContent', 35, 'Calorimeters', 'HGCAL', '^HGCAL/', '', - 'HGCAL/Layouts/00-Summary_Map', - 'HGCAL/Layouts/01-ChannelId', - 'HGCAL/Layouts/02-Pedestal', - ) - # # Trigger workspaces: # server.workspace('DQMContent', 10, 'Trigger', 'L1T', '^(L1T|L1T2016)/', '', # # Please add plots to Stage2-QuickCollection layout in layouts/l1t-layouts.py @@ -300,10 +297,6 @@ # 'Castor/Layouts/Digi/05 - DigiSize', # ) # -# server.workspace('DQMContent', 35, 'Calorimeters', 'HGCAL', '^HGCAL/', '', -# 'HGCAL/Layouts/01 - Pedestal in ADC', -# ) -# # # Muons workspaces: # server.workspace('DQMContent', 40, 'Muons', 'DT', '^DT/', '', # 'DT/Layouts/00-Summary/00-DataIntegritySummary', From f80b4dc2da08929e2818b215a0746aebe80e9073 Mon Sep 17 00:00:00 2001 From: ywkao Date: Mon, 22 Jul 2024 10:33:36 +0200 Subject: [PATCH 2/4] Update rendering plugin for layer-level polygonal plots --- HGCalRenderPlugin.cc | 40 ++++++++++++++++++++++------------------ workspaces-online.py | 19 +++++++++++++++++-- 2 files changed, 39 insertions(+), 20 deletions(-) diff --git a/HGCalRenderPlugin.cc b/HGCalRenderPlugin.cc index 812f72c..709f497 100644 --- a/HGCalRenderPlugin.cc +++ b/HGCalRenderPlugin.cc @@ -26,6 +26,8 @@ class HGCalRenderPlugin : public DQMRenderPlugin { virtual bool applies(const VisDQMObject &o, const VisDQMImgInfo &) { if (o.name.find("HGCAL/Modules") != std::string::npos) return true; + else if (o.name.find("HGCAL/Layers") != std::string::npos) + return true; else if (o.name.find("HGCAL/Digis") != std::string::npos) return true; else @@ -36,16 +38,8 @@ class HGCalRenderPlugin : public DQMRenderPlugin { c->cd(); c->SetRightMargin(0.15); - if (o.name.find("HGCAL/Modules/hex") != std::string::npos) { - //printf("[DEBUG] HGCAL/Maps/%s is loaded\n", o.name.c_str()); - if (dynamic_cast(o.object)) { - preDrawHex(o); - //printf("[DEBUG] HGCAL/Maps/%s is casted to TH2Poly\n", o.name.c_str()); - } else { - //if(o.object) printf("[DEBUG] o.object is NOT empty\n"); - //else printf("[DEBUG] o.object is NULL pointer\n"); - //printf("[DEBUG] HGCAL/Maps/%s is failed to cast to TH2Poly\n", o.name.c_str()); - } + if (dynamic_cast(o.object)) { + preDrawHex(o); } else if (dynamic_cast(o.object)) { preDrawTH2(c, o); } else if (dynamic_cast(o.object)) { @@ -68,21 +62,28 @@ class HGCalRenderPlugin : public DQMRenderPlugin { void preDrawHex(const VisDQMObject &o) { TH2Poly *obj = dynamic_cast(o.object); + TString name(obj->GetName()); assert(obj); //gStyle->SetPalette(kViridis); gStyle->SetPalette(kBird); + obj->SetOption("colz"); - //if (o.name.find("hex_channelId") !=std::string::npos) { - if (o.name.find("hex_channelId") != std::string::npos || o.name.find("hex_hgcrocPin") != std::string::npos || o.name.find("hex_sicellPadId") != std::string::npos) { + //customize display of hex plots + if (name.Contains("hex_channelId") || name.Contains("hex_hgcrocPin") || name.Contains("hex_sicellPadId")) { gStyle->SetPaintTextFormat(".0f"); + obj->SetMarkerSize(0.7); + obj->SetOption("colztext"); + } else if (name.Contains("_layer_")) { + gStyle->SetPaintTextFormat(".2e"); + obj->SetMarkerSize(2.0); + obj->SetOption("colztext"); } else { gStyle->SetPaintTextFormat(".2f"); - // gStyle->SetPaintTextFormat(".1e"); + obj->SetMarkerSize(0.7); + obj->SetOption("colz"); } - obj->SetMarkerSize(0.7); - obj->SetOption("colz"); // colztext obj->SetStats(kFALSE); obj->GetXaxis()->CenterLabels(); obj->GetYaxis()->CenterLabels(); @@ -161,7 +162,10 @@ class HGCalRenderPlugin : public DQMRenderPlugin { std::vector> x_coords; std::vector> y_coords; - if (name.Contains("LD_0")) { + if (name.Contains("_module_")) { + x_coords = aux::x_coords_LD_full; + y_coords = aux::y_coords_LD_full; + } else if (name.Contains("LD_0")) { x_coords = aux::x_coords_LD_full; y_coords = aux::y_coords_LD_full; } else if (name.Contains("LD_3")) { @@ -179,7 +183,7 @@ class HGCalRenderPlugin : public DQMRenderPlugin { if (drawLine) { TLine line; line.SetLineStyle(1); - line.SetLineColor(2); + line.SetLineColor(kRed-7); line.SetLineWidth(2); for (unsigned iline = 0; iline < x_coords.size(); ++iline) { @@ -229,7 +233,7 @@ class HGCalRenderPlugin : public DQMRenderPlugin { text.DrawText(x, y, v_texts[i]); } - } else if (name.Contains("LD") || name.Contains("ML") || name.Contains("hex")) { // LD + } else if (name.Contains("LD") || name.Contains("ML") || name.Contains("_module")) { // LD double theta1 = -TMath::Pi() / 3.; double theta2 = TMath::Pi() / 3.; double theta3 = TMath::Pi(); diff --git a/workspaces-online.py b/workspaces-online.py index 649cd56..76b920f 100644 --- a/workspaces-online.py +++ b/workspaces-online.py @@ -15,8 +15,23 @@ # DQM workspaces: server.workspace('DQMContent', 35, 'Calorimeters', 'HGCAL', '^HGCAL/', '', - 'HGCAL/Layouts/00-Modules', - 'HGCAL/Layouts/01-Digis', + # 'HGCAL/Layouts/00-Modules', + # 'HGCAL/Layouts/01-Digis', + "HGCAL/Digis/econdPayload", + "HGCAL/Digis/econdQualityH", + "HGCAL/Digis/cbQualityH", + "HGCAL/Modules/hex_avgadc_module_0", + "HGCAL/Modules/hex_avgadc_module_1", + "HGCAL/Modules/hex_avgadc_module_2", + "HGCAL/Modules/hex_avgadc_module_3", + "HGCAL/Modules/hex_avgadc_module_4", + "HGCAL/Modules/hex_avgadc_module_5", + "HGCAL/Digis/adc_module_0", + "HGCAL/Digis/adc_module_1", + "HGCAL/Digis/adc_module_2", + "HGCAL/Digis/adc_module_3", + "HGCAL/Digis/adc_module_4", + "HGCAL/Digis/adc_module_5", ) #server.workspace('DQMQuality', 0, 'Summaries', 'Summary') From ab7c674ebcd9ccf59089f20e442af81d38b26f45 Mon Sep 17 00:00:00 2001 From: ywkao Date: Tue, 3 Sep 2024 09:11:07 +0200 Subject: [PATCH 3/4] update script for quick (re)placements of HGCAL rendering plugins --- quick_replacement.sh | 48 +++++++++++++++----------------------------- 1 file changed, 16 insertions(+), 32 deletions(-) diff --git a/quick_replacement.sh b/quick_replacement.sh index 09faaf9..9efb33a 100755 --- a/quick_replacement.sh +++ b/quick_replacement.sh @@ -1,38 +1,22 @@ #!/bin/bash -# script to be executed under current/sw/slc7_amd64_gcc630/cms/dqmgui/ +current="." +destination="/data/srv/current/config/dqmgui" +backup="./backup" -dir="9.7.8" -ori_dir="original_9.7.8" -new_dir="new_feature_9.7.8.2" +function update(){ + f=$1 + d=$2 -function copy() -{ - file=$1 - echo "cp ${new_dir}/${file} ${dir}/${file}" - cp ${new_dir}/${file} ${dir}/${file} + cp -p ${current}/$f $d + ls -lhrt $d/$f } -function copy_dir() -{ - file=$1 - echo "cp -r ${new_dir}/${file} ${dir}/${file}" - cp -r ${new_dir}/${file} ${dir}/${file} -} - -# backup original directory first -echo "cp -r $dir $ori_dir" -cp -r $dir $ori_dir - -# update files for implementing TH2Poly -copy 128/bin/DQMCollector -copy 128/bin/visDQMIndex -copy 128/bin/visDQMRender -copy 128/lib/python2.7/site-packages/Monitoring/DQM/Accelerator.so -copy 128/lib/libDQMGUI.so - -# replace the include directory -echo "mv ${dir}/128/include ${dir}/128/tmp" -mv ${dir}/128/include ${dir}/128/tmp -copy_dir 128/include +# backup workspaces-online.py +mkdir -p ${backup} +cp -p "/data/srv/current/config/dqmgui/workspaces-online.py" ${backup} -echo ">>> finished!" +# update rendering plugins for HGCAL DQM plots +update "workspaces-online.py" "${destination}" +update "HGCalRenderPlugin.cc" "${destination}/style" +update "hgcal-layouts.py" "${destination}/layouts" +update "HGCalAuxiliaryInfo.h" "${destination}/style" From 8a19df85702b6e62f2cffd8428eb4fc3bb17b8ba Mon Sep 17 00:00:00 2001 From: ywkao Date: Tue, 3 Sep 2024 09:33:32 +0200 Subject: [PATCH 4/4] Update README.md --- README.md | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/README.md b/README.md index 2231794..2ca34c5 100644 --- a/README.md +++ b/README.md @@ -6,6 +6,10 @@ This repository tracks sparse CMS-HGCAL-DQM layouts and rendering plugins for sy 2. The code will be modified from time to time to meet the needs of beam tests at different stages 3. The DQM layout for the HGCAL beam tests differs slightly from the official one +# hgc-dqmgui (outdated) +> [!IMPORTANT] +> Please follow a link here: https://github.com/cms-DQM/dqmgui_prod_deployment/wiki (update: 2024) + Below are instructions on building a DQM GUI for the HGCAL. These commands are based on an official tutorial, [twiki/CMS/DQMGuiForUsers](https://twiki.cern.ch/twiki/bin/viewauth/CMS/DQMGuiForUsers), with additional steps for setting up HGCAL DQM. The procedure includes the following four steps: - Step1: Deploy a dqmgui