From 9f0890158ad48d76b19c38f0da665b01caae84e1 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Thu, 29 Aug 2024 14:48:58 +0000 Subject: [PATCH 01/34] prettify MonitoringLAPPDData tool --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 2058 +++++++++-------- 1 file changed, 1149 insertions(+), 909 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index fb1d06dd9..e163814cc 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1,22 +1,23 @@ #include "MonitorLAPPDData.h" -MonitorLAPPDData::MonitorLAPPDData() : - Tool() { +MonitorLAPPDData::MonitorLAPPDData() : Tool() +{ } -bool MonitorLAPPDData::Initialise(std::string configfile, DataModel &data) { +bool MonitorLAPPDData::Initialise(std::string configfile, DataModel &data) +{ /////////////////// Useful header /////////////////////// if (configfile != "") m_variables.Initialise(configfile); // loading config file - //m_variables.Print(); + // m_variables.Print(); - m_data = &data; //assigning transient data pointer + m_data = &data; // assigning transient data pointer ///////////////////////////////////////////////////////////////// - //gObjectTable only for debugging memory leaks, otherwise comment out - //std::cout <<"MonitorLAPPDData: List of Objects (beginning of Initialise): "<Print(); + // gObjectTable only for debugging memory leaks, otherwise comment out + // std::cout <<"MonitorLAPPDData: List of Objects (beginning of Initialise): "<Print(); //------------------------------------------------------- //-----------------Get Configuration--------------------- @@ -27,7 +28,7 @@ bool MonitorLAPPDData::Initialise(std::string configfile, DataModel &data) { sync_reference_time = false; std::string acdc_configuration; - + m_variables.Get("OutputPath", outpath_temp); m_variables.Get("StartTime", StartTime); m_variables.Get("ReferenceDate", referenceDate); @@ -41,45 +42,47 @@ bool MonitorLAPPDData::Initialise(std::string configfile, DataModel &data) { m_variables.Get("DrawMarker", draw_marker); m_variables.Get("ThresholdPulse", threshold_pulse); m_variables.Get("verbose", verbosity); - + if (verbosity > 1) std::cout << "Tool MonitorLAPPDData: Initialising...." << std::endl; // Update frequency specifies the frequency at which the File Log Histogram is updated // All other monitor plots are updated as soon as a new file is available for readout - if (update_frequency < 0.1) { + if (update_frequency < 0.1) + { if (verbosity > 0) std::cout << "MonitorLAPPDData: Update Frequency of " << update_frequency << " mins is too low. Setting default value of 5 min." << std::endl; update_frequency = 5.; } - //default should be no forced update of the monitoring plots every execute step - if (force_update != 0 && force_update != 1) { + // default should be no forced update of the monitoring plots every execute step + if (force_update != 0 && force_update != 1) + { force_update = 0; } - //check if the image format is jpg or png - if (!(img_extension == "png" || img_extension == "jpg" || img_extension == "jpeg")) { + // check if the image format is jpg or png + if (!(img_extension == "png" || img_extension == "jpg" || img_extension == "jpeg")) + { img_extension = "jpg"; } - //Print out path to monitoring files + // Print out path to monitoring files if (verbosity > 2) std::cout << "MonitorLAPPDData: PathMonitoring: " << path_monitoring << std::endl; - //Set up Epoch + // Set up Epoch Epoch = new boost::posix_time::ptime(boost::gregorian::from_string(StartTime)); - - + referenceTimeDate = referenceDate + " " + referenceTime; boost::posix_time::ptime reference = boost::posix_time::time_from_string(referenceTimeDate); - - //Set up reference time + + // Set up reference time boost::posix_time::time_duration reference_stamp = boost::posix_time::time_duration(reference - *Epoch); reference_time = reference_stamp.total_milliseconds(); - if (verbosity > 1) std::cout <<"ReferenceTime: "< 1) + std::cout << "ReferenceTime: " << referenceTimeDate << ", total milliseconds: " << reference_time << std::endl; - //Evaluating output path for monitoring plots + // Evaluating output path for monitoring plots if (outpath_temp == "fromStore") m_data->CStore.Get("OutPath", outpath); else @@ -118,7 +121,8 @@ bool MonitorLAPPDData::Initialise(std::string configfile, DataModel &data) { return true; } -bool MonitorLAPPDData::Execute() { +bool MonitorLAPPDData::Execute() +{ if (verbosity > 10) std::cout << "MonitorLAPPDData: Executing ...." << std::endl; @@ -130,8 +134,8 @@ bool MonitorLAPPDData::Execute() { utc = (boost::posix_time::second_clock::universal_time()); current_utc_duration = boost::posix_time::time_duration(utc - current); current_utc = current_utc_duration.total_milliseconds(); - utc_to_t = (ULong64_t) current_utc; - t_current = (ULong64_t) current_stamp; + utc_to_t = (ULong64_t)current_utc; + t_current = (ULong64_t)current_stamp; //------------------------------------------------------------ //---------Checking the state of LAPPD SC data stream--------- @@ -143,38 +147,43 @@ bool MonitorLAPPDData::Execute() { std::string State; m_data->CStore.Get("State", State); - if (has_lappd) { - if (State == "Wait" || State == "LAPPDSC") { + if (has_lappd) + { + if (State == "Wait" || State == "LAPPDSC") + { if (verbosity > 2) std::cout << "MonitorLAPPDData: State is " << State << std::endl; - } else if (State == "DataFile") { + } + else if (State == "DataFile") + { if (verbosity > 1) std::cout << "MonitorLAPPDData: New PSEC data available." << std::endl; - //TODO - //TODO: Need to confirm data format of LAPPDData, is it PsecData, or a vec of PsecData, or map? - //TODO + // TODO + // TODO: Need to confirm data format of LAPPDData, is it PsecData, or a vec of PsecData, or map? + // TODO - //m_data->Stores["LAPPDData"]->Get("LAPPDData", LAPPDData); + // m_data->Stores["LAPPDData"]->Get("LAPPDData", LAPPDData); - //Process data - //TODO: Adapt when data type is understood + // Process data + // TODO: Adapt when data type is understood this->ProcessLAPPDData(); - //Write the event information to a file - //TODO: change this to a database later on! - //Check if data has already been written included in WriteToFile function + // Write the event information to a file + // TODO: change this to a database later on! + // Check if data has already been written included in WriteToFile function this->WriteToFile(); - //Plot plots only associated to current file + // Plot plots only associated to current file this->DrawLastFilePlots(); - //Draw customly defined plots + // Draw customly defined plots this->UpdateMonitorPlotsLAPPD(config_timeframes, config_endtime_long, config_label, config_plottypes); - //last = current; //Why was this here in the first place? - - } else { + // last = current; //Why was this here in the first place? + } + else + { if (verbosity > 1) std::cout << "MonitorLAPPDData: State not recognized: " << State << std::endl; } @@ -188,26 +197,27 @@ bool MonitorLAPPDData::Execute() { //-----------Has enough time passed for update?---------- //------------------------------------------------------- - if (duration >= period_update) { + if (duration >= period_update) + { Log("MonitorLAPPDData: " + std::to_string(update_frequency) + " mins passed... Updating file history plot.", v_message, verbosity); last = current; - //TODO: Maybe implement the file history plots - DrawFileHistoryLAPPD(current_stamp,24.,"current_24h",1); //show 24h history of LAPPD files - PrintFileTimeStampLAPPD(current_stamp,24.,"current_24h"); - DrawFileHistoryLAPPD(current_stamp,2.,"current_2h",3); - + // TODO: Maybe implement the file history plots + DrawFileHistoryLAPPD(current_stamp, 24., "current_24h", 1); // show 24h history of LAPPD files + PrintFileTimeStampLAPPD(current_stamp, 24., "current_24h"); + DrawFileHistoryLAPPD(current_stamp, 2., "current_2h", 3); } - //gObjectTable only for debugging memory leaks, otherwise comment out - //std::cout <<"MonitorLAPPDData: List of Objects (after execute step): "<Print(); + // gObjectTable only for debugging memory leaks, otherwise comment out + // std::cout <<"MonitorLAPPDData: List of Objects (after execute step): "<Print(); return true; } -bool MonitorLAPPDData::Finalise() { +bool MonitorLAPPDData::Finalise() +{ if (verbosity > 1) std::cout << "Tool MonitorLAPPDData: Finalising ...." << std::endl; @@ -215,10 +225,10 @@ bool MonitorLAPPDData::Finalise() { // gDirectory->ls(); // gDirectory->pwd(); - //timing pointers + // timing pointers delete Epoch; - //canvas + // canvas delete canvas_status_data; delete canvas_pps_rate; @@ -247,10 +257,10 @@ bool MonitorLAPPDData::Finalise() { delete canvas_ped_lappd; delete canvas_sigma_lappd; delete canvas_rate_lappd; - delete canvas_frame_count; + delete canvas_frame_count; delete canvas_pps_count; - //histograms + // histograms // /* Somehow deleting histograms creates a segfault, omit for now for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++){ @@ -269,8 +279,9 @@ bool MonitorLAPPDData::Finalise() { } */ - //graphs - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + // graphs + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); delete graph_pps_rate.at(board_nr); @@ -278,10 +289,12 @@ bool MonitorLAPPDData::Finalise() { delete graph_buffer_size.at(board_nr); delete graph_int_charge.at(board_nr); - if (board_nr != -1){ + if (board_nr != -1) + { int board_min = board_channel.at(i_board); - for (int i=0; i<30 ;i++){ - int chkey = board_min+i; + for (int i = 0; i < 30; i++) + { + int chkey = board_min + i; delete graph_ped.at(chkey); delete graph_sigma.at(chkey); delete graph_rate.at(chkey); @@ -289,18 +302,17 @@ bool MonitorLAPPDData::Finalise() { } } - - //multi-graphs + // multi-graphs delete multi_ped_lappd; delete multi_sigma_lappd; delete multi_rate_lappd; - //legends + // legends delete leg_ped_lappd; delete leg_sigma_lappd; delete leg_rate_lappd; - //text + // text delete text_data_title; delete text_pps_rate; delete text_frame_rate; @@ -312,13 +324,14 @@ bool MonitorLAPPDData::Finalise() { return true; } -void MonitorLAPPDData::InitializeHistsLAPPD() { +void MonitorLAPPDData::InitializeHistsLAPPD() +{ if (verbosity > 2) std::cout << "MonitorLAPPDData: InitializeHists" << std::endl; gROOT->cd(); - //Canvas + // Canvas canvas_status_data = new TCanvas("canvas_status_data", "Status of PSEC data", 900, 600); canvas_pps_rate = new TCanvas("canvas_pps_rate", "PPS Rate Time evolution", 900, 600); canvas_frame_rate = new TCanvas("canvas_frame_rate", "Frame Rate Time evolution", 900, 600); @@ -341,19 +354,19 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { canvas_pedestal_difference = new TCanvas("canvas_pedestal_difference", "LAPPD Pedestals Differences", 900, 600); canvas_buffer_size_all = new TCanvas("canvas_buffer_size_all", "LAPPD Buffer Sizes", 900, 600); canvas_rate_threshold_all = new TCanvas("canvas_rate_threshold_all", "LAPPD Hits", 900, 600); - canvas_logfile_lappd = new TCanvas("canvas_logfile_lappd","LAPPD File History",900,600); - canvas_file_timestamp_lappd = new TCanvas("canvas_file_timestamp_lappd","Timestamp Last File",900,600); + canvas_logfile_lappd = new TCanvas("canvas_logfile_lappd", "LAPPD File History", 900, 600); + canvas_file_timestamp_lappd = new TCanvas("canvas_file_timestamp_lappd", "Timestamp Last File", 900, 600); canvas_events_per_channel = new TCanvas("canvas_events_per_channel", "LAPPD Events per Channel", 900, 600); - canvas_ped_lappd = new TCanvas("canvas_ped_lappd","LAPPD Pedestals",900,600); - canvas_sigma_lappd = new TCanvas("canvas_sigma_lappd","LAPPD Sigmas",900,600); - canvas_rate_lappd = new TCanvas("canvas_rate_lappd","LAPPD Rates",900,600); - canvas_frame_count = new TCanvas("canvas_frame_count","LAPPD Data Count",900,600); - canvas_pps_count = new TCanvas("canvas_pps_count","LAPPD PPS Count",900,600); - - //Histograms - //ToDo: Not hardcode the number of channels here + canvas_ped_lappd = new TCanvas("canvas_ped_lappd", "LAPPD Pedestals", 900, 600); + canvas_sigma_lappd = new TCanvas("canvas_sigma_lappd", "LAPPD Sigmas", 900, 600); + canvas_rate_lappd = new TCanvas("canvas_rate_lappd", "LAPPD Rates", 900, 600); + canvas_frame_count = new TCanvas("canvas_frame_count", "LAPPD Data Count", 900, 600); + canvas_pps_count = new TCanvas("canvas_pps_count", "LAPPD PPS Count", 900, 600); + + // Histograms + // ToDo: Not hardcode the number of channels here int numberOfChannels = 30; - int numberOfCards = (int) board_configuration.size(); + int numberOfCards = (int)board_configuration.size(); hist_pedestal_all = new TH2F("Fitted pedestal values", "Fitted pedestal values", numberOfChannels, 0, numberOfChannels, numberOfCards, 0, numberOfCards); hist_pedestal_difference_all = new TH2F("Fitted pedestal difference values", "Fitted pedestal difference values", numberOfChannels, 0, numberOfChannels, numberOfCards, 0, numberOfCards); @@ -379,7 +392,8 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { hist_rate_threshold_all->GetYaxis()->SetNdivisions(numberOfCards); hist_events_per_channel->GetYaxis()->SetNdivisions(numberOfCards); - for (int i_label_x = 0; i_label_x < numberOfChannels; i_label_x++) { + for (int i_label_x = 0; i_label_x < numberOfChannels; i_label_x++) + { std::stringstream ss_channel; ss_channel << i_label_x; std::string str_ch = "ch " + ss_channel.str(); @@ -389,7 +403,8 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { hist_rate_threshold_all->GetXaxis()->SetBinLabel(i_label_x + 1, str_ch.c_str()); hist_events_per_channel->GetXaxis()->SetBinLabel(i_label_x + 1, str_ch.c_str()); } - for (int i_label_y = 0; i_label_y < numberOfCards; i_label_y++) { + for (int i_label_y = 0; i_label_y < numberOfCards; i_label_y++) + { std::stringstream ss_card; int board_nr = board_configuration.at(i_label_y); ss_card << board_nr; @@ -416,14 +431,17 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { hist_rate_threshold_all->LabelsOption("v"); hist_events_per_channel->LabelsOption("v"); -//TODO: Change this number -//In principle, here we need the number of events in the file - for (int i_event = 0; i_event < 100; i_event++) { - std::map > tempMap; - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + // TODO: Change this number + // In principle, here we need the number of events in the file + for (int i_event = 0; i_event < 100; i_event++) + { + std::map> tempMap; + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); - std::vector hist_waveform_temp_vec; - for (int i = 0; i < numberOfChannels; i++) { + std::vector hist_waveform_temp_vec; + for (int i = 0; i < numberOfChannels; i++) + { std::stringstream ss_waveform_text; ss_waveform_text << "hist_waveforms" << board_nr << "channel" << i << "event" << i_event; TH1F *hist_waveforms_onedim_single = new TH1F(ss_waveform_text.str().c_str(), ss_waveform_text.str().c_str(), 256, 0, 256); @@ -438,8 +456,9 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { hist_waveforms_onedim.push_back(tempMap); } - //Create separate histograms for all board numbers - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + // Create separate histograms for all board numbers + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); int min_board = board_channel.at(i_board); @@ -463,13 +482,13 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { TH1F *hist_align_20files_single = new TH1F(ss_align_20files.str().c_str(), ss_align_20files.str().c_str(), 100, 0, 20000); TH1F *hist_align_100files_single = new TH1F(ss_align_100files.str().c_str(), ss_align_100files.str().c_str(), 100, 0, 20000); TH1F *hist_align_1000files_single = new TH1F(ss_align_1000files.str().c_str(), ss_align_1000files.str().c_str(), 100, 0, 20000); - TH2F *hist_adc_channel_single = new TH2F(ss_adc_channel.str().c_str(), ss_adc_channel.str().c_str(), 200, -500, 0, 30, min_board, min_board+30); - TH2F *hist_waveform_channel_single = new TH2F(ss_waveform_channel.str().c_str(), ss_waveform_channel.str().c_str(), 256, 0, 256, 30, min_board, min_board+30); - TH2F *hist_buffer_channel_single = new TH2F(ss_buffer_channel.str().c_str(), ss_buffer_channel.str().c_str(), 50, 0, 2000, 30, min_board, min_board+30); + TH2F *hist_adc_channel_single = new TH2F(ss_adc_channel.str().c_str(), ss_adc_channel.str().c_str(), 200, -500, 0, 30, min_board, min_board + 30); + TH2F *hist_waveform_channel_single = new TH2F(ss_waveform_channel.str().c_str(), ss_waveform_channel.str().c_str(), 256, 0, 256, 30, min_board, min_board + 30); + TH2F *hist_buffer_channel_single = new TH2F(ss_buffer_channel.str().c_str(), ss_buffer_channel.str().c_str(), 50, 0, 2000, 30, min_board, min_board + 30); TH1F *hist_buffer_single = new TH1F(ss_buffer.str().c_str(), ss_buffer.str().c_str(), 50, 0, 2000); - TH2F *hist_waveform_voltages_single = new TH2F(ss_waveform_voltages.str().c_str(), ss_waveform_voltages.str().c_str(), 256, 0, 256, 30, min_board, min_board+30); + TH2F *hist_waveform_voltages_single = new TH2F(ss_waveform_voltages.str().c_str(), ss_waveform_voltages.str().c_str(), 256, 0, 256, 30, min_board, min_board + 30); - //TODO: Title, XAxis, YAxis for timing histos + // TODO: Title, XAxis, YAxis for timing histos hist_align_1file_single->GetXaxis()->SetTitle("Time [ns]"); hist_align_1file_single->GetYaxis()->SetTitle("Entries"); hist_align_1file_single->SetStats(0); @@ -527,12 +546,13 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { hist_buffer.emplace(board_nr, hist_buffer_single); hist_waveform_voltages.emplace(board_nr, hist_waveform_voltages_single); - std::vector hist_pedestal_temp_vec; + std::vector hist_pedestal_temp_vec; - for (int i = 0; i < numberOfChannels; i++) { + for (int i = 0; i < numberOfChannels; i++) + { std::stringstream ss_pedestal_text; ss_pedestal_text << "hist_pedestal" << board_nr << "channel" << i; - //ToDo: change this values to more reasonable numbers + // ToDo: change this values to more reasonable numbers TH1F *hist_pedestal_single = new TH1F(ss_pedestal_text.str().c_str(), ss_pedestal_text.str().c_str(), 200, -100, 0); hist_pedestal_single->GetXaxis()->SetTitle("ADC value"); hist_pedestal_single->GetYaxis()->SetTitle("Entries"); @@ -544,7 +564,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { } num_history_lappd = 10; - log_files_lappd = new TH1F("log_files_lappd","LAPPD Files History",num_history_lappd,0,num_history_lappd); + log_files_lappd = new TH1F("log_files_lappd", "LAPPD Files History", num_history_lappd, 0, num_history_lappd); log_files_lappd->GetXaxis()->SetTimeDisplay(1); log_files_lappd->GetXaxis()->SetLabelSize(0.03); log_files_lappd->GetXaxis()->SetLabelOffset(0.03); @@ -553,9 +573,10 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { log_files_lappd->GetYaxis()->SetLabelOffset(999); log_files_lappd->SetStats(0); - //Graphs - //Make one of each graph type for each board - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + // Graphs + // Make one of each graph type for each board + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); @@ -586,7 +607,8 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { graph_buffer_size_single->SetTitle(title_buffer_size.str().c_str()); graph_int_charge_single->SetTitle(title_int_charge.str().c_str()); - if (draw_marker) { + if (draw_marker) + { graph_pps_rate_single->SetMarkerStyle(20); graph_frame_rate_single->SetMarkerStyle(20); graph_buffer_size_single->SetMarkerStyle(20); @@ -643,16 +665,18 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { graph_buffer_size.emplace(board_nr, graph_buffer_size_single); graph_int_charge.emplace(board_nr, graph_int_charge_single); - if (board_nr != -1){ + if (board_nr != -1) + { int min_board = board_channel.at(i_board); - for (int i=0; i<30; i++){ + for (int i = 0; i < 30; i++) + { int chkey = min_board + i; std::stringstream ss_ped, ss_sigma, ss_rate; - ss_ped << "graph_ped_chkey" << chkey; - ss_sigma << "graph_sigma_chkey" << chkey; - ss_rate << "graph_rate_chkey" << chkey; - + ss_ped << "graph_ped_chkey" << chkey; + ss_sigma << "graph_sigma_chkey" << chkey; + ss_rate << "graph_rate_chkey" << chkey; + TGraph *graph_rate_single = new TGraph(); TGraph *graph_ped_single = new TGraph(); TGraph *graph_sigma_single = new TGraph(); @@ -662,27 +686,28 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { graph_sigma_single->SetName(ss_sigma.str().c_str()); std::stringstream title_rate, title_ped, title_sigma; - title_rate << "LAPPD Rate time evolution - Channel " << chkey; - title_ped << "LAPPD Baseline time evolution - Channel " << chkey; - title_sigma << "LAPPD Sigma time evolution - Channel " << chkey; + title_rate << "LAPPD Rate time evolution - Channel " << chkey; + title_ped << "LAPPD Baseline time evolution - Channel " << chkey; + title_sigma << "LAPPD Sigma time evolution - Channel " << chkey; graph_rate_single->SetTitle(title_rate.str().c_str()); graph_ped_single->SetTitle(title_ped.str().c_str()); graph_sigma_single->SetTitle(title_sigma.str().c_str()); - if (draw_marker) { - graph_rate_single->SetMarkerStyle(20); + if (draw_marker) + { + graph_rate_single->SetMarkerStyle(20); graph_ped_single->SetMarkerStyle(20); graph_sigma_single->SetMarkerStyle(20); } - graph_rate_single->SetMarkerColor((i%5)+1); - graph_ped_single->SetMarkerColor((i%5)+1); - graph_sigma_single->SetMarkerColor((i%5)+1); + graph_rate_single->SetMarkerColor((i % 5) + 1); + graph_ped_single->SetMarkerColor((i % 5) + 1); + graph_sigma_single->SetMarkerColor((i % 5) + 1); - graph_rate_single->SetLineColor((i%5)+1); - graph_ped_single->SetLineColor((i%5)+1); - graph_sigma_single->SetLineColor((i%5)+1); + graph_rate_single->SetLineColor((i % 5) + 1); + graph_ped_single->SetLineColor((i % 5) + 1); + graph_sigma_single->SetLineColor((i % 5) + 1); graph_rate_single->SetLineWidth(2); graph_ped_single->SetLineWidth(2); @@ -715,14 +740,11 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { graph_rate.emplace(chkey, graph_rate_single); graph_ped.emplace(chkey, graph_ped_single); graph_sigma.emplace(chkey, graph_sigma_single); - } - } - } - //Normal Graphs without board number + // Normal Graphs without board number graph_pps_count = new TGraph(); graph_frame_count = new TGraph(); @@ -732,7 +754,8 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { graph_pps_count->SetTitle("LAPPD PPS Events Time Evolution"); graph_frame_count->SetTitle("LAPPD Data Events Time Evolution"); - if (draw_marker){ + if (draw_marker) + { graph_pps_count->SetMarkerStyle(20); graph_frame_count->SetMarkerStyle(20); } @@ -760,24 +783,24 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { graph_pps_count->GetXaxis()->SetLabelOffset(0.03); graph_frame_count->GetXaxis()->SetLabelOffset(0.03); - + graph_pps_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_frame_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); - //Multi-Graphs + // Multi-Graphs multi_ped_lappd = new TMultiGraph(); multi_sigma_lappd = new TMultiGraph(); multi_rate_lappd = new TMultiGraph(); - //Legends - leg_ped_lappd = new TLegend(0.7,0.7,0.88,0.88); - leg_sigma_lappd = new TLegend(0.7,0.7,0.88,0.88); - leg_rate_lappd = new TLegend(0.7,0.7,0.88,0.88); + // Legends + leg_ped_lappd = new TLegend(0.7, 0.7, 0.88, 0.88); + leg_sigma_lappd = new TLegend(0.7, 0.7, 0.88, 0.88); + leg_rate_lappd = new TLegend(0.7, 0.7, 0.88, 0.88); leg_ped_lappd->SetLineColor(0); leg_sigma_lappd->SetLineColor(0); leg_rate_lappd->SetLineColor(0); - //Text + // Text text_data_title = new TText(); text_pps_rate = new TText(); text_buffer_size = new TText(); @@ -793,10 +816,10 @@ void MonitorLAPPDData::InitializeHistsLAPPD() { text_int_charge->SetNDC(1); text_pps_count->SetNDC(1); text_frame_count->SetNDC(1); - } -void MonitorLAPPDData::ReadInConfiguration() { +void MonitorLAPPDData::ReadInConfiguration() +{ //------------------------------------------------------- //----------------ReadInConfiguration ------------------- @@ -807,18 +830,22 @@ void MonitorLAPPDData::ReadInConfiguration() { ifstream file(plot_configuration.c_str()); std::string line; - if (file.is_open()) { - while (std::getline(file, line)) { + if (file.is_open()) + { + while (std::getline(file, line)) + { if (line.find("#") != std::string::npos) continue; std::vector values; std::stringstream ss; ss.str(line); std::string item; - while (std::getline(ss, item, '\t')) { + while (std::getline(ss, item, '\t')) + { values.push_back(item); } - if (values.size() < 4) { + if (values.size() < 4) + { if (verbosity > 0) std::cout << "ERROR (MonitorLAPPDData): ReadInConfiguration: Need at least 4 arguments in one line: TimeFrame - TimeEnd - FileLabel - PlotType1. Please look over the configuration file and adjust it accordingly." << std::endl; continue; @@ -828,23 +855,29 @@ void MonitorLAPPDData::ReadInConfiguration() { config_endtime.push_back(values.at(1)); config_label.push_back(values.at(2)); std::vector plottypes; - for (unsigned int i = 3; i < values.size(); i++) { + for (unsigned int i = 3; i < values.size(); i++) + { plottypes.push_back(values.at(i)); } config_plottypes.push_back(plottypes); } - } else { + } + else + { if (verbosity > 0) std::cout << "ERROR (MonitorLAPPDData): ReadInConfiguration: Could not open file " << plot_configuration << "! Check if path is valid..." << std::endl; } file.close(); - if (verbosity > 2) { + if (verbosity > 2) + { std::cout << "---------------------------------------------------------------------" << std::endl; std::cout << "MonitorLAPPDData: ReadInConfiguration: Read in the following data into configuration variables: " << std::endl; - for (unsigned int i_t = 0; i_t < config_timeframes.size(); i_t++) { + for (unsigned int i_t = 0; i_t < config_timeframes.size(); i_t++) + { std::cout << config_timeframes.at(i_t) << ", " << config_endtime.at(i_t) << ", " << config_label.at(i_t) << ", "; - for (unsigned int i_plot = 0; i_plot < config_plottypes.at(i_t).size(); i_plot++) { + for (unsigned int i_plot = 0; i_plot < config_plottypes.at(i_t).size(); i_plot++) + { std::cout << config_plottypes.at(i_t).at(i_plot) << ", "; } std::cout << std::endl; @@ -854,18 +887,24 @@ void MonitorLAPPDData::ReadInConfiguration() { if (verbosity > 2) std::cout << "MonitorLAPPDData: ReadInConfiguration: Parsing dates: " << std::endl; - for (unsigned int i_date = 0; i_date < config_endtime.size(); i_date++) { - if (config_endtime.at(i_date) == "TEND_LASTFILE") { + for (unsigned int i_date = 0; i_date < config_endtime.size(); i_date++) + { + if (config_endtime.at(i_date) == "TEND_LASTFILE") + { if (verbosity > 2) std::cout << "TEND_LASTFILE: Starting from end of last read-in file" << std::endl; ULong64_t zero = 0; config_endtime_long.push_back(zero); - } else if (config_endtime.at(i_date).size() == 15) { + } + else if (config_endtime.at(i_date).size() == 15) + { boost::posix_time::ptime spec_endtime(boost::posix_time::from_iso_string(config_endtime.at(i_date))); boost::posix_time::time_duration spec_endtime_duration = boost::posix_time::time_duration(spec_endtime - *Epoch); ULong64_t spec_endtime_long = spec_endtime_duration.total_milliseconds(); config_endtime_long.push_back(spec_endtime_long); - } else { + } + else + { if (verbosity > 2) std::cout << "Specified end date " << config_endtime.at(i_date) << " does not have the desired format YYYYMMDDTHHMMSS. Please change the format in the config file in order to use this tool. Starting from end of last file" << std::endl; ULong64_t zero = 0; @@ -874,15 +913,17 @@ void MonitorLAPPDData::ReadInConfiguration() { } } -void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) { +void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) +{ Log("MonitorLAPPDData: LoadACDCBoardConfig", v_message, verbosity); - //Load the active ACDC board numbers specified in the configuration file + // Load the active ACDC board numbers specified in the configuration file ifstream acdc_file(acdc_config); int board_number; int min_bin; - while (!acdc_file.eof()) { + while (!acdc_file.eof()) + { acdc_file >> board_number >> min_bin; if (acdc_file.eof()) break; @@ -931,11 +972,13 @@ void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) { data_beamgate_last20files.emplace(board_number, empty_int_64_vec); data_beamgate_last100files.emplace(board_number, empty_int_64_vec); data_beamgate_last1000files.emplace(board_number, empty_int_64_vec); - if (board_number != -1){ - for (int i=0; i<30; i++){ - ped_plot.emplace(min_bin+i,empty_double); - sigma_plot.emplace(min_bin+i,empty_double); - rate_plot.emplace(min_bin+i,empty_double); + if (board_number != -1) + { + for (int i = 0; i < 30; i++) + { + ped_plot.emplace(min_bin + i, empty_double); + sigma_plot.emplace(min_bin + i, empty_double); + rate_plot.emplace(min_bin + i, empty_double); } } } @@ -945,31 +988,31 @@ void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) { current_partrun = 0; current_pps_count = 0; current_frame_count = 0; - } -std::string MonitorLAPPDData::convertTimeStamp_to_Date(ULong64_t timestamp) { +std::string MonitorLAPPDData::convertTimeStamp_to_Date(ULong64_t timestamp) +{ - //format of date is YYYY_MM-DD + // format of date is YYYY_MM-DD boost::posix_time::ptime convertedtime = *Epoch + boost::posix_time::time_duration(int(timestamp / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(timestamp / MSEC_to_SEC / SEC_to_MIN) % 60, int(timestamp / MSEC_to_SEC / 1000.) % 60, timestamp % 1000); struct tm converted_tm = boost::posix_time::to_tm(convertedtime); std::stringstream ss_date; ss_date << converted_tm.tm_year + 1900 << "_" << converted_tm.tm_mon + 1 << "-" << converted_tm.tm_mday; return ss_date.str(); - } -bool MonitorLAPPDData::does_file_exist(std::string filename) { +bool MonitorLAPPDData::does_file_exist(std::string filename) +{ std::ifstream infile(filename.c_str()); bool file_good = infile.good(); infile.close(); return file_good; - } -void MonitorLAPPDData::WriteToFile() { +void MonitorLAPPDData::WriteToFile() +{ Log("MonitorLAPPDData: WriteToFile", v_message, verbosity); @@ -979,7 +1022,8 @@ void MonitorLAPPDData::WriteToFile() { t_file_end.clear(); t_file_end_global = 0; - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); t_file_end.push_back(last_timestamp.at(i_board)); if (last_timestamp.at(i_board) > t_file_end_global) @@ -1006,17 +1050,18 @@ void MonitorLAPPDData::WriteToFile() { std::vector *t_buffer_size = new std::vector; std::vector *t_board_idx = new std::vector; std::vector *t_chkey = new std::vector; - std::vector *t_rate = new std::vector; - std::vector *t_ped = new std::vector; - std::vector *t_sigma = new std::vector; + std::vector *t_rate = new std::vector; + std::vector *t_ped = new std::vector; + std::vector *t_sigma = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; ULong64_t t_lappd_offset; TTree *t; - if (f->GetListOfKeys()->Contains("lappddatamonitor_tree")) { + if (f->GetListOfKeys()->Contains("lappddatamonitor_tree")) + { Log("MonitorLAPPDData: WriteToFile: Tree already exists", v_message, verbosity); - t = (TTree*) f->Get("lappddatamonitor_tree"); + t = (TTree *)f->Get("lappddatamonitor_tree"); t->SetBranchAddress("t_start", &t_time); t->SetBranchAddress("t_end", &t_end); t->SetBranchAddress("pps_rate", &t_pps_rate); @@ -1025,17 +1070,19 @@ void MonitorLAPPDData::WriteToFile() { t->SetBranchAddress("int_charge", &t_int_charge); t->SetBranchAddress("buffer_size", &t_buffer_size); t->SetBranchAddress("board_idx", &t_board_idx); - t->SetBranchAddress("chkey",&t_chkey); - t->SetBranchAddress("rate",&t_rate); - t->SetBranchAddress("ped",&t_ped); - t->SetBranchAddress("sigma",&t_sigma); - t->SetBranchAddress("run",&t_run); - t->SetBranchAddress("subrun",&t_subrun); - t->SetBranchAddress("partrun",&t_partrun); + t->SetBranchAddress("chkey", &t_chkey); + t->SetBranchAddress("rate", &t_rate); + t->SetBranchAddress("ped", &t_ped); + t->SetBranchAddress("sigma", &t_sigma); + t->SetBranchAddress("run", &t_run); + t->SetBranchAddress("subrun", &t_subrun); + t->SetBranchAddress("partrun", &t_partrun); t->SetBranchAddress("pps_count", &t_pps_count); - t->SetBranchAddress("frame_count",&t_frame_count); - t->SetBranchAddress("lappd_offset",&t_lappd_offset); - } else { + t->SetBranchAddress("frame_count", &t_frame_count); + t->SetBranchAddress("lappd_offset", &t_lappd_offset); + } + else + { t = new TTree("lappddatamonitor_tree", "LAPPD Data Monitoring tree"); Log("MonitorLAPPDData: WriteToFile: Tree is created from scratch", v_message, verbosity); t->Branch("t_start", &t_time); @@ -1046,32 +1093,36 @@ void MonitorLAPPDData::WriteToFile() { t->Branch("int_charge", &t_int_charge); t->Branch("buffer_size", &t_buffer_size); t->Branch("board_idx", &t_board_idx); - t->Branch("chkey",&t_chkey); - t->Branch("rate",&t_rate); - t->Branch("ped",&t_ped); - t->Branch("sigma",&t_sigma); - t->Branch("run",&t_run); - t->Branch("subrun",&t_subrun); - t->Branch("partrun",&t_partrun); - t->Branch("pps_count", &t_pps_count); - t->Branch("frame_count",&t_frame_count); - t->Branch("lappd_offset",&t_lappd_offset); + t->Branch("chkey", &t_chkey); + t->Branch("rate", &t_rate); + t->Branch("ped", &t_ped); + t->Branch("sigma", &t_sigma); + t->Branch("run", &t_run); + t->Branch("subrun", &t_subrun); + t->Branch("partrun", &t_partrun); + t->Branch("pps_count", &t_pps_count); + t->Branch("frame_count", &t_frame_count); + t->Branch("lappd_offset", &t_lappd_offset); } int n_entries = t->GetEntries(); bool omit_entries = false; - for (int i_entry = 0; i_entry < n_entries; i_entry++) { + for (int i_entry = 0; i_entry < n_entries; i_entry++) + { t->GetEntry(i_entry); - if (t_board_idx->at(0) == -1) continue; - if (t_end->at(0) == t_file_end.at(0)) { + if (t_board_idx->at(0) == -1) + continue; + if (t_end->at(0) == t_file_end.at(0)) + { Log("WARNING (MonitorLAPPDData): WriteToFile: Wanted to write data from file that is already written to DB. Omit entries", v_warning, verbosity); omit_entries = true; } } - //if data is already written to DB/File, do not write it again - if (omit_entries) { - //don't write file again, but still delete TFile and TTree object!!! + // if data is already written to DB/File, do not write it again + if (omit_entries) + { + // don't write file again, but still delete TFile and TTree object!!! f->Close(); delete t_time; delete t_end; @@ -1092,7 +1143,7 @@ void MonitorLAPPDData::WriteToFile() { return; } - //If we have vectors, they need to be cleared + // If we have vectors, they need to be cleared t_time->clear(); t_end->clear(); t_pps_rate->clear(); @@ -1106,8 +1157,9 @@ void MonitorLAPPDData::WriteToFile() { t_ped->clear(); t_sigma->clear(); - //Get data that was processed - for (int i_current = 0; i_current < (int) current_pps_rate.size(); i_current++) { + // Get data that was processed + for (int i_current = 0; i_current < (int)current_pps_rate.size(); i_current++) + { t_time->push_back(first_timestamp.at(i_current)); t_end->push_back(last_timestamp.at(i_current)); t_pps_rate->push_back(current_pps_rate.at(i_current)); @@ -1121,18 +1173,19 @@ void MonitorLAPPDData::WriteToFile() { boost::posix_time::ptime starttime = *Epoch + boost::posix_time::time_duration(int(time / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(time / MSEC_to_SEC / SEC_to_MIN) % 60, int(time / MSEC_to_SEC / 1000.) % 60, time % 1000); struct tm starttime_tm = boost::posix_time::to_tm(starttime); Log( - "MonitorLAPPDData: WriteToFile: Board " + std::to_string(current_board_index.at(i_current)) + ". Writing data to file: " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" - + std::to_string(starttime_tm.tm_hour) + ":" + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec), v_message, verbosity); + "MonitorLAPPDData: WriteToFile: Board " + std::to_string(current_board_index.at(i_current)) + ". Writing data to file: " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" + std::to_string(starttime_tm.tm_hour) + ":" + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec), v_message, verbosity); } - if (verbosity > 3) std::cout <<"current_ped.size(): "< 3) + std::cout << "current_ped.size(): " << current_ped.size() << std::endl; + for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) + { t_chkey->push_back(current_chkey.at(i_current)); t_rate->push_back(current_rate.at(i_current)); t_ped->push_back(current_ped.at(i_current)); t_sigma->push_back(current_sigma.at(i_current)); } - + t_run = current_run; t_subrun = current_subrun; t_partrun = current_partrun; @@ -1140,19 +1193,26 @@ void MonitorLAPPDData::WriteToFile() { t_pps_count = current_pps_count; t_frame_count = current_frame_count; - if (verbosity > 3) std::cout <<"before fill"< 3) + std::cout << "before fill" << std::endl; t->Fill(); - if (verbosity > 3) std::cout <<"after fill"<Write("", TObject::kOverwrite); //prevent ROOT from making endless keys for the same tree when updating the tree - if (verbosity > 3) std::cout <<"after write"< 3) + std::cout << "after fill" << std::endl; + t->Write("", TObject::kOverwrite); // prevent ROOT from making endless keys for the same tree when updating the tree + if (verbosity > 3) + std::cout << "after write" << std::endl; f->Close(); - if (verbosity > 3) std::cout <<"after close"< 3) + std::cout << "after close" << std::endl; - if (verbosity > 3) std::cout <<"t_time"< 3) std::cout <<"t_time: "< 3) std::cout <<"t_time->size(): "<size()< 3) + std::cout << "t_time" << std::endl; + if (verbosity > 3) + std::cout << "t_time: " << t_time << std::endl; + if (verbosity > 3) + std::cout << "t_time->size(): " << t_time->size() << std::endl; - //Delete potential vectors + // Delete potential vectors delete t_time; delete t_end; delete t_pps_rate; @@ -1168,10 +1228,10 @@ void MonitorLAPPDData::WriteToFile() { delete f; gROOT->cd(); - } -void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { +void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) +{ Log("MonitorLAPPDData: ReadFromFile", v_message, verbosity); @@ -1179,7 +1239,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { //------------------ReadFromFile ------------------------ //------------------------------------------------------- - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); data_times_plot.at(board_nr).clear(); data_times_end_plot.at(board_nr).clear(); @@ -1191,7 +1252,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { num_channels_plot.at(board_nr).clear(); labels_timeaxis.at(board_nr).clear(); } - for (int i_ch=0; i_ch < (int) ped_plot.size(); i_ch++){ + for (int i_ch = 0; i_ch < (int)ped_plot.size(); i_ch++) + { ped_plot.at(i_ch).clear(); sigma_plot.at(i_ch).clear(); rate_plot.at(i_ch).clear(); @@ -1203,7 +1265,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { ppscount_plot.clear(); framecount_plot.clear(); - //take the end time and calculate the start time with the given time_frame + // take the end time and calculate the start time with the given time_frame ULong64_t timestamp_start = timestamp - time_frame * MIN_to_HOUR * SEC_to_MIN * MSEC_to_SEC; boost::posix_time::ptime starttime = *Epoch + boost::posix_time::time_duration(int(timestamp_start / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(timestamp_start / MSEC_to_SEC / SEC_to_MIN) % 60, int(timestamp_start / MSEC_to_SEC / 1000.) % 60, timestamp_start % 1000); struct tm starttime_tm = boost::posix_time::to_tm(starttime); @@ -1211,9 +1273,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { struct tm endtime_tm = boost::posix_time::to_tm(endtime); Log( - "MonitorLAPPDData: ReadFromFile: Reading in data for time frame " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" + std::to_string(starttime_tm.tm_hour) + ":" - + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec) + " ... " + std::to_string(endtime_tm.tm_year + 1900) + "/" + std::to_string(endtime_tm.tm_mon + 1) + "/" + std::to_string(endtime_tm.tm_mday) + "-" + std::to_string(endtime_tm.tm_hour) + ":" - + std::to_string(endtime_tm.tm_min) + ":" + std::to_string(endtime_tm.tm_sec), v_message, verbosity); + "MonitorLAPPDData: ReadFromFile: Reading in data for time frame " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" + std::to_string(starttime_tm.tm_hour) + ":" + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec) + " ... " + std::to_string(endtime_tm.tm_year + 1900) + "/" + std::to_string(endtime_tm.tm_mon + 1) + "/" + std::to_string(endtime_tm.tm_mday) + "-" + std::to_string(endtime_tm.tm_hour) + ":" + std::to_string(endtime_tm.tm_min) + ":" + std::to_string(endtime_tm.tm_sec), v_message, verbosity); std::stringstream ss_startdate, ss_enddate; ss_startdate << starttime_tm.tm_year + 1900 << "-" << starttime_tm.tm_mon + 1 << "-" << starttime_tm.tm_mday; @@ -1222,14 +1282,16 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { int number_of_days; if (endtime_tm.tm_mon == starttime_tm.tm_mon) number_of_days = endtime_tm.tm_mday - starttime_tm.tm_mday; - else { + else + { boost::gregorian::date endtime_greg(boost::gregorian::from_simple_string(ss_enddate.str())); boost::gregorian::date starttime_greg(boost::gregorian::from_simple_string(ss_startdate.str())); boost::gregorian::days days_dataframe = endtime_greg - starttime_greg; number_of_days = days_dataframe.days(); } - for (int i_day = 0; i_day <= number_of_days; i_day++) { + for (int i_day = 0; i_day <= number_of_days; i_day++) + { ULong64_t timestamp_i = timestamp_start + i_day * HOUR_to_DAY * MIN_to_HOUR * SEC_to_MIN * MSEC_to_SEC; std::string string_date_i = convertTimeStamp_to_Date(timestamp_i); @@ -1237,17 +1299,20 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { root_filename_i << path_monitoring << "LAPPDData_" << string_date_i << ".root"; bool tree_exists = true; - if (does_file_exist(root_filename_i.str())) { + if (does_file_exist(root_filename_i.str())) + { TFile *f = new TFile(root_filename_i.str().c_str(), "READ"); TTree *t; if (f->GetListOfKeys()->Contains("lappddatamonitor_tree")) - t = (TTree*) f->Get("lappddatamonitor_tree"); - else { + t = (TTree *)f->Get("lappddatamonitor_tree"); + else + { Log("WARNING (MonitorLAPPDData): File " + root_filename_i.str() + " does not contain lappddatamonitor_tree. Omit file.", v_warning, verbosity); tree_exists = false; } - if (tree_exists) { + if (tree_exists) + { Log("MonitorLAPPDData: Tree exists, start reading in data", v_message, verbosity); @@ -1282,25 +1347,28 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { t->SetBranchAddress("rate", &t_rate); t->SetBranchAddress("ped", &t_ped); t->SetBranchAddress("sigma", &t_sigma); - t->SetBranchAddress("run",&t_run); - t->SetBranchAddress("subrun",&t_subrun); - t->SetBranchAddress("partrun",&t_partrun); - t->SetBranchAddress("pps_count", &t_pps_count); - t->SetBranchAddress("frame_count",&t_frame_count); - t->SetBranchAddress("lappd_offset",&t_lappd_offset); + t->SetBranchAddress("run", &t_run); + t->SetBranchAddress("subrun", &t_subrun); + t->SetBranchAddress("partrun", &t_partrun); + t->SetBranchAddress("pps_count", &t_pps_count); + t->SetBranchAddress("frame_count", &t_frame_count); + t->SetBranchAddress("lappd_offset", &t_lappd_offset); nentries_tree = t->GetEntries(); - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration[i_board]; - //Sort timestamps for the case that they are not in order + // Sort timestamps for the case that they are not in order std::vector vector_timestamps; std::map map_timestamp_entry; - for (int i_entry = 0; i_entry < nentries_tree; i_entry++) { + for (int i_entry = 0; i_entry < nentries_tree; i_entry++) + { t->GetEntry(i_entry); - if (t_time->at(i_board) >= timestamp_start && t_end->at(i_board) <= timestamp) { + if (t_time->at(i_board) >= timestamp_start && t_end->at(i_board) <= timestamp) + { vector_timestamps.push_back(t_time->at(i_board)); map_timestamp_entry.emplace(t_time->at(i_board), i_entry); } @@ -1309,19 +1377,22 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { std::sort(vector_timestamps.begin(), vector_timestamps.end()); std::vector vector_sorted_entry; - for (int i_entry = 0; i_entry < (int) vector_timestamps.size(); i_entry++) { + for (int i_entry = 0; i_entry < (int)vector_timestamps.size(); i_entry++) + { vector_sorted_entry.push_back(map_timestamp_entry.at(vector_timestamps.at(i_entry))); } - for (int i_entry = 0; i_entry < (int) vector_sorted_entry.size(); i_entry++) { + for (int i_entry = 0; i_entry < (int)vector_sorted_entry.size(); i_entry++) + { int next_entry = vector_sorted_entry.at(i_entry); t->GetEntry(next_entry); - - //std::cout <<"i_board: "<at(i_board): "<at(i_board)<at(i_board) >= timestamp_start && t_end->at(i_board) <= timestamp && t_end->at(i_board)!= 0) { + + // std::cout <<"i_board: "<at(i_board): "<at(i_board)<at(i_board) >= timestamp_start && t_end->at(i_board) <= timestamp && t_end->at(i_board) != 0) + { data_times_plot.at(board_nr).push_back(t_time->at(i_board)); data_times_end_plot.at(board_nr).push_back(t_end->at(i_board)); pps_rate_plot.at(board_nr).push_back(t_pps_rate->at(i_board)); @@ -1330,24 +1401,25 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { int_charge_plot.at(board_nr).push_back(t_int_charge->at(i_board)); buffer_size_plot.at(board_nr).push_back(t_buffer_size->at(i_board)); - boost::posix_time::ptime boost_tend = *Epoch - + boost::posix_time::time_duration(int(t_end->at(i_board) / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(t_end->at(i_board) / MSEC_to_SEC / SEC_to_MIN) % 60, int(t_end->at(i_board) / MSEC_to_SEC / 1000.) % 60, t_end->at(i_board) % 1000); + boost::posix_time::ptime boost_tend = *Epoch + boost::posix_time::time_duration(int(t_end->at(i_board) / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(t_end->at(i_board) / MSEC_to_SEC / SEC_to_MIN) % 60, int(t_end->at(i_board) / MSEC_to_SEC / 1000.) % 60, t_end->at(i_board) % 1000); struct tm label_timestamp = boost::posix_time::to_tm(boost_tend); -// + // TDatime datime_timestamp(1900 + label_timestamp.tm_year, label_timestamp.tm_mon + 1, label_timestamp.tm_mday, label_timestamp.tm_hour, label_timestamp.tm_min, label_timestamp.tm_sec); - //TDatime datime_timestamp(1995,1,1,1,27,6); - //TDatimes initialised to dates before 1995/1/1 will be screwed up since this is the minimum date for the TDatime class - //std::cout <<"t_end: "<at(i_board)<<", datime: "<at(i_board)<<", datime: "<at(chankey)); sigma_plot.at(chankey).push_back(t_sigma->at(chankey)); - //std::cout <<"chankey "<at(chankey)<at(chankey)<at(chankey)); } - if (i_board == 0){ //No need to have separate run information for different boards + if (i_board == 0) + { // No need to have separate run information for different boards run_plot.push_back(t_run); subrun_plot.push_back(t_subrun); partrun_plot.push_back(t_partrun); @@ -1359,7 +1431,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { } } - //Delete vectors, if we have any + // Delete vectors, if we have any delete t_time; delete t_end; delete t_pps_rate; @@ -1377,20 +1449,20 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) { f->Close(); delete f; gROOT->cd(); - - } else { + } + else + { Log("MonitorLAPPDData: ReadFromFile: File " + root_filename_i.str() + " does not exist. Omit file.", v_warning, verbosity); } - } - //Set the readfromfile time variables to make sure data is not read twice for the same time window + // Set the readfromfile time variables to make sure data is not read twice for the same time window readfromfile_tend = timestamp; readfromfile_timeframe = time_frame; - } -void MonitorLAPPDData::DrawLastFilePlots() { +void MonitorLAPPDData::DrawLastFilePlots() +{ Log("MonitorLAPPDData: DrawLastFilePlots", v_message, verbosity); @@ -1398,18 +1470,18 @@ void MonitorLAPPDData::DrawLastFilePlots() { //------------------DrawLastFilePlots ------------------- //------------------------------------------------------- - //Draw status of PSecData in last data file + // Draw status of PSecData in last data file DrawStatus_PsecData(); - //Draw some histograms about the last file + // Draw some histograms about the last file DrawLastFileHists(); - //Draw time alignment plots + // Draw time alignment plots DrawTimeAlignment(); - } -void MonitorLAPPDData::UpdateMonitorPlotsLAPPD(std::vector timeFrames, std::vector endTimes, std::vector fileLabels, std::vector> plotTypes) { +void MonitorLAPPDData::UpdateMonitorPlotsLAPPD(std::vector timeFrames, std::vector endTimes, std::vector fileLabels, std::vector> plotTypes) +{ Log("MonitorLAPPDData: UpdateMonitorPlotsLAPPD", v_message, verbosity); @@ -1417,27 +1489,30 @@ void MonitorLAPPDData::UpdateMonitorPlotsLAPPD(std::vector timeFrames, s //------------------UpdateMonitorPlots ------------------ //------------------------------------------------------- - //Draw the monitoring plots according to the specifications in the configfiles + // Draw the monitoring plots according to the specifications in the configfiles - for (unsigned int i_time = 0; i_time < timeFrames.size(); i_time++) { + for (unsigned int i_time = 0; i_time < timeFrames.size(); i_time++) + { ULong64_t zero = 0; if (endTimes.at(i_time) == zero) - endTimes.at(i_time) = t_file_end_global; //set 0 for t_file_end since we did not know what that was at the beginning of initialise + endTimes.at(i_time) = t_file_end_global; // set 0 for t_file_end since we did not know what that was at the beginning of initialise - for (unsigned int i_plot = 0; i_plot < plotTypes.at(i_time).size(); i_plot++) { + for (unsigned int i_plot = 0; i_plot < plotTypes.at(i_time).size(); i_plot++) + { if (plotTypes.at(i_time).at(i_plot) == "TimeEvolution") DrawTimeEvolutionLAPPDData(endTimes.at(i_time), timeFrames.at(i_time), fileLabels.at(i_time)); - else { + else + { if (verbosity > 0) std::cout << "ERROR (MonitorLAPPDData): UpdateMonitorPlotsLAPPD: Specified plot type -" << plotTypes.at(i_time).at(i_plot) << "- does not exist! Omit entry." << std::endl; } } } - } -void MonitorLAPPDData::DrawStatus_PsecData() { +void MonitorLAPPDData::DrawStatus_PsecData() +{ Log("MonitorLAPPDData: DrawStatus_PsecData", v_message, verbosity); @@ -1445,53 +1520,61 @@ void MonitorLAPPDData::DrawStatus_PsecData() { //-------------DrawStatus_PsecData ---------------------- //------------------------------------------------------- - //TODO: Add status board for PSEC data status - //TODO: One Status board for each ACDC board + // TODO: Add status board for PSEC data status + // TODO: One Status board for each ACDC board // - // ----Rough sketch----- - // Title: LAPPD PSEC Data - // PPS Rate: - // Frame Rate: - // Buffer size: - // Integrated charge: - // PPS count: - // Data count: - // ----End of rough sketch--- + // ----Rough sketch----- + // Title: LAPPD PSEC Data + // PPS Rate: + // Frame Rate: + // Buffer size: + // Integrated charge: + // PPS count: + // Data count: + // ----End of rough sketch--- // - // Number of rows in canvas: 5 (maximum of 10 rows, so it fits) + // Number of rows in canvas: 5 (maximum of 10 rows, so it fits) - //TODO: Implement checks for bad values and draw them red + // TODO: Implement checks for bad values and draw them red double meanPPSRate = 0.0; double meanFrameRate = 0.0; double meanBufferSize = 0.0; double meanIntegratedCharge = 0.0; - //int totalPPSCount = 0; - //int totalFrameCount = 0; - //int totalRun = 0; + // int totalPPSCount = 0; + // int totalFrameCount = 0; + // int totalRun = 0; bool has_board_minus = false; - for (int i_board=0; i_board < current_pps_rate.size(); i_board++){ - if (board_configuration.at(i_board)==-1) has_board_minus = true; + for (int i_board = 0; i_board < current_pps_rate.size(); i_board++) + { + if (board_configuration.at(i_board) == -1) + has_board_minus = true; } - //Calculate mean values - for (int i_board = 0; i_board < current_pps_rate.size(); i_board++) { + // Calculate mean values + for (int i_board = 0; i_board < current_pps_rate.size(); i_board++) + { int board_nr = board_configuration.at(i_board); int size_vectors = current_pps_rate.size(); - if (has_board_minus) size_vectors -= 1; - if (board_nr != -1) { - meanPPSRate += (current_pps_rate.at(i_board) / (double) (size_vectors)); - meanFrameRate += (current_frame_rate.at(i_board) / (double) (size_vectors)); - meanBufferSize += (current_buffer_size.at(i_board) / (double) (size_vectors)); - meanIntegratedCharge += (current_int_charge.at(i_board) / (double) (size_vectors)); + if (has_board_minus) + size_vectors -= 1; + if (board_nr != -1) + { + meanPPSRate += (current_pps_rate.at(i_board) / (double)(size_vectors)); + meanFrameRate += (current_frame_rate.at(i_board) / (double)(size_vectors)); + meanBufferSize += (current_buffer_size.at(i_board) / (double)(size_vectors)); + meanIntegratedCharge += (current_int_charge.at(i_board) / (double)(size_vectors)); } } - //Calculate integrated values - if (current_run == totalRun){ + // Calculate integrated values + if (current_run == totalRun) + { totalPPSCount += current_pps_count; totalFrameCount += current_frame_count; - } else { - Log("MonitorLAPPDData: New run encountered, resetting PPS and data counters. New run: "+std::to_string(current_run)+", old run: "+std::to_string(totalRun),v_message,verbosity); + } + else + { + Log("MonitorLAPPDData: New run encountered, resetting PPS and data counters. New run: " + std::to_string(current_run) + ", old run: " + std::to_string(totalRun), v_message, verbosity); totalRun = current_run; totalPPSCount = current_pps_count; totalFrameCount = current_frame_count; @@ -1507,11 +1590,11 @@ void MonitorLAPPDData::DrawStatus_PsecData() { ss_text_psec_pps_rate << "Mean PPS Rate: " << meanPPSRate << " (" << current_time.str() << ")"; text_pps_rate->SetText(0.06, 0.8, ss_text_psec_pps_rate.str().c_str()); text_pps_rate->SetTextColor(1); -// if (lappd_sc.temperature_mon < lappd_sc.LIMIT_temperature_low || lappd_sc.temperature_mon > lappd_sc.LIMIT_temperature_high) { -// Log("MonitorLAPPDSC: SEVERE ERROR: Monitored temperature >>>" + std::to_string(lappd_sc.temperature_mon) + "<<< is outside of expected range [" + std::to_string(lappd_sc.LIMIT_temperature_low) + " , " + std::to_string(lappd_sc.LIMIT_temperature_high) + "]!!!", v_error, verbosity); -// text_temp->SetTextColor(kRed); -// temp_humid_check = false; -// } + // if (lappd_sc.temperature_mon < lappd_sc.LIMIT_temperature_low || lappd_sc.temperature_mon > lappd_sc.LIMIT_temperature_high) { + // Log("MonitorLAPPDSC: SEVERE ERROR: Monitored temperature >>>" + std::to_string(lappd_sc.temperature_mon) + "<<< is outside of expected range [" + std::to_string(lappd_sc.LIMIT_temperature_low) + " , " + std::to_string(lappd_sc.LIMIT_temperature_high) + "]!!!", v_error, verbosity); + // text_temp->SetTextColor(kRed); + // temp_humid_check = false; + // } std::stringstream ss_text_psec_frame_rate; ss_text_psec_frame_rate << "Mean Frame Rate: " << meanFrameRate << " (" << current_time.str() << ")"; @@ -1560,7 +1643,7 @@ void MonitorLAPPDData::DrawStatus_PsecData() { text_pps_rate->Draw(); text_frame_rate->Draw(); text_buffer_size->Draw(); -// text_int_charge->Draw(); + // text_int_charge->Draw(); text_pps_count->Draw(); text_frame_count->Draw(); @@ -1569,7 +1652,8 @@ void MonitorLAPPDData::DrawStatus_PsecData() { canvas_status_data->SaveAs(ss_path_psecinfo.str().c_str()); canvas_status_data->Clear(); - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); @@ -1620,20 +1704,19 @@ void MonitorLAPPDData::DrawStatus_PsecData() { text_pps_rate->Draw(); text_frame_rate->Draw(); text_buffer_size->Draw(); -// text_int_charge->Draw(); + // text_int_charge->Draw(); std::stringstream ss_path_boardpsecinfo; ss_path_boardpsecinfo << outpath << "LAPPDData_PSECData_currentBoardNr" << board_nr << "." << img_extension; canvas_status_data->SaveAs(ss_path_boardpsecinfo.str().c_str()); canvas_status_data->Clear(); - } - } -//ToDo: Also implement an overall status board showing whether everything is awesome and if there is something wrong, which board has issues +// ToDo: Also implement an overall status board showing whether everything is awesome and if there is something wrong, which board has issues -void MonitorLAPPDData::DrawLastFileHists() { +void MonitorLAPPDData::DrawLastFileHists() +{ std::vector colorVec; colorVec.push_back(632); colorVec.push_back(416); @@ -1648,12 +1731,12 @@ void MonitorLAPPDData::DrawLastFileHists() { //-------------DrawLastFileHists ------------------------ //------------------------------------------------------- - //TODO: Add histogram that shows the number of active channelkeys for each board + // TODO: Add histogram that shows the number of active channelkeys for each board std::stringstream current_time; - //Draw histograms for each board - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { - + // Draw histograms for each board + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); uint64_t t_fileend = t_file_end.at(i_board); @@ -1685,7 +1768,6 @@ void MonitorLAPPDData::DrawLastFileHists() { ss_path_waveform << outpath << "LAPPDData_Waveform_Board" << board_nr << "_current." << img_extension; canvas_waveform->SaveAs(ss_path_waveform.str().c_str()); - canvas_buffer_channel->Clear(); canvas_buffer_channel->cd(); std::stringstream ss_text_buffer_ch; @@ -1720,59 +1802,63 @@ void MonitorLAPPDData::DrawLastFileHists() { ss_path_waveform_voltages << outpath << "LAPPDWaveform_Voltages_Board" << board_nr << "_current." << img_extension; canvas_waveform_voltages->SaveAs(ss_path_waveform_voltages.str().c_str()); - //std::cout <<"PedestalFits"< isPlotted; - for (size_t i_channel = 0; i_channel < 30; i_channel++) { + for (size_t i_channel = 0; i_channel < 30; i_channel++) + { isPlotted.push_back(false); } - for (int i_event = 0; i_event < 100 /*entries*/; i_event++) { - for (size_t i_channel = 0; i_channel < hist_waveforms_onedim.at(i_event).at(board_nr).size(); i_channel++) { + for (int i_event = 0; i_event < 100 /*entries*/; i_event++) + { + for (size_t i_channel = 0; i_channel < hist_waveforms_onedim.at(i_event).at(board_nr).size(); i_channel++) + { canvas_waveform_onedim->Clear(); canvas_waveform_onedim->cd(); std::stringstream ss_text_waveform_onedim; ss_text_waveform_onedim << "LAPPD waveform board " << board_nr << " channel " << i_channel << " event number " << i_event << " (" << current_time.str() << ")"; hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->SetTitle(ss_text_waveform_onedim.str().c_str()); hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->SetStats(0); - - //Set color (not used right now) - //hist_waveforms_onedim.at(board_nr).at(i_channel)->SetMarkerColor(colorVec.at(i_channel)); - //hist_waveforms_onedim.at(board_nr).at(i_channel)->SetLineColor(colorVec.at(i_channel)); + + // Set color (not used right now) + // hist_waveforms_onedim.at(board_nr).at(i_channel)->SetMarkerColor(colorVec.at(i_channel)); + // hist_waveforms_onedim.at(board_nr).at(i_channel)->SetLineColor(colorVec.at(i_channel)); hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->Draw("HIST"); - - //Only save plot if pulse was seen (or if no pulse was observed) - if ((hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->GetMaximum() > mean_pedestal.at(board_nr).at(i_channel) + 5 * sigma_pedestal.at(board_nr).at(i_channel)) || (/*i_event + 1 == 100*/ /*entries*/ /*&&*/ !isPlotted.at(i_channel))) { - if (hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->GetEntries()>0){ - //std::cout <<"Save canvas for channel "<< i_channel <SaveAs(ss_path_waveform_onedim.str().c_str()); - isPlotted.at(i_channel) = true; - } -// Testing -// std::cout << "i_event " << i_event << " i_channel " << i_channel << std::endl; -// std::cout << "Baseline " << mean_pedestal.at(board_nr).at(i_channel) << std::endl; -// std::cout << "Maximum " << hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->GetMaximum() << std::endl; + // Only save plot if pulse was seen (or if no pulse was observed) + if ((hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->GetMaximum() > mean_pedestal.at(board_nr).at(i_channel) + 5 * sigma_pedestal.at(board_nr).at(i_channel)) || (/*i_event + 1 == 100*/ /*entries*/ /*&&*/ !isPlotted.at(i_channel))) + { + if (hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->GetEntries() > 0) + { + // std::cout <<"Save canvas for channel "<< i_channel <SaveAs(ss_path_waveform_onedim.str().c_str()); + isPlotted.at(i_channel) = true; + } + // Testing + // std::cout << "i_event " << i_event << " i_channel " << i_channel << std::endl; + // std::cout << "Baseline " << mean_pedestal.at(board_nr).at(i_channel) << std::endl; + // std::cout << "Maximum " << hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->GetMaximum() << std::endl; } - //hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->Reset(); + // hist_waveforms_onedim.at(i_event).at(board_nr).at(i_channel)->Reset(); } } - } // end board loop + } // end board loop canvas_pedestal_all->Clear(); canvas_pedestal_all->cd(); canvas_pedestal_all->SetRightMargin(0.15); std::stringstream ss_title_pedestals; - ss_title_pedestals << "Baselines ("<SetTitle(ss_title_pedestals.str().c_str()); - TPad *p = (TPad*) canvas_pedestal_all->cd(); + TPad *p = (TPad *)canvas_pedestal_all->cd(); p->SetGrid(); hist_pedestal_all->Draw("COLZ"); p->Update(); @@ -1784,9 +1870,9 @@ void MonitorLAPPDData::DrawLastFileHists() { canvas_buffer_size_all->cd(); canvas_buffer_size_all->SetRightMargin(0.15); std::stringstream ss_title_buffer; - ss_title_buffer << "Buffer Size ("<SetTitle(ss_title_buffer.str().c_str()); - TPad *prate = (TPad*) canvas_buffer_size_all->cd(); + TPad *prate = (TPad *)canvas_buffer_size_all->cd(); prate->SetGrid(); hist_buffer_size_all->Draw("COLZ"); prate->Update(); @@ -1795,12 +1881,12 @@ void MonitorLAPPDData::DrawLastFileHists() { canvas_buffer_size_all->SaveAs(ss_path_rate.str().c_str()); std::stringstream ss_title_rate_threshold; - ss_title_rate_threshold << "Rate over Threshold - ("<SetTitle(ss_title_rate_threshold.str().c_str()); canvas_rate_threshold_all->Clear(); canvas_rate_threshold_all->cd(); canvas_rate_threshold_all->SetRightMargin(0.15); - TPad *pthre = (TPad*) canvas_rate_threshold_all->cd(); + TPad *pthre = (TPad *)canvas_rate_threshold_all->cd(); pthre->SetGrid(); hist_rate_threshold_all->Draw("COLZ"); pthre->Update(); @@ -1809,22 +1895,22 @@ void MonitorLAPPDData::DrawLastFileHists() { canvas_rate_threshold_all->SaveAs(ss_path_rate_threshold.str().c_str()); std::stringstream ss_title_events_per_channel; - ss_title_events_per_channel << "Events ("<SetTitle(ss_title_events_per_channel.str().c_str()); canvas_events_per_channel->Clear(); canvas_events_per_channel->cd(); canvas_events_per_channel->SetRightMargin(0.15); - TPad *pevents = (TPad*) canvas_events_per_channel->cd(); + TPad *pevents = (TPad *)canvas_events_per_channel->cd(); pevents->SetGrid(); hist_events_per_channel->Draw("COLZ"); pevents->Update(); std::stringstream ss_path_events_channel; ss_path_events_channel << outpath << "LAPPD_Events_Per_Channel_current." << img_extension; canvas_events_per_channel->SaveAs(ss_path_events_channel.str().c_str()); - } -void MonitorLAPPDData::PedestalFits(int board_nr, int i_board) { +void MonitorLAPPDData::PedestalFits(int board_nr, int i_board) +{ uint64_t t_fileend = t_file_end.at(i_board); boost::posix_time::ptime currenttime = *Epoch + boost::posix_time::time_duration(int(t_fileend / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(t_fileend / MSEC_to_SEC / SEC_to_MIN) % 60, int(t_fileend / MSEC_to_SEC) % 60, t_fileend % 1000); struct tm currenttime_tm = boost::posix_time::to_tm(currenttime); @@ -1835,7 +1921,8 @@ void MonitorLAPPDData::PedestalFits(int board_nr, int i_board) { std::vector mean_vec; std::vector sigma_vec; std::vector rate_vec; - for (size_t i_channel = 0; i_channel < hist_pedestal.at(board_nr).size(); i_channel++) { + for (size_t i_channel = 0; i_channel < hist_pedestal.at(board_nr).size(); i_channel++) + { canvas_pedestal->Clear(); canvas_pedestal->cd(); std::stringstream ss_path_pedestal; @@ -1853,7 +1940,7 @@ void MonitorLAPPDData::PedestalFits(int board_nr, int i_board) { TFitResultPtr gaussFitResult = hist_pedestal.at(board_nr).at(i_channel)->Fit("fgaus", "Q"); int gaussFitResultInt = gaussFitResult; - //TODO: Put this in own function and tune parameters + // TODO: Put this in own function and tune parameters hist_pedestal.at(board_nr).at(i_channel)->Draw(); fgaus->Draw("SAME"); @@ -1862,57 +1949,73 @@ void MonitorLAPPDData::PedestalFits(int board_nr, int i_board) { int counter = 0; int counterThreshold = 0; - if (gaussFitResultInt == 0) { + if (gaussFitResultInt == 0) + { bool outOfBounds = ((fgaus->GetParameter(1) < 2000.) || (fgaus->GetParameter(1) > 3200.) || (fgaus->GetParameter(1) > 500.) || (fgaus->GetParameter(1) < 50.)); bool suddenChange = false; - //Look for a sudden change if we do not perform the first fit per board and channel - if (mean_pedestal.size() > i_board) { - if (mean_pedestal.at(board_nr).size() > i_channel) { + // Look for a sudden change if we do not perform the first fit per board and channel + if (mean_pedestal.size() > i_board) + { + if (mean_pedestal.at(board_nr).size() > i_channel) + { suddenChange = (fabs(fgaus->GetParameter(1) - mean_pedestal.at(board_nr).at(i_channel)) > 10 || fabs(fgaus->GetParameter(2) - sigma_pedestal.at(board_nr).at(i_channel)) > 0.2); } } - if (!outOfBounds && !suddenChange) { + if (!outOfBounds && !suddenChange) + { mean_vec.push_back(fgaus->GetParameter(1)); sigma_vec.push_back(fgaus->GetParameter(2)); hist_pedestal_all->SetBinContent(i_channel + 1, i_board + 1, fgaus->GetParameter(1)); - } else { + } + else + { mean_vec.push_back(hist_pedestal.at(board_nr).at(i_channel)->GetMean()); sigma_vec.push_back(hist_pedestal.at(board_nr).at(i_channel)->GetRMS()); hist_pedestal_all->SetBinContent(i_channel + 1, i_board + 1, hist_pedestal.at(board_nr).at(i_channel)->GetMean()); } - } else { + } + else + { mean_vec.push_back(hist_pedestal.at(board_nr).at(i_channel)->GetMean()); sigma_vec.push_back(hist_pedestal.at(board_nr).at(i_channel)->GetRMS()); hist_pedestal_all->SetBinContent(i_channel + 1, i_board + 1, hist_pedestal.at(board_nr).at(i_channel)->GetMean()); } - for (int i_bin = 0; i_bin < hist_pedestal.at(board_nr).at(i_channel)->GetNbinsX(); i_bin++) { - double center = hist_pedestal.at(board_nr).at(i_channel)->GetBinCenter(i_bin+1); - int content = hist_pedestal.at(board_nr).at(i_channel)->GetBinContent(i_bin+1); - //if (center > 0) { - counter += content; + for (int i_bin = 0; i_bin < hist_pedestal.at(board_nr).at(i_channel)->GetNbinsX(); i_bin++) + { + double center = hist_pedestal.at(board_nr).at(i_channel)->GetBinCenter(i_bin + 1); + int content = hist_pedestal.at(board_nr).at(i_channel)->GetBinContent(i_bin + 1); + // if (center > 0) { + counter += content; //} - //TODO: Find better parameter - //int x = 5; - if (center > (mean_vec.at(i_channel) + threshold_pulse * sigma_vec.at(i_channel))) { + // TODO: Find better parameter + // int x = 5; + if (center > (mean_vec.at(i_channel) + threshold_pulse * sigma_vec.at(i_channel))) + { counterThreshold += content; - } else if (center < (mean_vec.at(i_channel) - threshold_pulse * sigma_vec.at(i_channel))){ + } + else if (center < (mean_vec.at(i_channel) - threshold_pulse * sigma_vec.at(i_channel))) + { counterThreshold += content; } } - //int entries = (int) data_beamgate_lastfile.at(board_nr).size(); - //int entries = (int) hist_pedestal.at(board_nr).at(i_channel)->GetNbinsX(); + // int entries = (int) data_beamgate_lastfile.at(board_nr).size(); + // int entries = (int) hist_pedestal.at(board_nr).at(i_channel)->GetNbinsX(); int entries = n_data.at(board_nr); - if (i_channel == 5) counter = 256* entries; //manually set trigger channel to 256 buffer size + if (i_channel == 5) + counter = 256 * entries; // manually set trigger channel to 256 buffer size int bufferSize; - if (entries == 0) { + if (entries == 0) + { bufferSize = 0; - } else { + } + else + { bufferSize = counter / entries; } - //ToDo: Fix this number in config file? + // ToDo: Fix this number in config file? int numberOfSamples = 256; int numberOfEvents = counter / numberOfSamples; hist_buffer_size_all->SetBinContent(i_channel + 1, i_board + 1, bufferSize); @@ -1927,7 +2030,8 @@ void MonitorLAPPDData::PedestalFits(int board_nr, int i_board) { rate_pedestal[board_nr] = rate_vec; } -void MonitorLAPPDData::DrawTimeAlignment() { +void MonitorLAPPDData::DrawTimeAlignment() +{ Log("MonitorLAPPDData: DrawTimeAlignment", v_message, verbosity); @@ -1935,13 +2039,14 @@ void MonitorLAPPDData::DrawTimeAlignment() { //-------------DrawTimeAlignment ------------------------ //------------------------------------------------------- - //TODO: Implement function to fill time alignment histograms - //Probably for different time frames: Last file, last 10 files, last 20 files, ... + // TODO: Implement function to fill time alignment histograms + // Probably for different time frames: Last file, last 10 files, last 20 files, ... - //TODO: Add titles to histograms - //TODO: Write canvas as image to disk + // TODO: Add titles to histograms + // TODO: Write canvas as image to disk - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); uint64_t t_fileend = t_file_end.at(i_board); @@ -1951,62 +2056,74 @@ void MonitorLAPPDData::DrawTimeAlignment() { current_time << currenttime_tm.tm_year + 1900 << "/" << currenttime_tm.tm_mon + 1 << "/" << currenttime_tm.tm_mday << "-" << currenttime_tm.tm_hour << ":" << currenttime_tm.tm_min << ":" << currenttime_tm.tm_sec; //--------Last File----------- - //std::cout << "size before " << hist_align_1file.at(board_nr)->GetEntries() << std::endl; + // std::cout << "size before " << hist_align_1file.at(board_nr)->GetEntries() << std::endl; hist_align_1file.at(board_nr)->Reset(); - //std::cout << "size after " << hist_align_1file.at(board_nr)->GetEntries() << std::endl; + // std::cout << "size after " << hist_align_1file.at(board_nr)->GetEntries() << std::endl; std::stringstream ss_1file; ss_1file << "hist_align_1file_board" << i_board; // hist_align_1file.at(board_nr)->SetName(ss_1file.str().c_str()); // hist_align_1file.at(board_nr)->SetTitle(ss_1file.str().c_str()); - for (int i_align = 0; i_align < (int) data_beamgate_lastfile.at(board_nr).size(); i_align++) { - hist_align_1file.at(board_nr)->Fill(data_beamgate_lastfile.at(board_nr).at(i_align)*3.125); + for (int i_align = 0; i_align < (int)data_beamgate_lastfile.at(board_nr).size(); i_align++) + { + hist_align_1file.at(board_nr)->Fill(data_beamgate_lastfile.at(board_nr).at(i_align) * 3.125); } //-------Last 5 Files--------- hist_align_5files.at(board_nr)->Reset(); - for (int i_align = 0; i_align < (int) data_beamgate_last5files.at(board_nr).size(); i_align++) { - for (int i_data = 0; i_data < (int) data_beamgate_last5files.at(board_nr).at(i_align).size(); i_data++) { - hist_align_5files.at(board_nr)->Fill(data_beamgate_last5files.at(board_nr).at(i_align).at(i_data)*3.125); + for (int i_align = 0; i_align < (int)data_beamgate_last5files.at(board_nr).size(); i_align++) + { + for (int i_data = 0; i_data < (int)data_beamgate_last5files.at(board_nr).at(i_align).size(); i_data++) + { + hist_align_5files.at(board_nr)->Fill(data_beamgate_last5files.at(board_nr).at(i_align).at(i_data) * 3.125); } } //-------Last 10 Files-------- hist_align_10files.at(board_nr)->Reset(); - for (int i_align = 0; i_align < (int) data_beamgate_last10files.at(board_nr).size(); i_align++) { - for (int i_data = 0; i_data < (int) data_beamgate_last10files.at(board_nr).at(i_align).size(); i_data++) { - hist_align_10files.at(board_nr)->Fill(data_beamgate_last10files.at(board_nr).at(i_align).at(i_data)*3.125); - if (verbosity > 4) std::cout <<"MonitorLAPPDData: Filling time alignment of "<<(data_beamgate_last10files.at(board_nr).at(i_align).at(i_data))<Fill(data_beamgate_last10files.at(board_nr).at(i_align).at(i_data) * 3.125); + if (verbosity > 4) + std::cout << "MonitorLAPPDData: Filling time alignment of " << (data_beamgate_last10files.at(board_nr).at(i_align).at(i_data)) << std::endl; } } //------Last 20 Files--------- hist_align_20files.at(board_nr)->Reset(); - for (int i_align = 0; i_align < (int) data_beamgate_last20files.at(board_nr).size(); i_align++) { - for (int i_data = 0; i_data < (int) data_beamgate_last20files.at(board_nr).at(i_align).size(); i_data++) { - hist_align_20files.at(board_nr)->Fill(data_beamgate_last20files.at(board_nr).at(i_align).at(i_data)*3.125); + for (int i_align = 0; i_align < (int)data_beamgate_last20files.at(board_nr).size(); i_align++) + { + for (int i_data = 0; i_data < (int)data_beamgate_last20files.at(board_nr).at(i_align).size(); i_data++) + { + hist_align_20files.at(board_nr)->Fill(data_beamgate_last20files.at(board_nr).at(i_align).at(i_data) * 3.125); } } //------Last 100 Files--------- hist_align_100files.at(board_nr)->Reset(); - for (int i_align = 0; i_align < (int) data_beamgate_last100files.at(board_nr).size(); i_align++) { - for (int i_data = 0; i_data < (int) data_beamgate_last100files.at(board_nr).at(i_align).size(); i_data++) { - hist_align_100files.at(board_nr)->Fill(data_beamgate_last100files.at(board_nr).at(i_align).at(i_data)*3.125); + for (int i_align = 0; i_align < (int)data_beamgate_last100files.at(board_nr).size(); i_align++) + { + for (int i_data = 0; i_data < (int)data_beamgate_last100files.at(board_nr).at(i_align).size(); i_data++) + { + hist_align_100files.at(board_nr)->Fill(data_beamgate_last100files.at(board_nr).at(i_align).at(i_data) * 3.125); } } //------Last 1000 Files--------- hist_align_1000files.at(board_nr)->Reset(); - for (int i_align = 0; i_align < (int) data_beamgate_last1000files.at(board_nr).size(); i_align++) { - for (int i_data = 0; i_data < (int) data_beamgate_last1000files.at(board_nr).at(i_align).size(); i_data++) { - hist_align_1000files.at(board_nr)->Fill(data_beamgate_last1000files.at(board_nr).at(i_align).at(i_data)*3.125); + for (int i_align = 0; i_align < (int)data_beamgate_last1000files.at(board_nr).size(); i_align++) + { + for (int i_data = 0; i_data < (int)data_beamgate_last1000files.at(board_nr).at(i_align).size(); i_data++) + { + hist_align_1000files.at(board_nr)->Fill(data_beamgate_last1000files.at(board_nr).at(i_align).at(i_data) * 3.125); } } - //The drawing happens here + // The drawing happens here canvas_align_1file->Clear(); canvas_align_1file->cd(); std::stringstream ss_text_align1; @@ -2061,23 +2178,23 @@ void MonitorLAPPDData::DrawTimeAlignment() { std::stringstream ss_path_align100; ss_path_align100 << outpath << "LAPPD_Time_Alignment_Hundred_Files_Board" << board_nr << "_current." << img_extension; canvas_align_100files->SaveAs(ss_path_align100.str().c_str()); - + canvas_align_1000files->Clear(); canvas_align_1000files->cd(); std::stringstream ss_text_align1000; ss_text_align1000 << "Alignment Thousand Files Board " << board_nr << " (" << current_time.str() << ")"; hist_align_1000files.at(board_nr)->SetTitle(ss_text_align1000.str().c_str()); - + hist_align_1000files.at(board_nr)->SetStats(0); hist_align_1000files.at(board_nr)->Draw(""); std::stringstream ss_path_align1000; ss_path_align1000 << outpath << "LAPPD_Time_Alignment_Thousand_Files_Board" << board_nr << "_current." << img_extension; canvas_align_1000files->SaveAs(ss_path_align1000.str().c_str()); - } } -void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, double time_frame, std::string file_ending) { +void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, double time_frame, std::string file_ending) +{ Log("MonitorLAPPDData: DrawTimeEvolutionLAPPDData", v_message, verbosity); @@ -2090,7 +2207,8 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl std::stringstream end_time; end_time << endtime_tm.tm_year + 1900 << "/" << endtime_tm.tm_mon + 1 << "/" << endtime_tm.tm_mday << "-" << endtime_tm.tm_hour << ":" << endtime_tm.tm_min << ":" << endtime_tm.tm_sec; - if (verbosity > 2) std::cout <<"MonitorLAPPDData:DrawTimeEvolutionLAPPDData. timestamp_end: "< 2) + std::cout << "MonitorLAPPDData:DrawTimeEvolutionLAPPDData. timestamp_end: " << timestamp_end << ", time_frame; " << time_frame << ", end_time: " << end_time.str() << std::endl; if (int(time_frame * 60 * 60 * 1000) > timestamp_end) time_frame = 0.99 * (timestamp_end / 60 / 60 / 1000.); @@ -2098,26 +2216,32 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl if (timestamp_end != readfromfile_tend || time_frame != readfromfile_timeframe) ReadFromFile(timestamp_end, time_frame); - //looping over all files that are in the time interval, each file will be one data point + // looping over all files that are in the time interval, each file will be one data point std::stringstream ss_timeframe; ss_timeframe << round(time_frame * 100.) / 100.; - //Set 0 rates in case no data was found for a board - for (int i_board=0; i_board < (int) board_configuration.size(); i_board++){ - //std::cout <<"board: "<Set(0); graph_frame_count->Set(0); - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { - //std::cout <<"board: "<Set(0); graph_int_charge.at(board_nr)->Set(0); - if (board_nr != -1){ - for (int i=0; i<30; i++){ + if (board_nr != -1) + { + for (int i = 0; i < 30; i++) + { int chkey = min_board + i; graph_rate.at(chkey)->Set(0); graph_sigma.at(chkey)->Set(0); @@ -2162,51 +2289,54 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl std::cout <<"frame_rate_plot.size(): "<SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), pps_rate_plot.at(board_nr).at(i_file)); graph_frame_rate.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), frame_rate_plot.at(board_nr).at(i_file)); graph_buffer_size.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), buffer_size_plot.at(board_nr).at(i_file)); graph_int_charge.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), int_charge_plot.at(board_nr).at(i_file)); - if (board_nr != -1 && buffer_size_plot.at(board_nr).at(i_file)>0){ - for (int i=0; i<30; i++){ - int chkey = min_board+i; + if (board_nr != -1 && buffer_size_plot.at(board_nr).at(i_file) > 0) + { + for (int i = 0; i < 30; i++) + { + int chkey = min_board + i; graph_rate.at(chkey)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), rate_plot.at(chkey).at(i_file)); graph_ped.at(chkey)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), ped_plot.at(chkey).at(i_file)); graph_sigma.at(chkey)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), sigma_plot.at(chkey).at(i_file)); } } - - //PPS and data count plots - if (i_board == 0){ - if (integrated_run == run_plot.at(i_file)){ + + // PPS and data count plots + if (i_board == 0) + { + if (integrated_run == run_plot.at(i_file)) + { integrated_pps += ppscount_plot.at(i_file); integrated_data += framecount_plot.at(i_file); - } else { + } + else + { integrated_pps = ppscount_plot.at(i_file); integrated_data = framecount_plot.at(i_file); integrated_run = run_plot.at(i_file); } - graph_pps_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(),integrated_pps); - graph_frame_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(),integrated_data); - + graph_pps_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_pps); + graph_frame_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_data); } - - } - // Drawing time evolution plots - //std::cout <<"max_canvas"<cd(); @@ -2221,8 +2351,11 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_count->Draw("apl"); double max_pps_count = 1.; double max_pps_count2 = 1.; - if (ppscount_plot.size()>0) max_pps_count2 = TMath::MaxElement(ppscount_plot.size(), graph_pps_count->GetY());; - if (max_pps_count2 > max_pps_count) max_pps_count = max_pps_count2; + if (ppscount_plot.size() > 0) + max_pps_count2 = TMath::MaxElement(ppscount_plot.size(), graph_pps_count->GetY()); + ; + if (max_pps_count2 > max_pps_count) + max_pps_count = max_pps_count2; graph_pps_count->GetYaxis()->SetRangeUser(0.000, 1.1 * max_pps_count); std::stringstream ss_pps_count_path; ss_pps_count_path << outpath << "LAPPDData_TimeEvolution_PPSEvents_" << file_ending << "." << img_extension; @@ -2242,8 +2375,11 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_frame_count->Draw("apl"); double max_frame_count = 1.; double max_frame_count2 = 1.; - if (framecount_plot.size()>0) max_frame_count2 = TMath::MaxElement(framecount_plot.size(), graph_frame_count->GetY());; - if (max_frame_count2 > max_frame_count) max_frame_count = max_frame_count2; + if (framecount_plot.size() > 0) + max_frame_count2 = TMath::MaxElement(framecount_plot.size(), graph_frame_count->GetY()); + ; + if (max_frame_count2 > max_frame_count) + max_frame_count = max_frame_count2; graph_frame_count->GetYaxis()->SetRangeUser(0.000, 1.1 * max_frame_count); std::stringstream ss_frame_count_path; ss_frame_count_path << outpath << "LAPPDData_TimeEvolution_DataEvents_" << file_ending << "." << img_extension; @@ -2264,17 +2400,19 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_rate.at(board_nr)->Draw("apl"); double max_pps = 1.; double max_pps2 = 1.; - if (pps_rate_plot.at(board_nr).size()>0) max_pps2 = TMath::MaxElement(pps_rate_plot.at(board_nr).size(), graph_pps_rate.at(board_nr)->GetY());; - if (max_pps2 > max_pps) max_pps = max_pps2; - //if (pps_rate_plot.at(board_nr).size() > 0) + if (pps_rate_plot.at(board_nr).size() > 0) + max_pps2 = TMath::MaxElement(pps_rate_plot.at(board_nr).size(), graph_pps_rate.at(board_nr)->GetY()); + ; + if (max_pps2 > max_pps) + max_pps = max_pps2; + // if (pps_rate_plot.at(board_nr).size() > 0) // max_pps = TMath::MaxElement(pps_rate_plot.at(board_nr).size(), graph_pps_rate.at(board_nr)->GetY()); graph_pps_rate.at(board_nr)->GetYaxis()->SetRangeUser(0.000, 1.1 * max_pps); std::stringstream ss_pps_path; ss_pps_path << outpath << "LAPPDData_TimeEvolution_PPSRate_Board" << board_nr << "_" << file_ending << "." << img_extension; canvas_pps_rate->SaveAs(ss_pps_path.str().c_str()); - - //std::cout <<"frame rate"<cd(); @@ -2289,10 +2427,12 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_frame_rate.at(board_nr)->Draw("apl"); double max_frame = 1.; double max_frame2 = 1.; - if (frame_rate_plot.at(board_nr).size() > 0) max_frame2 = TMath::MaxElement(frame_rate_plot.at(board_nr).size(), graph_frame_rate.at(board_nr)->GetY()); - if (max_frame2 > max_frame) max_frame = max_frame2; - //if (frame_rate_plot.at(board_nr).size() > 0 && *std::max_element(frame_rate_plot.at(board_nr).begin(),frame_rate_plot.at(board_nr).end())>0) - //max_frame = TMath::MaxElement(frame_rate_plot.at(board_nr).size(), graph_frame_rate.at(board_nr)->GetY()); + if (frame_rate_plot.at(board_nr).size() > 0) + max_frame2 = TMath::MaxElement(frame_rate_plot.at(board_nr).size(), graph_frame_rate.at(board_nr)->GetY()); + if (max_frame2 > max_frame) + max_frame = max_frame2; + // if (frame_rate_plot.at(board_nr).size() > 0 && *std::max_element(frame_rate_plot.at(board_nr).begin(),frame_rate_plot.at(board_nr).end())>0) + // max_frame = TMath::MaxElement(frame_rate_plot.at(board_nr).size(), graph_frame_rate.at(board_nr)->GetY()); graph_frame_rate.at(board_nr)->GetYaxis()->SetRangeUser(0.000, 1.1 * max_frame); std::stringstream ss_frame_path; ss_frame_path << outpath << "LAPPDData_TimeEvolution_FrameRate_Board" << board_nr << "_" << file_ending << "." << img_extension; @@ -2312,10 +2452,12 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_int_charge.at(board_nr)->Draw("apl"); double max_charge = 1.; double max_charge2 = 1.; - if (int_charge_plot.at(board_nr).size()>0) max_charge2 = TMath::MaxElement(int_charge_plot.at(board_nr).size(), graph_int_charge.at(board_nr)->GetY()); - if (max_charge2 > max_charge) max_charge = max_charge2; -// if (int_charge_plot.at(board_nr).size() > 0) -// max_charge = TMath::MaxElement(int_charge_plot.at(board_nr).size(), graph_int_charge.at(board_nr)->GetY()); + if (int_charge_plot.at(board_nr).size() > 0) + max_charge2 = TMath::MaxElement(int_charge_plot.at(board_nr).size(), graph_int_charge.at(board_nr)->GetY()); + if (max_charge2 > max_charge) + max_charge = max_charge2; + // if (int_charge_plot.at(board_nr).size() > 0) + // max_charge = TMath::MaxElement(int_charge_plot.at(board_nr).size(), graph_int_charge.at(board_nr)->GetY()); graph_int_charge.at(board_nr)->GetYaxis()->SetRangeUser(0.000, 1.1 * max_charge); std::stringstream ss_charge_path; ss_charge_path << outpath << "LAPPDData_TimeEvolution_IntCharge_Board" << board_nr << "_" << file_ending << "." << img_extension; @@ -2335,18 +2477,21 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_buffer_size.at(board_nr)->Draw("apl"); double max_buffer = 1.; double max_buffer2 = 1.; - if (buffer_size_plot.at(board_nr).size()>0) max_buffer2 = TMath::MaxElement(buffer_size_plot.at(board_nr).size(), graph_buffer_size.at(board_nr)->GetY()); - if (max_buffer2 > max_buffer) max_buffer = max_buffer2; - //if (buffer_size_plot.at(board_nr).size() > 0) + if (buffer_size_plot.at(board_nr).size() > 0) + max_buffer2 = TMath::MaxElement(buffer_size_plot.at(board_nr).size(), graph_buffer_size.at(board_nr)->GetY()); + if (max_buffer2 > max_buffer) + max_buffer = max_buffer2; + // if (buffer_size_plot.at(board_nr).size() > 0) // max_buffer = TMath::MaxElement(buffer_size_plot.at(board_nr).size(), graph_buffer_size.at(board_nr)->GetY()); graph_buffer_size.at(board_nr)->GetYaxis()->SetRangeUser(0.000, 1.1 * max_buffer); std::stringstream ss_buffer_path; ss_buffer_path << outpath << "LAPPDData_TimeEvolution_BufferSize_Board" << board_nr << "_" << file_ending << "." << img_extension; canvas_buffer_size->SaveAs(ss_buffer_path.str().c_str()); - //std::cout <<"ped, sigma, ped"<Add(graph_ped.at(chkey)); - leg_ped_lappd->AddEntry(graph_ped.at(chkey),ss_leg.str().c_str(),"l"); + leg_ped_lappd->AddEntry(graph_ped.at(chkey), ss_leg.str().c_str(), "l"); multi_sigma_lappd->Add(graph_sigma.at(chkey)); - leg_sigma_lappd->AddEntry(graph_sigma.at(chkey),ss_leg.str().c_str(),"l"); + leg_sigma_lappd->AddEntry(graph_sigma.at(chkey), ss_leg.str().c_str(), "l"); multi_rate_lappd->Add(graph_rate.at(chkey)); - leg_rate_lappd->AddEntry(graph_rate.at(chkey),ss_leg.str().c_str(),"l"); + leg_rate_lappd->AddEntry(graph_rate.at(chkey), ss_leg.str().c_str(), "l"); } canvas_ped_lappd->cd(); @@ -2402,7 +2551,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl multi_sigma_lappd->GetXaxis()->SetTimeFormat("#splitline{%m/%d}{%H:%M}"); multi_sigma_lappd->GetXaxis()->SetTimeOffset(0.); leg_sigma_lappd->Draw(); - + canvas_rate_lappd->cd(); multi_rate_lappd->Draw("apl"); multi_rate_lappd->SetTitle(ss_rate.str().c_str()); @@ -2417,22 +2566,22 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl ss_ped.str(""); ss_sigma.str(""); ss_rate.str(""); - - ss_ped << outpath << "LAPPDTimeEvolution_Ped_Ch"<SaveAs(ss_ped.str().c_str()); canvas_sigma_lappd->SaveAs(ss_sigma.str().c_str()); canvas_rate_lappd->SaveAs(ss_rate.str().c_str()); - for (int i_gr=0; i_gr < CH_per_CANVAS; i_gr++){ - int i_balance = (i == 29)? 1 : 0; - multi_ped_lappd->RecursiveRemove(graph_ped.at(chkey-CH_per_CANVAS+i_gr+i_balance)); - multi_sigma_lappd->RecursiveRemove(graph_sigma.at(chkey-CH_per_CANVAS+i_gr+i_balance)); - multi_rate_lappd->RecursiveRemove(graph_rate.at(chkey-CH_per_CANVAS+i_gr+i_balance)); + for (int i_gr = 0; i_gr < CH_per_CANVAS; i_gr++) + { + int i_balance = (i == 29) ? 1 : 0; + multi_ped_lappd->RecursiveRemove(graph_ped.at(chkey - CH_per_CANVAS + i_gr + i_balance)); + multi_sigma_lappd->RecursiveRemove(graph_sigma.at(chkey - CH_per_CANVAS + i_gr + i_balance)); + multi_rate_lappd->RecursiveRemove(graph_rate.at(chkey - CH_per_CANVAS + i_gr + i_balance)); } - } leg_ped_lappd->Clear(); leg_sigma_lappd->Clear(); @@ -2441,57 +2590,63 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_ped_lappd->Clear(); canvas_sigma_lappd->Clear(); canvas_rate_lappd->Clear(); + } - } - - if (i != 29){ + if (i != 29) + { ss_leg.str(""); - ss_leg << "ch "<Add(graph_ped.at(chkey)); - if (graph_ped.at(chkey)->GetMaximum()>max_canvas_ped) max_canvas_ped = graph_ped.at(chkey)->GetMaximum(); - if (graph_ped.at(chkey)->GetMinimum()>min_canvas_ped) min_canvas_ped = graph_ped.at(chkey)->GetMaximum(); - leg_ped_lappd->AddEntry(graph_ped.at(chkey),ss_leg.str().c_str(),"l"); + if (graph_ped.at(chkey)->GetMaximum() > max_canvas_ped) + max_canvas_ped = graph_ped.at(chkey)->GetMaximum(); + if (graph_ped.at(chkey)->GetMinimum() > min_canvas_ped) + min_canvas_ped = graph_ped.at(chkey)->GetMaximum(); + leg_ped_lappd->AddEntry(graph_ped.at(chkey), ss_leg.str().c_str(), "l"); multi_sigma_lappd->Add(graph_sigma.at(chkey)); - if (graph_sigma.at(chkey)->GetMaximum()>max_canvas_sigma) max_canvas_sigma = graph_sigma.at(chkey)->GetMaximum(); - if (graph_sigma.at(chkey)->GetMinimum()>min_canvas_sigma) min_canvas_sigma = graph_sigma.at(chkey)->GetMaximum(); - leg_sigma_lappd->AddEntry(graph_sigma.at(chkey),ss_leg.str().c_str(),"l"); + if (graph_sigma.at(chkey)->GetMaximum() > max_canvas_sigma) + max_canvas_sigma = graph_sigma.at(chkey)->GetMaximum(); + if (graph_sigma.at(chkey)->GetMinimum() > min_canvas_sigma) + min_canvas_sigma = graph_sigma.at(chkey)->GetMaximum(); + leg_sigma_lappd->AddEntry(graph_sigma.at(chkey), ss_leg.str().c_str(), "l"); multi_rate_lappd->Add(graph_rate.at(chkey)); - if (graph_rate.at(chkey)->GetMaximum()>max_canvas_rate) max_canvas_rate = graph_rate.at(chkey)->GetMaximum(); - if (graph_rate.at(chkey)->GetMinimum()>min_canvas_rate) min_canvas_rate = graph_rate.at(chkey)->GetMaximum(); - leg_rate_lappd->AddEntry(graph_rate.at(chkey),ss_leg.str().c_str(),"l"); - + if (graph_rate.at(chkey)->GetMaximum() > max_canvas_rate) + max_canvas_rate = graph_rate.at(chkey)->GetMaximum(); + if (graph_rate.at(chkey)->GetMinimum() > min_canvas_rate) + min_canvas_rate = graph_rate.at(chkey)->GetMaximum(); + leg_rate_lappd->AddEntry(graph_rate.at(chkey), ss_leg.str().c_str(), "l"); } - } - } } - //std::cout <<"End of TimeEvolution"< lappdType; - //long entries = (long) lappdType.size(); + // TODO: Add code to handle PPS Frames once they are available in the data file + // TODO: Extract pedestal values from 2D ADC Value histogram and also save values in a vector + // std::vector lappdType; + // long entries = (long) lappdType.size(); - BoostStore *Temp = new BoostStore(false,2); + BoostStore *Temp = new BoostStore(false, 2); Temp->Initialise("LAPPDTemp"); long entries; - Temp->Header->Get("TotalEntries",entries); - if (verbosity > 2) std::cout <<"MonitorLAPPDData: Got Temp entries: "<Header->Get("TotalEntries", entries); + if (verbosity > 2) + std::cout << "MonitorLAPPDData: Got Temp entries: " << entries << std::endl; - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); @@ -2522,17 +2677,20 @@ void MonitorLAPPDData::ProcessLAPPDData() { data_beamgate_lastfile.at(board_nr).clear(); - for (size_t i_channel = 0; i_channel < hist_pedestal.at(board_nr).size(); i_channel++) { - //hist_pedestal.at(board_nr).at(i_channel)->Clear(); + for (size_t i_channel = 0; i_channel < hist_pedestal.at(board_nr).size(); i_channel++) + { + // hist_pedestal.at(board_nr).at(i_channel)->Clear(); hist_pedestal.at(board_nr).at(i_channel)->Reset(); } - //ToDo: entries not equal to events -// long entries; -// LAPPDData->Header->Get("TotalEntries", entries); -// - for (int i_entry = 0; i_entry < 100; i_entry++) { - for (size_t i_channel = 0; i_channel < hist_waveforms_onedim.at(i_entry).at(board_nr).size(); i_channel++) { + // ToDo: entries not equal to events + // long entries; + // LAPPDData->Header->Get("TotalEntries", entries); + // + for (int i_entry = 0; i_entry < 100; i_entry++) + { + for (size_t i_channel = 0; i_channel < hist_waveforms_onedim.at(i_entry).at(board_nr).size(); i_channel++) + { hist_waveforms_onedim.at(i_entry).at(board_nr).at(i_channel)->Reset(); } } @@ -2549,58 +2707,63 @@ void MonitorLAPPDData::ProcessLAPPDData() { current_ped.clear(); current_sigma.clear(); -/* - long entries; - LAPPDData->Header->Get("TotalEntries", entries); -*/ - /*std::vector>>> lappdDATA; - std::vector> lappdPPS; - std::vector> lappdACC; - std::vector> lappdMETA; - - m_data->CStore.Get("LAPPD_PPS",lappdPPS); - m_data->CStore.Get("LAPPD_Data",lappdDATA); - m_data->CStore.Get("LAPPD_ACC",lappdACC); - m_data->CStore.Get("LAPPD_Meta",lappdMETA); - m_data->CStore.Get("LAPPD_Type",lappdType);*/ - - int entry_data=0; - int entry_pps=0; + /* + long entries; + LAPPDData->Header->Get("TotalEntries", entries); + */ + /*std::vector>>> lappdDATA; + std::vector> lappdPPS; + std::vector> lappdACC; + std::vector> lappdMETA; + + m_data->CStore.Get("LAPPD_PPS",lappdPPS); + m_data->CStore.Get("LAPPD_Data",lappdDATA); + m_data->CStore.Get("LAPPD_ACC",lappdACC); + m_data->CStore.Get("LAPPD_Meta",lappdMETA); + m_data->CStore.Get("LAPPD_Type",lappdType);*/ + + int entry_data = 0; + int entry_pps = 0; current_pps_count = 0; current_frame_count = 0; - bool have_pps = false; + bool have_pps = false; - for (int i_entry = 0; i_entry < (int) entries; i_entry++) { - if (verbosity > 1) std::cout <<"MonitorLAPPDData: i_entry: "< 1) + std::cout << "MonitorLAPPDData: i_entry: " << i_entry << "/" << entries << std::endl; - std::map> > RawLAPPDData; + std::map>> RawLAPPDData; std::vector Metadata; std::vector AccInfoFrame; - std::vector pps; + std::vector pps; std::string entry_type; Temp->GetEntry(i_entry); - Temp->Get("Type",entry_type); + Temp->Get("Type", entry_type); - if (entry_type == "Data") Temp->Get("Data",RawLAPPDData); - else if (entry_type == "PPS") Temp->Get("PPS",pps); + if (entry_type == "Data") + Temp->Get("Data", RawLAPPDData); + else if (entry_type == "PPS") + Temp->Get("PPS", pps); - Temp->Get("ACC",AccInfoFrame); - Temp->Get("Meta",Metadata); + Temp->Get("ACC", AccInfoFrame); + Temp->Get("Meta", Metadata); - if (verbosity > 1) std::cout <<"MonitorLAPPDData: entry_type: "< 1) + std::cout << "MonitorLAPPDData: entry_type: " << entry_type << std::endl; - /*LAPPDData->GetEntry(i_entry); - LAPPDData->Get("RawLAPPDData", RawLAPPDData); - LAPPDData->Get("Metadata", Metadata); - LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ + /*LAPPDData->GetEntry(i_entry); +LAPPDData->Get("RawLAPPDData", RawLAPPDData); +LAPPDData->Get("Metadata", Metadata); +LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ /*std::string entry_type = lappdType.at(i_entry); if (entry_type == "PPS"){ pps = lappdPPS.at(entry_pps); AccInfoFrame = lappdACC.at(entry_pps); - entry_pps++; + entry_pps++; current_pps_count++; have_pps=true; } else if (entry_type == "DATA"){ @@ -2611,192 +2774,228 @@ void MonitorLAPPDData::ProcessLAPPDData() { current_frame_count++; }*/ - bool do_continue=false; - if (entry_type == "PPS"){ + bool do_continue = false; + if (entry_type == "PPS") + { - current_pps_count ++; - //std::cout <<"PPS entry!"< bits_pps_63_48(pps_63_48); - std::bitset < 16 > bits_pps_47_32(pps_47_32); - std::bitset < 16 > bits_pps_31_16(pps_31_16); - std::bitset < 16 > bits_pps_15_0(pps_15_0); - //std::cout << "bits_pps_63_48: " << bits_pps_63_48 << std::endl; - //std::cout << "bits_pps_47_32: " << bits_pps_47_32 << std::endl; - //std::cout << "bits_pps_31_16: " << bits_pps_31_16 << std::endl; - //std::cout << "bits_pps_15_0: " << bits_pps_15_0 << std::endl; - unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); - if (verbosity > 2) std::cout << "pps combined: " << pps_63_0 << std::endl; - std::bitset < 64 > bits_pps_63_0(pps_63_0); - //std::cout << "bits_pps_63_0: " << bits_pps_63_0 << std::endl; - last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); + unsigned short pps_47_32 = pps.at(3); + unsigned short pps_31_16 = pps.at(4); + unsigned short pps_15_0 = pps.at(5); + std::bitset<16> bits_pps_63_48(pps_63_48); + std::bitset<16> bits_pps_47_32(pps_47_32); + std::bitset<16> bits_pps_31_16(pps_31_16); + std::bitset<16> bits_pps_15_0(pps_15_0); + // std::cout << "bits_pps_63_48: " << bits_pps_63_48 << std::endl; + // std::cout << "bits_pps_47_32: " << bits_pps_47_32 << std::endl; + // std::cout << "bits_pps_31_16: " << bits_pps_31_16 << std::endl; + // std::cout << "bits_pps_15_0: " << bits_pps_15_0 << std::endl; + unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); + if (verbosity > 2) + std::cout << "pps combined: " << pps_63_0 << std::endl; + std::bitset<64> bits_pps_63_0(pps_63_0); + // std::cout << "bits_pps_63_0: " << bits_pps_63_0 << std::endl; + last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); int vector_idx = -1; std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), 0); - if (it != board_configuration.end()) { - vector_idx = std::distance(board_configuration.begin(), it); - if (verbosity > 2) std::cout << "Found board index " << 0 << " at position " << vector_idx << " inside of the vector" << std::endl; - } else { - Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(0) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); - continue; - } - if (first_entry_pps.at(vector_idx) == true) { - first_pps_timestamps.at(vector_idx) = last_pps_timestamp; - first_entry_pps.at(vector_idx) = false; - } + if (it != board_configuration.end()) + { + vector_idx = std::distance(board_configuration.begin(), it); + if (verbosity > 2) + std::cout << "Found board index " << 0 << " at position " << vector_idx << " inside of the vector" << std::endl; + } + else + { + Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(0) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); + continue; + } + if (first_entry_pps.at(vector_idx) == true) + { + first_pps_timestamps.at(vector_idx) = last_pps_timestamp; + first_entry_pps.at(vector_idx) = false; + } last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); - n_pps.at(vector_idx) ++; + n_pps.at(vector_idx)++; have_pps = true; do_continue = true; - } else if (pps.size() == 32){ + } + else if (pps.size() == 32) + { unsigned short pps_63_48 = pps.at(2); - unsigned short pps_47_32 = pps.at(3); - unsigned short pps_31_16 = pps.at(4); - unsigned short pps_15_0 = pps.at(5); - std::bitset < 16 > bits_pps_63_48(pps_63_48); - std::bitset < 16 > bits_pps_47_32(pps_47_32); - std::bitset < 16 > bits_pps_31_16(pps_31_16); - std::bitset < 16 > bits_pps_15_0(pps_15_0); - //std::cout << "bits_pps_63_48: " << bits_pps_63_48 << std::endl; - //std::cout << "bits_pps_47_32: " << bits_pps_47_32 << std::endl; - //std::cout << "bits_pps_31_16: " << bits_pps_31_16 << std::endl; - //std::cout << "bits_pps_15_0: " << bits_pps_15_0 << std::endl; - unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); - if (verbosity > 2) std::cout << "pps combined: " << pps_63_0 << std::endl; - std::bitset < 64 > bits_pps_63_0(pps_63_0); - //std::cout << "bits_pps_63_0: " << bits_pps_63_0 << std::endl; - last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); + unsigned short pps_47_32 = pps.at(3); + unsigned short pps_31_16 = pps.at(4); + unsigned short pps_15_0 = pps.at(5); + std::bitset<16> bits_pps_63_48(pps_63_48); + std::bitset<16> bits_pps_47_32(pps_47_32); + std::bitset<16> bits_pps_31_16(pps_31_16); + std::bitset<16> bits_pps_15_0(pps_15_0); + // std::cout << "bits_pps_63_48: " << bits_pps_63_48 << std::endl; + // std::cout << "bits_pps_47_32: " << bits_pps_47_32 << std::endl; + // std::cout << "bits_pps_31_16: " << bits_pps_31_16 << std::endl; + // std::cout << "bits_pps_15_0: " << bits_pps_15_0 << std::endl; + unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); + if (verbosity > 2) + std::cout << "pps combined: " << pps_63_0 << std::endl; + std::bitset<64> bits_pps_63_0(pps_63_0); + // std::cout << "bits_pps_63_0: " << bits_pps_63_0 << std::endl; + last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); int vector_idx = -1; - std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), 0); - if (it != board_configuration.end()) { - vector_idx = std::distance(board_configuration.begin(), it); - if (verbosity > 2) std::cout << "Found board index " << 0 << " at position " << vector_idx << " inside of the vector" << std::endl; - } else { - Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(0) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); - continue; - } - if (first_entry_pps.at(vector_idx) == true) { - first_pps_timestamps.at(vector_idx) = last_pps_timestamp; - first_entry_pps.at(vector_idx) = false; - } - last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); - n_pps.at(vector_idx) ++; - + std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), 0); + if (it != board_configuration.end()) + { + vector_idx = std::distance(board_configuration.begin(), it); + if (verbosity > 2) + std::cout << "Found board index " << 0 << " at position " << vector_idx << " inside of the vector" << std::endl; + } + else + { + Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(0) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); + continue; + } + if (first_entry_pps.at(vector_idx) == true) + { + first_pps_timestamps.at(vector_idx) = last_pps_timestamp; + first_entry_pps.at(vector_idx) = false; + } + last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); + n_pps.at(vector_idx)++; + pps_63_48 = pps.at(18); - pps_47_32 = pps.at(19); - pps_31_16 = pps.at(20); - pps_15_0 = pps.at(21); - std::bitset < 16 > Bits_pps_63_48(pps_63_48); - std::bitset < 16 > Bits_pps_47_32(pps_47_32); - std::bitset < 16 > Bits_pps_31_16(pps_31_16); - std::bitset < 16 > Bits_pps_15_0(pps_15_0); + pps_47_32 = pps.at(19); + pps_31_16 = pps.at(20); + pps_15_0 = pps.at(21); + std::bitset<16> Bits_pps_63_48(pps_63_48); + std::bitset<16> Bits_pps_47_32(pps_47_32); + std::bitset<16> Bits_pps_31_16(pps_31_16); + std::bitset<16> Bits_pps_15_0(pps_15_0); pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); - if (verbosity > 2) std::cout << "pps combined: " << pps_63_0 << std::endl; - std::bitset < 64 > Bits_pps_63_0(pps_63_0); - //std::cout << "bits_pps_63_0: " << Bits_pps_63_0 << std::endl; - last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); + if (verbosity > 2) + std::cout << "pps combined: " << pps_63_0 << std::endl; + std::bitset<64> Bits_pps_63_0(pps_63_0); + // std::cout << "bits_pps_63_0: " << Bits_pps_63_0 << std::endl; + last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); it = std::find(board_configuration.begin(), board_configuration.end(), 1); - if (it != board_configuration.end()) { - vector_idx = std::distance(board_configuration.begin(), it); - if (verbosity > 2) std::cout << "Found board index " << 1 << " at position " << vector_idx << " inside of the vector" << std::endl; - } else { - Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(1) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); - continue; - } - if (first_entry_pps.at(vector_idx) == true) { - first_pps_timestamps.at(vector_idx) = last_pps_timestamp; - first_entry_pps.at(vector_idx) = false; - } - last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); - n_pps.at(vector_idx) ++; + if (it != board_configuration.end()) + { + vector_idx = std::distance(board_configuration.begin(), it); + if (verbosity > 2) + std::cout << "Found board index " << 1 << " at position " << vector_idx << " inside of the vector" << std::endl; + } + else + { + Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(1) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); + continue; + } + if (first_entry_pps.at(vector_idx) == true) + { + first_pps_timestamps.at(vector_idx) = last_pps_timestamp; + first_entry_pps.at(vector_idx) = false; + } + last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); + n_pps.at(vector_idx)++; have_pps = true; do_continue = true; - } } - if (do_continue) continue; - + if (do_continue) + continue; - if (verbosity > 2){ + if (verbosity > 2) + { std::cout << "******************************" << std::endl; std::cout << "Entry: " << i_entry << ", loop through LAPPD Raw data" << std::endl; } + // Only look at raw data if there was a PPS entry at some point + // if (!have_pps) continue; - //Only look at raw data if there was a PPS entry at some point - //if (!have_pps) continue; - - //Check if we have a Board Index entry - //The entry after the Board Index will always be the startword of chip 0 (0xCA00, or 51712) - //Create "offset" variable based on position of the Board Index + // Check if we have a Board Index entry + // The entry after the Board Index will always be the startword of chip 0 (0xCA00, or 51712) + // Create "offset" variable based on position of the Board Index unsigned short metadata_0 = Metadata.at(0); unsigned short metadata_1 = Metadata.at(1); - //std::cout <<"metadata_0: "< 3) std::cout << "Metadata Board #: " << board_idx << std::endl; - std::bitset < 16 > bits_metadata(board_idx); - if (verbosity > 3) std::cout << "Metadata Bits: " << bits_metadata << std::endl; - } else { + if (board_idx != -1) + { + if (verbosity > 3) + std::cout << "Metadata Board #: " << board_idx << std::endl; + std::bitset<16> bits_metadata(board_idx); + if (verbosity > 3) + std::cout << "Metadata Bits: " << bits_metadata << std::endl; + } + else + { Log("MonitorLAPPDData: ERROR!!! Found no board index in the data!", v_error, verbosity); } board_index.push_back(board_idx); - - //Look for board index in the board_configuration vector + // Look for board index in the board_configuration vector int vector_idx = -1; std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), board_idx); - if (it != board_configuration.end()) { + if (it != board_configuration.end()) + { vector_idx = std::distance(board_configuration.begin(), it); - if (verbosity > 2) std::cout << "Found board index " << board_idx << " at position " << vector_idx << " inside of the vector" << std::endl; - } else { + if (verbosity > 2) + std::cout << "Found board index " << board_idx << " at position " << vector_idx << " inside of the vector" << std::endl; + } + else + { Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(board_idx) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); continue; } int min_board = board_channel.at(vector_idx); - - if (vector_idx == 0) current_frame_count ++; //Only increase event counter once per event, not once per board - - //Build beamgate timestamp - unsigned short beamgate_63_48 = Metadata.at(7 - offset); //Shift everything by 1 for the test file - unsigned short beamgate_47_32 = Metadata.at(27 - offset); //Shift everything by 1 for the test file - unsigned short beamgate_31_16 = Metadata.at(47 - offset); //Shift everything by 1 for the test file - unsigned short beamgate_15_0 = Metadata.at(67 - offset); //Shift everything by 1 for the test file - std::bitset < 16 > bits_beamgate_63_48(beamgate_63_48); - std::bitset < 16 > bits_beamgate_47_32(beamgate_47_32); - std::bitset < 16 > bits_beamgate_31_16(beamgate_31_16); - std::bitset < 16 > bits_beamgate_15_0(beamgate_15_0); - if (verbosity > 2) std::cout << "bits_beamgate_63_48: " << bits_beamgate_63_48 << std::endl; - if (verbosity > 2) std::cout << "bits_beamgate_47_32: " << bits_beamgate_47_32 << std::endl; - if (verbosity > 2) std::cout << "bits_beamgate_31_16: " << bits_beamgate_31_16 << std::endl; - if (verbosity > 2) std::cout << "bits_beamgate_15_0: " << bits_beamgate_15_0 << std::endl; - unsigned long beamgate_63_0 = (static_cast(beamgate_63_48) << 48) + (static_cast(beamgate_47_32) << 32) + (static_cast(beamgate_31_16) << 16) + (static_cast(beamgate_15_0)); - if (verbosity > 2) std::cout << "beamgate combined: " << beamgate_63_0 << std::endl; - std::bitset < 64 > bits_beamgate_63_0(beamgate_63_0); - if (verbosity > 2) std::cout << "bits_beamgate_63_0: " << bits_beamgate_63_0 << std::endl; + if (vector_idx == 0) + current_frame_count++; // Only increase event counter once per event, not once per board + + // Build beamgate timestamp + unsigned short beamgate_63_48 = Metadata.at(7 - offset); // Shift everything by 1 for the test file + unsigned short beamgate_47_32 = Metadata.at(27 - offset); // Shift everything by 1 for the test file + unsigned short beamgate_31_16 = Metadata.at(47 - offset); // Shift everything by 1 for the test file + unsigned short beamgate_15_0 = Metadata.at(67 - offset); // Shift everything by 1 for the test file + std::bitset<16> bits_beamgate_63_48(beamgate_63_48); + std::bitset<16> bits_beamgate_47_32(beamgate_47_32); + std::bitset<16> bits_beamgate_31_16(beamgate_31_16); + std::bitset<16> bits_beamgate_15_0(beamgate_15_0); + if (verbosity > 2) + std::cout << "bits_beamgate_63_48: " << bits_beamgate_63_48 << std::endl; + if (verbosity > 2) + std::cout << "bits_beamgate_47_32: " << bits_beamgate_47_32 << std::endl; + if (verbosity > 2) + std::cout << "bits_beamgate_31_16: " << bits_beamgate_31_16 << std::endl; + if (verbosity > 2) + std::cout << "bits_beamgate_15_0: " << bits_beamgate_15_0 << std::endl; + unsigned long beamgate_63_0 = (static_cast(beamgate_63_48) << 48) + (static_cast(beamgate_47_32) << 32) + (static_cast(beamgate_31_16) << 16) + (static_cast(beamgate_15_0)); + if (verbosity > 2) + std::cout << "beamgate combined: " << beamgate_63_0 << std::endl; + std::bitset<64> bits_beamgate_63_0(beamgate_63_0); + if (verbosity > 2) + std::cout << "bits_beamgate_63_0: " << bits_beamgate_63_0 << std::endl; std::stringstream str_beamgate_15_0; str_beamgate_15_0 << std::hex << (beamgate_15_0); - std::stringstream str_beamgate_31_16; + std::stringstream str_beamgate_31_16; str_beamgate_31_16 << std::hex << (beamgate_31_16); std::stringstream str_beamgate_47_32; str_beamgate_47_32 << std::hex << (beamgate_47_32); @@ -2805,144 +3004,160 @@ void MonitorLAPPDData::ProcessLAPPDData() { const char *hexstring = str_beamgate_63_48.str().c_str(); unsigned int meta7_1 = (unsigned int)strtol(hexstring, NULL, 16); hexstring = str_beamgate_47_32.str().c_str(); - unsigned int meta27_1 = (unsigned int) strtol(hexstring, NULL, 16); + unsigned int meta27_1 = (unsigned int)strtol(hexstring, NULL, 16); hexstring = str_beamgate_31_16.str().c_str(); - unsigned int meta47_1 = (unsigned int) strtol(hexstring, NULL, 16); + unsigned int meta47_1 = (unsigned int)strtol(hexstring, NULL, 16); hexstring = str_beamgate_15_0.str().c_str(); - unsigned int meta67_1 = (unsigned int) strtol(hexstring, NULL, 16); + unsigned int meta67_1 = (unsigned int)strtol(hexstring, NULL, 16); meta7_1 = meta7_1 << 16; meta47_1 = meta47_1 << 16; unsigned int beamcounter = meta47_1 + meta67_1; - unsigned int beamcounterL = meta7_1 + meta27_1; - - double largetime = (double)beamcounterL*13.1; - double smalltime = ((double)beamcounter/1E9)*3.125; - - if (verbosity > 2) { - std::cout <<"meta7_1: "< 2) + { + std::cout << "meta7_1: " << meta7_1 << std::endl; + std::cout << "meta27_1: " << meta27_1 << std::endl; + std::cout << "meta47_1: " << meta47_1 << std::endl; + std::cout << "meta67_1: " << meta67_1 << std::endl; + std::cout << "beamcounter: " << beamcounter << std::endl; + std::cout << "beamcounterL: " << beamcounterL << std::endl; + std::cout << "largetime: " << largetime << std::endl; + std::cout << "smalltime: " << smalltime << std::endl; + std::cout << "eventtime: " << (largetime + smalltime) << std::endl; + std::cout << "beamgate old: " << ((beamgate_63_0 / 1E9) * 3.125) << std::endl; } - //Build data timestamp - unsigned short timestamp_63_48 = Metadata.at(70 - offset); //Shift everything by 1 for the test file - unsigned short timestamp_47_32 = Metadata.at(50 - offset); //Shift everything by 1 for the test file - unsigned short timestamp_31_16 = Metadata.at(30 - offset); //Shift everything by 1 for the test file - unsigned short timestamp_15_0 = Metadata.at(10 - offset); //Shift everything by 1 for the test file - std::bitset < 16 > bits_timestamp_63_48(timestamp_63_48); - std::bitset < 16 > bits_timestamp_47_32(timestamp_47_32); - std::bitset < 16 > bits_timestamp_31_16(timestamp_31_16); - std::bitset < 16 > bits_timestamp_15_0(timestamp_15_0); - //std::cout << "bits_timestamp_63_48: " << bits_timestamp_63_48 << std::endl; - //std::cout << "bits_timestamp_47_32: " << bits_timestamp_47_32 << std::endl; - //std::cout << "bits_timestamp_31_16: " << bits_timestamp_31_16 << std::endl; - //std::cout << "bits_timestamp_15_0: " << bits_timestamp_15_0 << std::endl; + // Build data timestamp + unsigned short timestamp_63_48 = Metadata.at(70 - offset); // Shift everything by 1 for the test file + unsigned short timestamp_47_32 = Metadata.at(50 - offset); // Shift everything by 1 for the test file + unsigned short timestamp_31_16 = Metadata.at(30 - offset); // Shift everything by 1 for the test file + unsigned short timestamp_15_0 = Metadata.at(10 - offset); // Shift everything by 1 for the test file + std::bitset<16> bits_timestamp_63_48(timestamp_63_48); + std::bitset<16> bits_timestamp_47_32(timestamp_47_32); + std::bitset<16> bits_timestamp_31_16(timestamp_31_16); + std::bitset<16> bits_timestamp_15_0(timestamp_15_0); + // std::cout << "bits_timestamp_63_48: " << bits_timestamp_63_48 << std::endl; + // std::cout << "bits_timestamp_47_32: " << bits_timestamp_47_32 << std::endl; + // std::cout << "bits_timestamp_31_16: " << bits_timestamp_31_16 << std::endl; + // std::cout << "bits_timestamp_15_0: " << bits_timestamp_15_0 << std::endl; unsigned long timestamp_63_0 = (static_cast(timestamp_63_48) << 48) + (static_cast(timestamp_47_32) << 32) + (static_cast(timestamp_31_16) << 16) + (static_cast(timestamp_15_0)); - if (verbosity > 2) std::cout << "timestamp combined: " << timestamp_63_0 << std::endl; - std::bitset < 64 > bits_timestamp_63_0(timestamp_63_0); - //std::cout << "bits_timestamp_63_0: " << bits_timestamp_63_0 << std::endl; + if (verbosity > 2) + std::cout << "timestamp combined: " << timestamp_63_0 << std::endl; + std::bitset<64> bits_timestamp_63_0(timestamp_63_0); + // std::cout << "bits_timestamp_63_0: " << bits_timestamp_63_0 << std::endl; beamgate_timestamp.push_back(beamgate_63_0); data_timestamp.push_back(timestamp_63_0); - //for (int i=0; i 3) std::cout <<"vector_idx: "< 3) + std::cout << "vector_idx: " << vector_idx << ", first_timestamp: " << first_timestamp.at(vector_idx) << ", last_timestamp: " << last_timestamp.at(vector_idx) << std::endl; - //Loop through LAPPD data - if (verbosity > 2) std::cout <<"Loop through LAPPD Data"< 2) + std::cout << "Loop through LAPPD Data" << std::endl; int n_channels = 0; double buffer_size = 0; - n_data.at(vector_idx) ++; - for (std::map>>::iterator it = RawLAPPDData.begin(); it != RawLAPPDData.end(); it++) { - if (verbosity > 4) std::cout <<"Got channel "<first<>>::iterator it = RawLAPPDData.begin(); it != RawLAPPDData.end(); it++) + { + if (verbosity > 4) + std::cout << "Got channel " << it->first << std::endl; n_channels++; std::vector> waveforms = it->second; - for (int i_vec = 0; i_vec < (int) waveforms.size(); i_vec++) { - //std::cout <<"i_vec: "< waveform = *(waveforms.at(i_vec).GetSamples()); hist_buffer_channel.at(board_idx)->Fill(waveform.size(), it->first); hist_buffer.at(board_idx)->Fill(waveform.size()); current_buffer_size.at(vector_idx) += waveform.size(); buffer_size += waveform.size(); n_buffer.at(vector_idx)++; - //std::cout <<"waveform.size(): "<Fill(waveform.at(i_wave),it->first); - //std::cout <<"hist_waveform_channel"<SetBinContent(i_wave+1,(it->first)%30+1,hist_waveform_channel.at(board_idx)->GetBinContent(i_wave+1,(it->first)%30+1)+waveform.at(i_wave)); - //std::cout <<"hist_waveform_voltages"<Fill(waveform.at(i_wave), it->first); + // std::cout <<"hist_waveform_channel"<SetBinContent(i_wave + 1, (it->first) % 30 + 1, hist_waveform_channel.at(board_idx)->GetBinContent(i_wave + 1, (it->first) % 30 + 1) + waveform.at(i_wave)); + // std::cout <<"hist_waveform_voltages"<Fill(i_wave, it->first, waveform.at(i_wave)); - //std::cout <<"hist_waveforms_onedim"<first-min_board<first-min_board)->Fill(i_wave,waveform.at(i_wave)); - //std::cout <<"hist_pedestal"<first-min_board)->Fill(waveform.at(i_wave)); + // std::cout <<"hist_waveforms_onedim"<first-min_board<first - min_board)->Fill(i_wave, waveform.at(i_wave)); + // std::cout <<"hist_pedestal"<first - min_board)->Fill(waveform.at(i_wave)); } } } - if (verbosity > 2) std::cout << "*******************************" << std::endl; + if (verbosity > 2) + std::cout << "*******************************" << std::endl; num_channels.push_back(n_channels); if (n_channels != 0) buffer_size /= n_channels; average_buffer.push_back(buffer_size); - } //end entry loop - + } // end entry loop - //Check whether file time has already been synced + // Check whether file time has already been synced std::time_t current_filetime; - m_data->CStore.Get("CurrentFileTime",current_filetime); + m_data->CStore.Get("CurrentFileTime", current_filetime); boost::posix_time::ptime reference_new = boost::posix_time::from_time_t(current_filetime); boost::posix_time::time_duration reference_stamp_new = boost::posix_time::time_duration(reference_new - *Epoch); - - //Sync reference time every Execute step since it will be reset if the LAPPD is restarted + + // Sync reference time every Execute step since it will be reset if the LAPPD is restarted sync_reference_time = false; - if (!sync_reference_time){ - if (have_pps) { + if (!sync_reference_time) + { + if (have_pps) + { reference_time = reference_stamp_new.total_milliseconds(); reference_time -= last_pps_timestamps.at(0); sync_reference_time = true; } - } else { - if (have_pps){ + } + else + { + if (have_pps) + { ULong64_t reference_time_temp = reference_stamp_new.total_milliseconds(); reference_time_temp -= last_pps_timestamps.at(0); double diff = double(reference_time_temp) - double(reference_time); - if (verbosity > 2) std::cout <<"MonitorLAPPDData: Synced time offset for PPS timestamps: "< 2) + std::cout << "MonitorLAPPDData: Synced time offset for PPS timestamps: " << diff << " milliseconds" << std::endl; } } - t_file_end.clear(); + t_file_end.clear(); std::string rawfilename; - m_data->CStore.Get("CurrentFileName",rawfilename); + m_data->CStore.Get("CurrentFileName", rawfilename); this->GetRunSubPart(rawfilename); bool got_tfile_start = false; - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { int board_nr = board_configuration.at(i_board); ModifyBeamgateData(5, board_nr, data_beamgate_last5files); ModifyBeamgateData(10, board_nr, data_beamgate_last10files); @@ -2954,9 +3169,12 @@ void MonitorLAPPDData::ProcessLAPPDData() { double diff_timestamps = (last_timestamp.at(i_board) - first_timestamp.at(i_board)) * CLOCK_to_SEC; double diff_timestamps_beam = (last_beamgate_timestamp.at(i_board) - first_beamgate_timestamp.at(i_board)) * CLOCK_to_SEC; double diff_timestamps_pps = (last_pps_timestamps.at(i_board) - first_pps_timestamps.at(i_board)) / 1000.; - if (verbosity > 3) std::cout <<"first_pps_timestamp: "< 3) std::cout <<"n_pps: "< 3) std::cout <<"i_board: "< 3) + std::cout << "first_pps_timestamp: " << first_pps_timestamps.at(i_board) << ", last_pps_timestamp: " << last_pps_timestamps.at(i_board) << ", diff: " << diff_timestamps_pps << std::endl; + if (verbosity > 3) + std::cout << "n_pps: " << n_pps.at(i_board) << ", rate: " << (n_pps.at(i_board) / diff_timestamps_pps) << std::endl; + if (verbosity > 3) + std::cout << "i_board: " << i_board << ", first_timestamp: " << first_timestamp.at(i_board) << ", last_timestamp: " << last_timestamp.at(i_board) << ", diff_timestamps: " << diff_timestamps << std::endl; if (diff_timestamps > 0.) current_frame_rate.at(i_board) = n_data.at(i_board) / diff_timestamps_pps; // Need to convert difference of timestamps into seconds or something similar if (diff_timestamps_beam > 0.) @@ -2966,32 +3184,35 @@ void MonitorLAPPDData::ProcessLAPPDData() { if (diff_timestamps_pps > 0.) current_pps_rate.at(i_board) = (n_pps.at(i_board)) / diff_timestamps_pps; - //Convert timestamps to msec - //TODO: Need to add absolute time reference from PPS signal to get milliseconds since 1970/1/1 + // Convert timestamps to msec + // TODO: Need to add absolute time reference from PPS signal to get milliseconds since 1970/1/1 first_timestamp.at(i_board) *= (CLOCK_to_SEC * 1000); last_timestamp.at(i_board) *= (CLOCK_to_SEC * 1000); first_beamgate_timestamp.at(i_board) *= (CLOCK_to_SEC * 1000); last_beamgate_timestamp.at(i_board) *= (CLOCK_to_SEC * 1000); - //Add reference time offset + // Add reference time offset first_timestamp.at(i_board) += reference_time; last_timestamp.at(i_board) += reference_time; first_beamgate_timestamp.at(i_board) += reference_time; last_beamgate_timestamp.at(i_board) += reference_time; - - if (!got_tfile_start && first_timestamp.at(i_board) > 0) { + if (!got_tfile_start && first_timestamp.at(i_board) > 0) + { t_file_start = first_timestamp.at(i_board); - if (board_nr != -1) got_tfile_start = true; + if (board_nr != -1) + got_tfile_start = true; } t_file_end.push_back(last_timestamp.at(i_board)); - PedestalFits(board_nr, i_board); + PedestalFits(board_nr, i_board); int min_board = board_channel.at(i_board); - if (board_nr!=-1){ - for (int i=0; i < 30; i++){ - current_chkey.push_back(min_board+i); + if (board_nr != -1) + { + for (int i = 0; i < 30; i++) + { + current_chkey.push_back(min_board + i); current_ped.push_back(mean_pedestal.at(board_nr).at(i)); current_sigma.push_back(sigma_pedestal.at(board_nr).at(i)); current_rate.push_back(rate_pedestal.at(board_nr).at(i)); @@ -3001,163 +3222,182 @@ void MonitorLAPPDData::ProcessLAPPDData() { Temp->Close(); delete Temp; - } -void MonitorLAPPDData::ModifyBeamgateData(size_t numberOfFiles, int boardNumber, std::map>> &dataVector) { - if (dataVector.at(boardNumber).size()) { - if (dataVector.at(boardNumber).size() == numberOfFiles) { - for (size_t i_file = 0; i_file < dataVector.at(boardNumber).size() - 1; i_file++) { +void MonitorLAPPDData::ModifyBeamgateData(size_t numberOfFiles, int boardNumber, std::map>> &dataVector) +{ + if (dataVector.at(boardNumber).size()) + { + if (dataVector.at(boardNumber).size() == numberOfFiles) + { + for (size_t i_file = 0; i_file < dataVector.at(boardNumber).size() - 1; i_file++) + { dataVector.at(boardNumber).at(i_file) = dataVector.at(boardNumber).at(i_file + 1); } dataVector.at(boardNumber).at(numberOfFiles - 1) = data_beamgate_lastfile.at(boardNumber); - } else { + } + else + { dataVector.at(boardNumber).push_back(data_beamgate_lastfile.at(boardNumber)); } - } else { - if (data_beamgate_lastfile.at(boardNumber).size()) { + } + else + { + if (data_beamgate_lastfile.at(boardNumber).size()) + { dataVector.at(boardNumber).push_back(data_beamgate_lastfile.at(boardNumber)); } } } -void MonitorLAPPDData::DrawFileHistoryLAPPD(ULong64_t timestamp_end, double time_frame, std::string file_ending, int _linewidth){ - - Log("MonitorLAPPDData: DrawFileHistoryLAPPD",v_message,verbosity); +void MonitorLAPPDData::DrawFileHistoryLAPPD(ULong64_t timestamp_end, double time_frame, std::string file_ending, int _linewidth) +{ + Log("MonitorLAPPDData: DrawFileHistoryLAPPD", v_message, verbosity); - //------------------------------------------------------------ - //------------------DrawFileHistoryLAPPD --------------------- - //------------------------------------------------------------ + //------------------------------------------------------------ + //------------------DrawFileHistoryLAPPD --------------------- + //------------------------------------------------------------ - //Creates a plot showing the time stamps for all the files within the last time_frame mins - //The plot is updated with the update_frequency specified in the configuration file (default: 5 mins) + // Creates a plot showing the time stamps for all the files within the last time_frame mins + // The plot is updated with the update_frequency specified in the configuration file (default: 5 mins) - if (timestamp_end != readfromfile_tend || time_frame != readfromfile_timeframe) ReadFromFile(timestamp_end, time_frame); + if (timestamp_end != readfromfile_tend || time_frame != readfromfile_timeframe) + ReadFromFile(timestamp_end, time_frame); - timestamp_end += utc_to_t; + timestamp_end += utc_to_t; - ULong64_t timestamp_start = timestamp_end - time_frame*MSEC_to_SEC*SEC_to_MIN*MIN_to_HOUR; - std::stringstream ss_timeframe; - ss_timeframe << round(time_frame*100.)/100.; + ULong64_t timestamp_start = timestamp_end - time_frame * MSEC_to_SEC * SEC_to_MIN * MIN_to_HOUR; + std::stringstream ss_timeframe; + ss_timeframe << round(time_frame * 100.) / 100.; - canvas_logfile_lappd->cd(); - log_files_lappd->SetBins(num_history_lappd,timestamp_start/MSEC_to_SEC,timestamp_end/MSEC_to_SEC); - log_files_lappd->GetXaxis()->SetTimeOffset(0.); - log_files_lappd->Draw(); + canvas_logfile_lappd->cd(); + log_files_lappd->SetBins(num_history_lappd, timestamp_start / MSEC_to_SEC, timestamp_end / MSEC_to_SEC); + log_files_lappd->GetXaxis()->SetTimeOffset(0.); + log_files_lappd->Draw(); - std::stringstream ss_title_filehistory; - ss_title_filehistory << "LAPPD Files History (last "<SetTitle(ss_title_filehistory.str().c_str()); + std::stringstream ss_title_filehistory; + ss_title_filehistory << "LAPPD Files History (last " << ss_timeframe.str() << "h)"; - std::vector file_markers; - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { - int board_nr = board_configuration.at(i_board); - std::vector tend_plot = data_times_end_plot.at(board_nr); - for (unsigned int i_file = 0; i_file < tend_plot.size(); i_file++){ - TLine *line_file = new TLine((tend_plot.at(i_file)+utc_to_t)/MSEC_to_SEC,0.,(tend_plot.at(i_file)+utc_to_t)/MSEC_to_SEC,1.); - line_file->SetLineColor(1); - line_file->SetLineStyle(1); - line_file->SetLineWidth(_linewidth); - line_file->Draw("same"); - file_markers.push_back(line_file); - } - } + log_files_lappd->SetTitle(ss_title_filehistory.str().c_str()); - std::stringstream ss_logfiles; - ss_logfiles << outpath << "LAPPD_FileHistory_" << file_ending << "." << img_extension; - canvas_logfile_lappd->SaveAs(ss_logfiles.str().c_str()); + std::vector file_markers; + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { + int board_nr = board_configuration.at(i_board); + std::vector tend_plot = data_times_end_plot.at(board_nr); + for (unsigned int i_file = 0; i_file < tend_plot.size(); i_file++) + { + TLine *line_file = new TLine((tend_plot.at(i_file) + utc_to_t) / MSEC_to_SEC, 0., (tend_plot.at(i_file) + utc_to_t) / MSEC_to_SEC, 1.); + line_file->SetLineColor(1); + line_file->SetLineStyle(1); + line_file->SetLineWidth(_linewidth); + line_file->Draw("same"); + file_markers.push_back(line_file); + } + } - for (unsigned int i_line = 0; i_line < file_markers.size(); i_line++){ - delete file_markers.at(i_line); - } + std::stringstream ss_logfiles; + ss_logfiles << outpath << "LAPPD_FileHistory_" << file_ending << "." << img_extension; + canvas_logfile_lappd->SaveAs(ss_logfiles.str().c_str()); - log_files_lappd->Reset(); - canvas_logfile_lappd->Clear(); + for (unsigned int i_line = 0; i_line < file_markers.size(); i_line++) + { + delete file_markers.at(i_line); + } + log_files_lappd->Reset(); + canvas_logfile_lappd->Clear(); } -void MonitorLAPPDData::PrintFileTimeStampLAPPD(ULong64_t timestamp_end, double time_frame, std::string file_ending){ - - if (verbosity > 2) std::cout <<"MonitorLAPPDData: PrintFileTimeStampLAPPD"<SetNDC(1); - label_lastfile->SetTextSize(0.05); - - //TLatex *label_timediff = nullptr; - - std::vector vec_label_timediff; - - for (int i_board = 0; i_board < (int) board_configuration.size(); i_board++) { - int board_nr = board_configuration.at(i_board); - std::vector tend_plot = data_times_end_plot.at(board_nr); - if (tend_plot.size() == 0){ - std::stringstream time_diff; - time_diff << "#Delta t Last LAPPD File (Board "<"<SetNDC(1); - label_timediff->SetTextSize(0.05); - vec_label_timediff.push_back(label_timediff); - } else { - ULong64_t timestamp_lastfile = tend_plot.at(tend_plot.size()-1); - boost::posix_time::ptime filetime = *Epoch + boost::posix_time::time_duration(int(timestamp_lastfile/MSEC_to_SEC/SEC_to_MIN/MIN_to_HOUR),int(timestamp_lastfile/MSEC_to_SEC/SEC_to_MIN)%60,int(timestamp_lastfile/MSEC_to_SEC/1000.)%60,timestamp_lastfile%1000); - boost::posix_time::time_duration t_since_file= boost::posix_time::time_duration(endtime - filetime); - int t_since_file_min = int(t_since_file.total_milliseconds()/MSEC_to_SEC/SEC_to_MIN); - std::stringstream time_diff; - time_diff << "#Delta t Last LAPPD File (Board "<SetNDC(1); - label_timediff->SetTextSize(0.05); - vec_label_timediff.push_back(label_timediff); - } - } - - canvas_file_timestamp_lappd->cd(); - label_lastfile->Draw(); - for (int i_vec=0; i_vec < (int) vec_label_timediff.size(); i_vec++){ - vec_label_timediff.at(i_vec)->Draw(); - } - std::stringstream ss_file_timestamp; - ss_file_timestamp << outpath << "LAPPD_FileTimeStamp_" << file_ending << "." << img_extension; - canvas_file_timestamp_lappd->SaveAs(ss_file_timestamp.str().c_str()); - - delete label_lastfile; - for (int i_vec=0; i_vec < (int) vec_label_timediff.size(); i_vec++){ - delete vec_label_timediff.at(i_vec); - } - - canvas_file_timestamp_lappd->Clear(); +void MonitorLAPPDData::PrintFileTimeStampLAPPD(ULong64_t timestamp_end, double time_frame, std::string file_ending) +{ + + if (verbosity > 2) + std::cout << "MonitorLAPPDData: PrintFileTimeStampLAPPD" << std::endl; + + //------------------------------------------------------------ + //-----------------PrintFileTimeStampLAPPD-------------------- + //------------------------------------------------------------ + + if (timestamp_end != readfromfile_tend || time_frame != readfromfile_timeframe) + ReadFromFile(timestamp_end, time_frame); + + boost::posix_time::ptime endtime = *Epoch + boost::posix_time::time_duration(int(timestamp_end / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(timestamp_end / MSEC_to_SEC / SEC_to_MIN) % 60, int(timestamp_end / MSEC_to_SEC / 1000.) % 60, timestamp_end % 1000); + struct tm endtime_tm = boost::posix_time::to_tm(endtime); + std::stringstream end_time; + end_time << "Current time: " << endtime_tm.tm_year + 1900 << "/" << endtime_tm.tm_mon + 1 << "/" << endtime_tm.tm_mday << "-" << endtime_tm.tm_hour << ":" << endtime_tm.tm_min << ":" << endtime_tm.tm_sec; + + TText *label_lastfile = nullptr; + label_lastfile = new TText(0.04, 0.9, end_time.str().c_str()); + label_lastfile->SetNDC(1); + label_lastfile->SetTextSize(0.05); + + // TLatex *label_timediff = nullptr; + + std::vector vec_label_timediff; + for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) + { + int board_nr = board_configuration.at(i_board); + std::vector tend_plot = data_times_end_plot.at(board_nr); + if (tend_plot.size() == 0) + { + std::stringstream time_diff; + time_diff << "#Delta t Last LAPPD File (Board " << board_nr << "): >" << time_frame << "h"; + TLatex *label_timediff = new TLatex(0.04, 0.7 - 0.2 * (i_board), time_diff.str().c_str()); + label_timediff->SetNDC(1); + label_timediff->SetTextSize(0.05); + vec_label_timediff.push_back(label_timediff); + } + else + { + ULong64_t timestamp_lastfile = tend_plot.at(tend_plot.size() - 1); + boost::posix_time::ptime filetime = *Epoch + boost::posix_time::time_duration(int(timestamp_lastfile / MSEC_to_SEC / SEC_to_MIN / MIN_to_HOUR), int(timestamp_lastfile / MSEC_to_SEC / SEC_to_MIN) % 60, int(timestamp_lastfile / MSEC_to_SEC / 1000.) % 60, timestamp_lastfile % 1000); + boost::posix_time::time_duration t_since_file = boost::posix_time::time_duration(endtime - filetime); + int t_since_file_min = int(t_since_file.total_milliseconds() / MSEC_to_SEC / SEC_to_MIN); + std::stringstream time_diff; + time_diff << "#Delta t Last LAPPD File (Board " << board_nr << "): " << t_since_file_min / 60 << "h:" << t_since_file_min % 60 << "min"; + TLatex *label_timediff = new TLatex(0.04, 0.7 - 0.2 * (i_board), time_diff.str().c_str()); + label_timediff->SetNDC(1); + label_timediff->SetTextSize(0.05); + vec_label_timediff.push_back(label_timediff); + } + } + + canvas_file_timestamp_lappd->cd(); + label_lastfile->Draw(); + for (int i_vec = 0; i_vec < (int)vec_label_timediff.size(); i_vec++) + { + vec_label_timediff.at(i_vec)->Draw(); + } + std::stringstream ss_file_timestamp; + ss_file_timestamp << outpath << "LAPPD_FileTimeStamp_" << file_ending << "." << img_extension; + canvas_file_timestamp_lappd->SaveAs(ss_file_timestamp.str().c_str()); + + delete label_lastfile; + for (int i_vec = 0; i_vec < (int)vec_label_timediff.size(); i_vec++) + { + delete vec_label_timediff.at(i_vec); + } + + canvas_file_timestamp_lappd->Clear(); } -void MonitorLAPPDData::GetRunSubPart(std::string filename){ +void MonitorLAPPDData::GetRunSubPart(std::string filename) +{ - std::cout <<"filename: "< Date: Thu, 29 Aug 2024 14:57:42 +0000 Subject: [PATCH 02/34] combine pps timestamp parsing logic in MonitoringLAPPDData tool --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 61 ++++--------------- 1 file changed, 11 insertions(+), 50 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index e163814cc..09c63345c 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2779,12 +2779,11 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ { current_pps_count++; - // std::cout <<"PPS entry!"<Get("AccInfoFrame", AccInfoFrame);*/ std::bitset<16> bits_pps_47_32(pps_47_32); std::bitset<16> bits_pps_31_16(pps_31_16); std::bitset<16> bits_pps_15_0(pps_15_0); - // std::cout << "bits_pps_63_48: " << bits_pps_63_48 << std::endl; - // std::cout << "bits_pps_47_32: " << bits_pps_47_32 << std::endl; - // std::cout << "bits_pps_31_16: " << bits_pps_31_16 << std::endl; - // std::cout << "bits_pps_15_0: " << bits_pps_15_0 << std::endl; + + // Combine all the bits to create PPS timestamp unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); if (verbosity > 2) std::cout << "pps combined: " << pps_63_0 << std::endl; std::bitset<64> bits_pps_63_0(pps_63_0); - // std::cout << "bits_pps_63_0: " << bits_pps_63_0 << std::endl; last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); + int vector_idx = -1; std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), 0); if (it != board_configuration.end()) @@ -2823,51 +2820,15 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ } last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); n_pps.at(vector_idx)++; + } + + if (pps.size() == 16) + { have_pps = true; do_continue = true; } else if (pps.size() == 32) { - unsigned short pps_63_48 = pps.at(2); - unsigned short pps_47_32 = pps.at(3); - unsigned short pps_31_16 = pps.at(4); - unsigned short pps_15_0 = pps.at(5); - std::bitset<16> bits_pps_63_48(pps_63_48); - std::bitset<16> bits_pps_47_32(pps_47_32); - std::bitset<16> bits_pps_31_16(pps_31_16); - std::bitset<16> bits_pps_15_0(pps_15_0); - // std::cout << "bits_pps_63_48: " << bits_pps_63_48 << std::endl; - // std::cout << "bits_pps_47_32: " << bits_pps_47_32 << std::endl; - // std::cout << "bits_pps_31_16: " << bits_pps_31_16 << std::endl; - // std::cout << "bits_pps_15_0: " << bits_pps_15_0 << std::endl; - unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); - if (verbosity > 2) - std::cout << "pps combined: " << pps_63_0 << std::endl; - std::bitset<64> bits_pps_63_0(pps_63_0); - // std::cout << "bits_pps_63_0: " << bits_pps_63_0 << std::endl; - last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); - - int vector_idx = -1; - std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), 0); - if (it != board_configuration.end()) - { - vector_idx = std::distance(board_configuration.begin(), it); - if (verbosity > 2) - std::cout << "Found board index " << 0 << " at position " << vector_idx << " inside of the vector" << std::endl; - } - else - { - Log("MonitorLAPPDData: ERROR!!! Board index " + std::to_string(0) + " was not found as one of the configured board index options!!! Abort LAPPD data entry", v_error, verbosity); - continue; - } - if (first_entry_pps.at(vector_idx) == true) - { - first_pps_timestamps.at(vector_idx) = last_pps_timestamp; - first_entry_pps.at(vector_idx) = false; - } - last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); - n_pps.at(vector_idx)++; - pps_63_48 = pps.at(18); pps_47_32 = pps.at(19); pps_31_16 = pps.at(20); From df01b3476c8b7fbf17434caeb1a0179e33c3e7bf Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Thu, 29 Aug 2024 17:07:12 +0000 Subject: [PATCH 03/34] Parse PPS event counter data --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 37 +++++++++++++------ UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 2 + 2 files changed, 28 insertions(+), 11 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 09c63345c..91a0d0e01 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -947,6 +947,8 @@ void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) last_timestamp.push_back(0); first_pps_timestamps.push_back(0); last_pps_timestamps.push_back(0); + current_pps_event_counters.push_back(0); + current_board_index.push_back(board_number); first_entry.push_back(true); first_entry_pps.push_back(true); @@ -2777,7 +2779,8 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ bool do_continue = false; if (entry_type == "PPS") { - + std::vector::iterator it; + int vector_idx = -1; current_pps_count++; // Parse PPS data according to Data Frame (PPS) metadata @@ -2800,8 +2803,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ std::bitset<64> bits_pps_63_0(pps_63_0); last_pps_timestamp = pps_63_0 * (CLOCK_to_SEC * 1000); - int vector_idx = -1; - std::vector::iterator it = std::find(board_configuration.begin(), board_configuration.end(), 0); + it = std::find(board_configuration.begin(), board_configuration.end(), 0); if (it != board_configuration.end()) { vector_idx = std::distance(board_configuration.begin(), it); @@ -2818,10 +2820,23 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ first_pps_timestamps.at(vector_idx) = last_pps_timestamp; first_entry_pps.at(vector_idx) = false; } - last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); + last_pps_timestamps.at(vector_idx) = last_pps_timestamp; n_pps.at(vector_idx)++; + + // Parse PPS count + unsigned short pps_count_31_16 = pps.at(8); + unsigned short pps_count_15_0 = pps.at(9); + std::bitset<16> bits_pps_count_31_16(pps_count_31_16); + std::bitset<16> bits_pps_count_15_0(pps_count_15_0); + + // Combine all the bits to create PPS count + unsigned int pps_count_31_0 = (static_cast(pps_count_31_16) << 16) + (static_cast(pps_count_15_0)); + std::bitset<32> bits_pps_count_31_0(pps_count_31_0); + last_pps_count = pps_count_31_0; + + current_pps_event_counters.at(vector_idx) = last_pps_count; } - + if (pps.size() == 16) { have_pps = true; @@ -2829,15 +2844,15 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ } else if (pps.size() == 32) { - pps_63_48 = pps.at(18); - pps_47_32 = pps.at(19); - pps_31_16 = pps.at(20); - pps_15_0 = pps.at(21); + unsigned short pps_63_48 = pps.at(18); + unsigned short pps_47_32 = pps.at(19); + unsigned short pps_31_16 = pps.at(20); + unsigned short pps_15_0 = pps.at(21); std::bitset<16> Bits_pps_63_48(pps_63_48); std::bitset<16> Bits_pps_47_32(pps_47_32); std::bitset<16> Bits_pps_31_16(pps_31_16); std::bitset<16> Bits_pps_15_0(pps_15_0); - pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); + unsigned short pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); if (verbosity > 2) std::cout << "pps combined: " << pps_63_0 << std::endl; std::bitset<64> Bits_pps_63_0(pps_63_0); @@ -2863,7 +2878,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ } last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); n_pps.at(vector_idx)++; - + have_pps = true; do_continue = true; } diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index e39a040c8..620248c55 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -139,6 +139,7 @@ class MonitorLAPPDData: public Tool { double CLOCK_to_SEC = 3.125e-9; //320MHz clock -> 1/320MHz = 3.125ns ULong64_t reference_time; ULong64_t last_pps_timestamp; + int last_pps_count; //Geometry variables Geometry *geom = nullptr; @@ -163,6 +164,7 @@ class MonitorLAPPDData: public Tool { std::vector last_timestamp; std::vector first_pps_timestamps; std::vector last_pps_timestamps; + std::vector current_pps_event_counters; std::vector first_entry; std::vector first_entry_pps; std::vector n_buffer; From 624e43abb727b28f92ddd53c0d5a4d932f9d5811 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Fri, 30 Aug 2024 20:25:09 +0000 Subject: [PATCH 04/34] WIP: Working on PPS event counter plotting --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 50 ++++++++++++++++++- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 3 ++ 2 files changed, 52 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 91a0d0e01..95cbd9ad3 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -259,6 +259,7 @@ bool MonitorLAPPDData::Finalise() delete canvas_rate_lappd; delete canvas_frame_count; delete canvas_pps_count; + delete canvas_pps_event_counter; // histograms // @@ -362,6 +363,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() canvas_rate_lappd = new TCanvas("canvas_rate_lappd", "LAPPD Rates", 900, 600); canvas_frame_count = new TCanvas("canvas_frame_count", "LAPPD Data Count", 900, 600); canvas_pps_count = new TCanvas("canvas_pps_count", "LAPPD PPS Count", 900, 600); + canvas_pps_event_counter = new TCanvas("canvas_pps_event_counter", "LAPPD PPS Event Counter", 900, 600); // Histograms // ToDo: Not hardcode the number of channels here @@ -746,12 +748,15 @@ void MonitorLAPPDData::InitializeHistsLAPPD() // Normal Graphs without board number graph_pps_count = new TGraph(); + graph_pps_event_counter = new TGraph(); graph_frame_count = new TGraph(); graph_pps_count->SetName("graph_pps_count"); + graph_pps_event_counter->SetName("graph_pps_event_counter"); graph_frame_count->SetName("graph_frame_count"); graph_pps_count->SetTitle("LAPPD PPS Events Time Evolution"); + graph_pps_event_counter->SetTitle("LAPPD PPS Event Counter Time Evolution"); graph_frame_count->SetTitle("LAPPD Data Events Time Evolution"); if (draw_marker) @@ -761,30 +766,39 @@ void MonitorLAPPDData::InitializeHistsLAPPD() } graph_pps_count->SetMarkerColor(kBlack); + graph_pps_event_counter->SetMarkerColor(kBlack); graph_frame_count->SetMarkerColor(kBlack); graph_pps_count->SetLineColor(kBlack); + graph_pps_event_counter->SetLineColor(kBlack); graph_frame_count->SetLineColor(kBlack); graph_pps_count->SetLineWidth(2); + graph_pps_event_counter->SetLineWidth(2); graph_frame_count->SetLineWidth(2); graph_pps_count->SetFillColor(0); + graph_pps_event_counter->SetFillColor(0); graph_frame_count->SetFillColor(0); graph_pps_count->GetYaxis()->SetTitle("PPS Events"); + graph_pps_event_counter->GetYaxis()->SetTitle("PPS Event Counter"); graph_frame_count->GetYaxis()->SetTitle("Data Events"); graph_pps_count->GetXaxis()->SetTimeDisplay(1); + graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); graph_frame_count->GetXaxis()->SetTimeDisplay(1); graph_pps_count->GetXaxis()->SetLabelSize(0.03); + graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); graph_frame_count->GetXaxis()->SetLabelSize(0.03); graph_pps_count->GetXaxis()->SetLabelOffset(0.03); + graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); graph_frame_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); + graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_frame_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); // Multi-Graphs @@ -962,6 +976,7 @@ void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) data_times_plot.emplace(board_number, empty_unsigned_long); data_times_end_plot.emplace(board_number, empty_unsigned_long); pps_rate_plot.emplace(board_number, empty_double); + pps_event_counter_plot.emplace(board_number, empty_double); frame_rate_plot.emplace(board_number, empty_double); beamgate_rate_plot.emplace(board_number, empty_double); int_charge_plot.emplace(board_number, empty_double); @@ -1046,6 +1061,7 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_time = new std::vector; std::vector *t_end = new std::vector; std::vector *t_pps_rate = new std::vector; + std::vector *t_pps_event_counter = new std::vector; std::vector *t_frame_rate = new std::vector; std::vector *t_beamgate_rate = new std::vector; std::vector *t_int_charge = new std::vector; @@ -1067,6 +1083,7 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("t_start", &t_time); t->SetBranchAddress("t_end", &t_end); t->SetBranchAddress("pps_rate", &t_pps_rate); + t->SetBranchAddress("pps_event_counter", &t_pps_event_counter); t->SetBranchAddress("frame_rate", &t_frame_rate); t->SetBranchAddress("beamgate_rate", &t_beamgate_rate); t->SetBranchAddress("int_charge", &t_int_charge); @@ -1090,6 +1107,7 @@ void MonitorLAPPDData::WriteToFile() t->Branch("t_start", &t_time); t->Branch("t_end", &t_end); t->Branch("pps_rate", &t_pps_rate); + t->Branch("pps_event_counter", &t_pps_event_counter); t->Branch("frame_rate", &t_frame_rate); t->Branch("beamgate_rate", &t_beamgate_rate); t->Branch("int_charge", &t_int_charge); @@ -1129,6 +1147,7 @@ void MonitorLAPPDData::WriteToFile() delete t_time; delete t_end; delete t_pps_rate; + delete t_pps_event_counter; delete t_frame_rate; delete t_beamgate_rate; delete t_int_charge; @@ -1149,6 +1168,7 @@ void MonitorLAPPDData::WriteToFile() t_time->clear(); t_end->clear(); t_pps_rate->clear(); + t_pps_event_counter->clear(); t_frame_rate->clear(); t_beamgate_rate->clear(); t_int_charge->clear(); @@ -1165,6 +1185,7 @@ void MonitorLAPPDData::WriteToFile() t_time->push_back(first_timestamp.at(i_current)); t_end->push_back(last_timestamp.at(i_current)); t_pps_rate->push_back(current_pps_rate.at(i_current)); + t_pps_event_counter->push_back(current_pps_event_counters.at(i_current)); t_frame_rate->push_back(current_frame_rate.at(i_current)); t_beamgate_rate->push_back(current_beamgate_rate.at(i_current)); t_int_charge->push_back(current_int_charge.at(i_current)); @@ -1218,6 +1239,7 @@ void MonitorLAPPDData::WriteToFile() delete t_time; delete t_end; delete t_pps_rate; + delete t_pps_event_counter; delete t_frame_rate; delete t_beamgate_rate; delete t_int_charge; @@ -1247,6 +1269,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) data_times_plot.at(board_nr).clear(); data_times_end_plot.at(board_nr).clear(); pps_rate_plot.at(board_nr).clear(); + pps_event_counter_plot.at(board_nr).clear(); frame_rate_plot.at(board_nr).clear(); beamgate_rate_plot.at(board_nr).clear(); int_charge_plot.at(board_nr).clear(); @@ -1321,6 +1344,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_time = new std::vector; std::vector *t_end = new std::vector; std::vector *t_pps_rate = new std::vector; + std::vector *t_pps_event_counter = new std::vector; std::vector *t_frame_rate = new std::vector; std::vector *t_beamgate_rate = new std::vector; std::vector *t_int_charge = new std::vector; @@ -1340,6 +1364,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("t_start", &t_time); t->SetBranchAddress("t_end", &t_end); t->SetBranchAddress("pps_rate", &t_pps_rate); + t->SetBranchAddress("pps_event_counter", &t_pps_event_counter); t->SetBranchAddress("frame_rate", &t_frame_rate); t->SetBranchAddress("beamgate_rate", &t_beamgate_rate); t->SetBranchAddress("int_charge", &t_int_charge); @@ -1395,6 +1420,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) // std::cout <<"timestamp_start: "<at(i_board) >= timestamp_start && t_end->at(i_board) <= timestamp && t_end->at(i_board) != 0) { + Log("MonitorLAPPDData: ReadFromFile: PPSEventCounter: " + std::to_string(t_pps_event_counter->at(i_board)), v_error, verbosity); data_times_plot.at(board_nr).push_back(t_time->at(i_board)); data_times_end_plot.at(board_nr).push_back(t_end->at(i_board)); pps_rate_plot.at(board_nr).push_back(t_pps_rate->at(i_board)); @@ -1437,6 +1463,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) delete t_time; delete t_end; delete t_pps_rate; + delete t_pps_event_counter; delete t_frame_rate; delete t_beamgate_rate; delete t_int_charge; @@ -2246,6 +2273,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // for (int i_vec=0; i_vecSet(0); + graph_pps_event_counter->Set(0); graph_frame_count->Set(0); for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) @@ -2294,7 +2323,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl for (unsigned int i_file = 0; i_file < pps_rate_plot.at(board_nr).size(); i_file++) { - Log("MonitorLAPPDData: Stored data (file #" + std::to_string(i_file + 1) + "): ", v_message, verbosity); + Log("MonitorLAPPDData: Stored data (file #" + std::to_string(i_file + 1) + ") and i_board: " + std::to_string(board_nr), v_message, verbosity); graph_pps_rate.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), pps_rate_plot.at(board_nr).at(i_file)); graph_frame_rate.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), frame_rate_plot.at(board_nr).at(i_file)); graph_buffer_size.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), buffer_size_plot.at(board_nr).at(i_file)); @@ -2326,6 +2355,8 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl } graph_pps_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_pps); graph_frame_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_data); + Log("MonitorLAPPDData: EventCounter: " + std::to_string(pps_event_counter_plot.at(board_nr).at(i_file)) + " and pps_rate_plot size: " + std::to_string(pps_rate_plot.size()), v_message, verbosity); + graph_pps_event_counter->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), pps_event_counter_plot.at(board_nr).at(i_file)); } } @@ -2363,6 +2394,22 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl ss_pps_count_path << outpath << "LAPPDData_TimeEvolution_PPSEvents_" << file_ending << "." << img_extension; canvas_pps_count->SaveAs(ss_pps_count_path.str().c_str()); + std::stringstream ss_pps_event_counter; + ss_pps_event_counter << "PPS event counter time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); + canvas_pps_event_counter->cd(); + canvas_pps_event_counter->Clear(); + graph_pps_event_counter->SetTitle(ss_pps_event_counter.str().c_str()); + graph_pps_event_counter->GetYaxis()->SetTitle("PPS event counter"); + graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); + graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); + graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); + graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline{%m/%d}{%H:%M}"); + graph_pps_event_counter->GetXaxis()->SetTimeOffset(0.); + graph_pps_event_counter->Draw("apl"); + std::stringstream ss_pps_event_counter_path; + ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; + canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); + std::stringstream ss_frame_count; ss_frame_count << "Data events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_frame_count->cd(); @@ -2835,6 +2882,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ last_pps_count = pps_count_31_0; current_pps_event_counters.at(vector_idx) = last_pps_count; + Log("Set PPS[" + std::to_string(vector_idx) + "] to " + std::to_string(last_pps_count),v_error,verbosity); } if (pps.size() == 16) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 620248c55..76679ab4a 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -225,6 +225,7 @@ class MonitorLAPPDData: public Tool { std::vector partrun_plot; std::vector lappdoffset_plot; std::vector ppscount_plot; + std::map > pps_event_counter_plot; std::vector framecount_plot; //canvas @@ -258,6 +259,7 @@ class MonitorLAPPDData: public Tool { TCanvas *canvas_rate_lappd = nullptr; TCanvas *canvas_frame_count = nullptr; TCanvas *canvas_pps_count = nullptr; + TCanvas *canvas_pps_event_counter = nullptr; //graphs std::map graph_pps_rate; @@ -268,6 +270,7 @@ class MonitorLAPPDData: public Tool { std::map graph_ped; std::map graph_sigma; TGraph *graph_pps_count = nullptr; + TGraph *graph_pps_event_counter = nullptr; TGraph *graph_frame_count = nullptr; //multi-graphs From a544c5178ff32bf7beca6587c9d1e964a7c7e5d9 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 31 Aug 2024 13:04:41 +0000 Subject: [PATCH 05/34] WIP: Working on PPS event counter monitoring 2 --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 19 +++++-------------- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 3 ++- 2 files changed, 7 insertions(+), 15 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 95cbd9ad3..6a615e859 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -961,7 +961,6 @@ void MonitorLAPPDData::LoadACDCBoardConfig(std::string acdc_config) last_timestamp.push_back(0); first_pps_timestamps.push_back(0); last_pps_timestamps.push_back(0); - current_pps_event_counters.push_back(0); current_board_index.push_back(board_number); first_entry.push_back(true); @@ -1083,7 +1082,6 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("t_start", &t_time); t->SetBranchAddress("t_end", &t_end); t->SetBranchAddress("pps_rate", &t_pps_rate); - t->SetBranchAddress("pps_event_counter", &t_pps_event_counter); t->SetBranchAddress("frame_rate", &t_frame_rate); t->SetBranchAddress("beamgate_rate", &t_beamgate_rate); t->SetBranchAddress("int_charge", &t_int_charge); @@ -1107,7 +1105,6 @@ void MonitorLAPPDData::WriteToFile() t->Branch("t_start", &t_time); t->Branch("t_end", &t_end); t->Branch("pps_rate", &t_pps_rate); - t->Branch("pps_event_counter", &t_pps_event_counter); t->Branch("frame_rate", &t_frame_rate); t->Branch("beamgate_rate", &t_beamgate_rate); t->Branch("int_charge", &t_int_charge); @@ -1147,7 +1144,6 @@ void MonitorLAPPDData::WriteToFile() delete t_time; delete t_end; delete t_pps_rate; - delete t_pps_event_counter; delete t_frame_rate; delete t_beamgate_rate; delete t_int_charge; @@ -1168,7 +1164,6 @@ void MonitorLAPPDData::WriteToFile() t_time->clear(); t_end->clear(); t_pps_rate->clear(); - t_pps_event_counter->clear(); t_frame_rate->clear(); t_beamgate_rate->clear(); t_int_charge->clear(); @@ -1185,7 +1180,6 @@ void MonitorLAPPDData::WriteToFile() t_time->push_back(first_timestamp.at(i_current)); t_end->push_back(last_timestamp.at(i_current)); t_pps_rate->push_back(current_pps_rate.at(i_current)); - t_pps_event_counter->push_back(current_pps_event_counters.at(i_current)); t_frame_rate->push_back(current_frame_rate.at(i_current)); t_beamgate_rate->push_back(current_beamgate_rate.at(i_current)); t_int_charge->push_back(current_int_charge.at(i_current)); @@ -1344,7 +1338,6 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_time = new std::vector; std::vector *t_end = new std::vector; std::vector *t_pps_rate = new std::vector; - std::vector *t_pps_event_counter = new std::vector; std::vector *t_frame_rate = new std::vector; std::vector *t_beamgate_rate = new std::vector; std::vector *t_int_charge = new std::vector; @@ -1364,7 +1357,6 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("t_start", &t_time); t->SetBranchAddress("t_end", &t_end); t->SetBranchAddress("pps_rate", &t_pps_rate); - t->SetBranchAddress("pps_event_counter", &t_pps_event_counter); t->SetBranchAddress("frame_rate", &t_frame_rate); t->SetBranchAddress("beamgate_rate", &t_beamgate_rate); t->SetBranchAddress("int_charge", &t_int_charge); @@ -1420,7 +1412,6 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) // std::cout <<"timestamp_start: "<at(i_board) >= timestamp_start && t_end->at(i_board) <= timestamp && t_end->at(i_board) != 0) { - Log("MonitorLAPPDData: ReadFromFile: PPSEventCounter: " + std::to_string(t_pps_event_counter->at(i_board)), v_error, verbosity); data_times_plot.at(board_nr).push_back(t_time->at(i_board)); data_times_end_plot.at(board_nr).push_back(t_end->at(i_board)); pps_rate_plot.at(board_nr).push_back(t_pps_rate->at(i_board)); @@ -1463,7 +1454,6 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) delete t_time; delete t_end; delete t_pps_rate; - delete t_pps_event_counter; delete t_frame_rate; delete t_beamgate_rate; delete t_int_charge; @@ -2273,7 +2263,6 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // for (int i_vec=0; i_vecSetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_pps); graph_frame_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_data); Log("MonitorLAPPDData: EventCounter: " + std::to_string(pps_event_counter_plot.at(board_nr).at(i_file)) + " and pps_rate_plot size: " + std::to_string(pps_rate_plot.size()), v_message, verbosity); - graph_pps_event_counter->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), pps_event_counter_plot.at(board_nr).at(i_file)); } } @@ -2756,6 +2744,9 @@ void MonitorLAPPDData::ProcessLAPPDData() current_ped.clear(); current_sigma.clear(); + all_pps_event_counters.clear(); + all_timestamps.clear(); + /* long entries; LAPPDData->Header->Get("TotalEntries", entries); @@ -2881,8 +2872,8 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ std::bitset<32> bits_pps_count_31_0(pps_count_31_0); last_pps_count = pps_count_31_0; - current_pps_event_counters.at(vector_idx) = last_pps_count; - Log("Set PPS[" + std::to_string(vector_idx) + "] to " + std::to_string(last_pps_count),v_error,verbosity); + all_pps_event_counters.push_back(last_pps_count); + all_timestamps.push_back(last_pps_timestamp); } if (pps.size() == 16) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 76679ab4a..007632b51 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -164,7 +164,8 @@ class MonitorLAPPDData: public Tool { std::vector last_timestamp; std::vector first_pps_timestamps; std::vector last_pps_timestamps; - std::vector current_pps_event_counters; + std::vector all_pps_event_counters; // Both vectors used for + std::vector all_timestamps; // plotting std::vector first_entry; std::vector first_entry_pps; std::vector n_buffer; From 2676b8a952c6ffa2e92ee6ce31c5cc561692cfad Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 31 Aug 2024 14:51:10 +0000 Subject: [PATCH 06/34] PPS event counter plotting now works --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 19 ++++++++++++------- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 5 +++-- 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 6a615e859..ff11b0c23 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2311,7 +2311,6 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl std::cout <<"int_charge_plot.size(): "<SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), pps_rate_plot.at(board_nr).at(i_file)); graph_frame_rate.at(board_nr)->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), frame_rate_plot.at(board_nr).at(i_file)); @@ -2344,7 +2343,6 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl } graph_pps_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_pps); graph_frame_count->SetPoint(i_file, labels_timeaxis.at(board_nr)[i_file].Convert(), integrated_data); - Log("MonitorLAPPDData: EventCounter: " + std::to_string(pps_event_counter_plot.at(board_nr).at(i_file)) + " and pps_rate_plot size: " + std::to_string(pps_rate_plot.size()), v_message, verbosity); } } @@ -2358,6 +2356,13 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // std::cout <<"pps_rate_plot.at(board_nr).size(): "<SetPoint(graph_pps_event_counter->GetN() + 1, timestamp_to_e13, all_pps_event_counters.at(i_timestamp)); + } + std::stringstream ss_pps_count; ss_pps_count << "PPS events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_pps_count->cd(); @@ -2388,11 +2393,10 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_pps_event_counter->Clear(); graph_pps_event_counter->SetTitle(ss_pps_event_counter.str().c_str()); graph_pps_event_counter->GetYaxis()->SetTitle("PPS event counter"); - graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); + graph_pps_event_counter->GetXaxis()->SetTitle("ns (1e13)"); + graph_pps_event_counter->GetXaxis()->SetTimeDisplay(0); + graph_pps_event_counter->GetXaxis()->SetTimeOffset(0); graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); - graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); - graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline{%m/%d}{%H:%M}"); - graph_pps_event_counter->GetXaxis()->SetTimeOffset(0.); graph_pps_event_counter->Draw("apl"); std::stringstream ss_pps_event_counter_path; ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; @@ -2872,8 +2876,9 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ std::bitset<32> bits_pps_count_31_0(pps_count_31_0); last_pps_count = pps_count_31_0; + // Add pps count and timestamp for plotting all_pps_event_counters.push_back(last_pps_count); - all_timestamps.push_back(last_pps_timestamp); + all_timestamps.push_back(pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds } if (pps.size() == 16) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 007632b51..052c9b1ee 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -137,6 +137,7 @@ class MonitorLAPPDData: public Tool { ULong64_t utc_to_fermi = 2.7e12; //6h clock delay in ADC clocks (timestamps in UTC time compared to Fermilab time) ULong64_t utc_to_t=21600000; //6h clock delay in millisecons double CLOCK_to_SEC = 3.125e-9; //320MHz clock -> 1/320MHz = 3.125ns + double CLOCK_to_NSEC = 3.125; //320MHz clock -> 1/320MHz = 3.125ns ULong64_t reference_time; ULong64_t last_pps_timestamp; int last_pps_count; @@ -164,8 +165,8 @@ class MonitorLAPPDData: public Tool { std::vector last_timestamp; std::vector first_pps_timestamps; std::vector last_pps_timestamps; - std::vector all_pps_event_counters; // Both vectors used for - std::vector all_timestamps; // plotting + std::vector all_pps_event_counters; // PPS event counters, indexed by all_timestamps + std::vector all_timestamps; // Timestamp in nanoseconds std::vector first_entry; std::vector first_entry_pps; std::vector n_buffer; From 6e313c3bae4d9a270f834fba290555e2a7d79627 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sun, 1 Sep 2024 11:55:20 +0000 Subject: [PATCH 07/34] Fixed label offset in PPS event counter graph --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index ff11b0c23..d56f04104 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2395,8 +2395,9 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_event_counter->GetYaxis()->SetTitle("PPS event counter"); graph_pps_event_counter->GetXaxis()->SetTitle("ns (1e13)"); graph_pps_event_counter->GetXaxis()->SetTimeDisplay(0); - graph_pps_event_counter->GetXaxis()->SetTimeOffset(0); graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); + graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.01); + graph_pps_event_counter->GetXaxis()->SetTimeOffset(0.); graph_pps_event_counter->Draw("apl"); std::stringstream ss_pps_event_counter_path; ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; @@ -2826,7 +2827,8 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ current_pps_count++; // Parse PPS data according to Data Frame (PPS) metadata - if (pps.size() == 16 || pps.size() == 32) { + if (pps.size() == 16 || pps.size() == 32) + { // Parse PPS Timestamp // Get words from 2 to 5 unsigned short pps_63_48 = pps.at(2); @@ -2837,8 +2839,8 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ std::bitset<16> bits_pps_47_32(pps_47_32); std::bitset<16> bits_pps_31_16(pps_31_16); std::bitset<16> bits_pps_15_0(pps_15_0); - - // Combine all the bits to create PPS timestamp + + // Combine all the bits to create PPS timestamp unsigned long pps_63_0 = (static_cast(pps_63_48) << 48) + (static_cast(pps_47_32) << 32) + (static_cast(pps_31_16) << 16) + (static_cast(pps_15_0)); if (verbosity > 2) std::cout << "pps combined: " << pps_63_0 << std::endl; @@ -2922,7 +2924,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ } last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); n_pps.at(vector_idx)++; - + have_pps = true; do_continue = true; } From e4ea037c2767f59699af69c7eb4e52028c066317 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Fri, 6 Sep 2024 14:46:22 +0000 Subject: [PATCH 08/34] fix: Remove unnecessary PPS parsing logic --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 10 +--------- 1 file changed, 1 insertion(+), 9 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index d56f04104..d0bc8f8be 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2883,12 +2883,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ all_timestamps.push_back(pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds } - if (pps.size() == 16) - { - have_pps = true; - do_continue = true; - } - else if (pps.size() == 32) + if (pps.size() == 32) { unsigned short pps_63_48 = pps.at(18); unsigned short pps_47_32 = pps.at(19); @@ -2924,9 +2919,6 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ } last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); n_pps.at(vector_idx)++; - - have_pps = true; - do_continue = true; } } if (do_continue) From d4ee78b20a33dafbb4772cc89d8adc2a28acdab4 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Fri, 6 Sep 2024 15:02:06 +0000 Subject: [PATCH 09/34] fix: Add missing flags for LAPPD processing --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 3 +++ 1 file changed, 3 insertions(+) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index d0bc8f8be..823ba5d29 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2920,6 +2920,9 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ last_pps_timestamps.at(vector_idx) = (last_pps_timestamp); n_pps.at(vector_idx)++; } + + have_pps = true; + do_continue = true; } if (do_continue) continue; From 79f5e60bf704474a9b67c7093b64a6607cd2c92b Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Fri, 6 Sep 2024 17:43:29 +0000 Subject: [PATCH 10/34] chore: Update PPS event counter graph marker style and color --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 823ba5d29..20d83e37a 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2398,7 +2398,10 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.01); graph_pps_event_counter->GetXaxis()->SetTimeOffset(0.); - graph_pps_event_counter->Draw("apl"); + graph_pps_event_counter->SetMarkerSize(0.4F); + graph_pps_event_counter->SetMarkerColor(kBlue); + graph_pps_event_counter->SetMarkerStyle(kFullCircle); + graph_pps_event_counter->Draw("AP"); std::stringstream ss_pps_event_counter_path; ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); From 9748ff61f709a626c8c3083a257fe70e7a58ab72 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 7 Sep 2024 15:09:15 +0000 Subject: [PATCH 11/34] feat: persist lappd pps and timestamps throughout runs --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 45 ++++++++++++++++--- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 4 +- 2 files changed, 40 insertions(+), 9 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 20d83e37a..4a2b27524 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1070,6 +1070,9 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_rate = new std::vector; std::vector *t_ped = new std::vector; std::vector *t_sigma = new std::vector; + std::vector *t_raw_lappd_data_pps_counts = new std::vector; + std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; + int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; ULong64_t t_lappd_offset; @@ -1097,6 +1100,8 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("pps_count", &t_pps_count); t->SetBranchAddress("frame_count", &t_frame_count); t->SetBranchAddress("lappd_offset", &t_lappd_offset); + t->SetBranchAddress("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); + t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); } else { @@ -1120,6 +1125,8 @@ void MonitorLAPPDData::WriteToFile() t->Branch("pps_count", &t_pps_count); t->Branch("frame_count", &t_frame_count); t->Branch("lappd_offset", &t_lappd_offset); + t->Branch("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); + t->Branch("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); } int n_entries = t->GetEntries(); @@ -1153,6 +1160,8 @@ void MonitorLAPPDData::WriteToFile() delete t_rate; delete t_ped; delete t_sigma; + delete t_raw_lappd_data_pps_counts; + delete t_raw_lappd_data_pps_timestamps; delete f; gROOT->cd(); @@ -1193,6 +1202,13 @@ void MonitorLAPPDData::WriteToFile() "MonitorLAPPDData: WriteToFile: Board " + std::to_string(current_board_index.at(i_current)) + ". Writing data to file: " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" + std::to_string(starttime_tm.tm_hour) + ":" + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec), v_message, verbosity); } + // Push raw lappd data + for (int i_current = 0; i_current < raw_lappd_data_pps_timestamps.size(); i_current++) + { + t_raw_lappd_data_pps_counts->push_back(raw_lappd_data_pps_counts.at(i_current)); + t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); + } + if (verbosity > 3) std::cout << "current_ped.size(): " << current_ped.size() << std::endl; for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) @@ -1243,6 +1259,8 @@ void MonitorLAPPDData::WriteToFile() delete t_rate; delete t_ped; delete t_sigma; + delete t_raw_lappd_data_pps_counts; + delete t_raw_lappd_data_pps_timestamps; delete f; gROOT->cd(); @@ -1283,6 +1301,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) lappdoffset_plot.clear(); ppscount_plot.clear(); framecount_plot.clear(); + raw_lappd_data_pps_counts.clear(); + raw_lappd_data_pps_timestamps.clear(); // take the end time and calculate the start time with the given time_frame ULong64_t timestamp_start = timestamp - time_frame * MIN_to_HOUR * SEC_to_MIN * MSEC_to_SEC; @@ -1347,6 +1367,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_rate = new std::vector; std::vector *t_ped = new std::vector; std::vector *t_sigma = new std::vector; + std::vector *t_raw_lappd_data_pps_counts = new std::vector; + std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; @@ -1372,6 +1394,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("pps_count", &t_pps_count); t->SetBranchAddress("frame_count", &t_frame_count); t->SetBranchAddress("lappd_offset", &t_lappd_offset); + t->SetBranchAddress("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); + t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); nentries_tree = t->GetEntries(); @@ -1450,6 +1474,11 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) } } + for (int i = 0; i < t_raw_lappd_data_pps_timestamps->size(); i++) { + raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); + raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); + } + // Delete vectors, if we have any delete t_time; delete t_end; @@ -1463,6 +1492,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) delete t_rate; delete t_ped; delete t_sigma; + delete t_raw_lappd_data_pps_counts; + delete t_raw_lappd_data_pps_timestamps; } f->Close(); @@ -2357,10 +2388,10 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl if (i_board == 0) { // Add graph points for PPS event counter - for (int i_timestamp = 0; i_timestamp < all_timestamps.size(); i_timestamp++) + for (int i_timestamp = 0; i_timestamp < raw_lappd_data_pps_timestamps.size(); i_timestamp++) { - double timestamp_to_e13 = (double)all_timestamps.at(i_timestamp) / pow(10, 13); - graph_pps_event_counter->SetPoint(graph_pps_event_counter->GetN() + 1, timestamp_to_e13, all_pps_event_counters.at(i_timestamp)); + double timestamp_to_e13 = (double)raw_lappd_data_pps_timestamps.at(i_timestamp) / pow(10, 13); + graph_pps_event_counter->SetPoint(graph_pps_event_counter->GetN() + 1, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); } std::stringstream ss_pps_count; @@ -2752,8 +2783,8 @@ void MonitorLAPPDData::ProcessLAPPDData() current_ped.clear(); current_sigma.clear(); - all_pps_event_counters.clear(); - all_timestamps.clear(); + raw_lappd_data_pps_counts.clear(); + raw_lappd_data_pps_timestamps.clear(); /* long entries; @@ -2882,8 +2913,8 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ last_pps_count = pps_count_31_0; // Add pps count and timestamp for plotting - all_pps_event_counters.push_back(last_pps_count); - all_timestamps.push_back(pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds + raw_lappd_data_pps_counts.push_back(last_pps_count); + raw_lappd_data_pps_timestamps.push_back(pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds } if (pps.size() == 32) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 052c9b1ee..6b5bee86d 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -165,8 +165,8 @@ class MonitorLAPPDData: public Tool { std::vector last_timestamp; std::vector first_pps_timestamps; std::vector last_pps_timestamps; - std::vector all_pps_event_counters; // PPS event counters, indexed by all_timestamps - std::vector all_timestamps; // Timestamp in nanoseconds + std::vector raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps + std::vector raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds std::vector first_entry; std::vector first_entry_pps; std::vector n_buffer; From e0e6bfacd3c1d460abcd0cdbceaf273496f39dfe Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 7 Sep 2024 17:14:03 +0000 Subject: [PATCH 12/34] chore: Update README.md --- UserTools/MonitorLAPPDData/README.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/UserTools/MonitorLAPPDData/README.md b/UserTools/MonitorLAPPDData/README.md index 78963ebae..ccbfe3629 100644 --- a/UserTools/MonitorLAPPDData/README.md +++ b/UserTools/MonitorLAPPDData/README.md @@ -10,6 +10,8 @@ It produces the following kinds of plots: * simple hit counting for LAPPD pulses * Timing plot w.r.t. the beginning of the beamgate +Data persistance for handling certain plots (i.e. PPS Event Counting) is handled using ROOT files, which are written to the `PathMonitoring` directory while processing each run file, by the `WriteToFile` function, so that we can handle all of the sub-runs incrementally, and plot them in a single plot. + ## Configuration `MonitorLAPPDData` has the following configuration variables From b72396a64afe0a80e8a64b6142df568de70a9bed Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 7 Sep 2024 17:31:27 +0000 Subject: [PATCH 13/34] feat: persist PPS accumulated number and PSec timestamp --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 31 +++++++++++++++++-- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 2 ++ 2 files changed, 30 insertions(+), 3 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 4a2b27524..c498c7f6b 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1072,7 +1072,9 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; - + std::vector *t_pps_accumulated_number = new std::vector; // Accumulated PPS event number, taken from current_pps_count, + std::vector *t_pps_accumulated_psec_timestamp = new std::vector; + int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; ULong64_t t_lappd_offset; @@ -1102,6 +1104,8 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("lappd_offset", &t_lappd_offset); t->SetBranchAddress("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); + t->SetBranchAddress("pps_accumulated_number", &t_pps_accumulated_number); + t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); } else { @@ -1127,6 +1131,8 @@ void MonitorLAPPDData::WriteToFile() t->Branch("lappd_offset", &t_lappd_offset); t->Branch("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); t->Branch("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); + t->Branch("pps_accumulated_number", &t_pps_accumulated_number); + t->Branch("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); } int n_entries = t->GetEntries(); @@ -1162,6 +1168,8 @@ void MonitorLAPPDData::WriteToFile() delete t_sigma; delete t_raw_lappd_data_pps_counts; delete t_raw_lappd_data_pps_timestamps; + delete t_pps_accumulated_number; + delete t_pps_accumulated_psec_timestamp; delete f; gROOT->cd(); @@ -1209,8 +1217,14 @@ void MonitorLAPPDData::WriteToFile() t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); } - if (verbosity > 3) - std::cout << "current_ped.size(): " << current_ped.size() << std::endl; + // Push accumulated PPS event number and PSec timestamp + t_pps_accumulated_number->push_back(current_pps_count); + std::string psec_timestamp_string; + // Get the PSecTimestamp given by ParseDataMonitoring tool + m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); + // Cast PSec timestamp to long, then push it + t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); + for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) { t_chkey->push_back(current_chkey.at(i_current)); @@ -1303,6 +1317,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) framecount_plot.clear(); raw_lappd_data_pps_counts.clear(); raw_lappd_data_pps_timestamps.clear(); + pps_accumulated_number.clear(); + pps_accumulated_psec_timestamp.clear(); // take the end time and calculate the start time with the given time_frame ULong64_t timestamp_start = timestamp - time_frame * MIN_to_HOUR * SEC_to_MIN * MSEC_to_SEC; @@ -1369,6 +1385,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; + std::vector *t_pps_accumulated_number = new std::vector; + std::vector *t_pps_accumulated_psec_timestamp = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; @@ -1396,6 +1414,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("lappd_offset", &t_lappd_offset); t->SetBranchAddress("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); + t->SetBranchAddress("pps_accumulated_number", &t_pps_accumulated_number); + t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); nentries_tree = t->GetEntries(); @@ -1478,6 +1498,11 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); } + + for (int i = 0; i < t_pps_accumulated_psec_timestamp->size(); i++) { + pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp->at(i)); + pps_accumulated_number.push_back(t_pps_accumulated_number->at(i)); + } // Delete vectors, if we have any delete t_time; diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 6b5bee86d..64aa009fc 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -167,6 +167,8 @@ class MonitorLAPPDData: public Tool { std::vector last_pps_timestamps; std::vector raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps std::vector raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds + std::vector pps_accumulated_number; // PPS accumulated number of events + std::vector pps_accumulated_psec_timestamp; // PSec timestamps of each PPS accumulated number std::vector first_entry; std::vector first_entry_pps; std::vector n_buffer; From 52542d1cd946a5351f81090d07c2d6d0cd08b51f Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 7 Sep 2024 22:11:23 +0000 Subject: [PATCH 14/34] feat: add PPS accumulated number vs System Time graph --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 39 ++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index c498c7f6b..f71b2e771 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -364,6 +364,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() canvas_frame_count = new TCanvas("canvas_frame_count", "LAPPD Data Count", 900, 600); canvas_pps_count = new TCanvas("canvas_pps_count", "LAPPD PPS Count", 900, 600); canvas_pps_event_counter = new TCanvas("canvas_pps_event_counter", "LAPPD PPS Event Counter", 900, 600); + canvas_pps_accumulated_number_vs_psec_timestamp = new TCanvas("canvas_pps_accumulated_number_vs_psec_timestamp", "LAPPD PPS Accumulated Number vs System Time", 900, 600); // PSec timestamp is also referred to as "System Time" // Histograms // ToDo: Not hardcode the number of channels here @@ -749,14 +750,17 @@ void MonitorLAPPDData::InitializeHistsLAPPD() // Normal Graphs without board number graph_pps_count = new TGraph(); graph_pps_event_counter = new TGraph(); + graph_pps_accumulated_number_vs_psec_timestamp = new TGraph(); graph_frame_count = new TGraph(); graph_pps_count->SetName("graph_pps_count"); graph_pps_event_counter->SetName("graph_pps_event_counter"); + graph_pps_accumulated_number_vs_psec_timestamp->SetName("graph_pps_accumulated_number_vs_psec_timestamp"); graph_frame_count->SetName("graph_frame_count"); graph_pps_count->SetTitle("LAPPD PPS Events Time Evolution"); graph_pps_event_counter->SetTitle("LAPPD PPS Event Counter Time Evolution"); + graph_pps_accumulated_number_vs_psec_timestamp->SetTitle("LAPPD PPS Accumulated Number vs System Time"); graph_frame_count->SetTitle("LAPPD Data Events Time Evolution"); if (draw_marker) @@ -767,38 +771,47 @@ void MonitorLAPPDData::InitializeHistsLAPPD() graph_pps_count->SetMarkerColor(kBlack); graph_pps_event_counter->SetMarkerColor(kBlack); + graph_pps_accumulated_number_vs_psec_timestamp->SetMarkerColor(kBlack); graph_frame_count->SetMarkerColor(kBlack); graph_pps_count->SetLineColor(kBlack); graph_pps_event_counter->SetLineColor(kBlack); + graph_pps_accumulated_number_vs_psec_timestamp->SetLineColor(kBlack); graph_frame_count->SetLineColor(kBlack); graph_pps_count->SetLineWidth(2); graph_pps_event_counter->SetLineWidth(2); + graph_pps_accumulated_number_vs_psec_timestamp->SetLineWidth(2); graph_frame_count->SetLineWidth(2); graph_pps_count->SetFillColor(0); graph_pps_event_counter->SetFillColor(0); + graph_pps_accumulated_number_vs_psec_timestamp->SetFillColor(0); graph_frame_count->SetFillColor(0); graph_pps_count->GetYaxis()->SetTitle("PPS Events"); graph_pps_event_counter->GetYaxis()->SetTitle("PPS Event Counter"); + graph_pps_accumulated_number_vs_psec_timestamp->GetYaxis()->SetTitle("PPS Accumulated Number"); graph_frame_count->GetYaxis()->SetTitle("Data Events"); graph_pps_count->GetXaxis()->SetTimeDisplay(1); graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeDisplay(1); graph_frame_count->GetXaxis()->SetTimeDisplay(1); graph_pps_count->GetXaxis()->SetLabelSize(0.03); graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelSize(0.03); graph_frame_count->GetXaxis()->SetLabelSize(0.03); graph_pps_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelOffset(0.03); graph_frame_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_frame_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); // Multi-Graphs @@ -2332,6 +2345,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_count->Set(0); graph_pps_event_counter->Set(0); + graph_pps_accumulated_number_vs_psec_timestamp->Set(0); graph_frame_count->Set(0); for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) @@ -2416,7 +2430,14 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl for (int i_timestamp = 0; i_timestamp < raw_lappd_data_pps_timestamps.size(); i_timestamp++) { double timestamp_to_e13 = (double)raw_lappd_data_pps_timestamps.at(i_timestamp) / pow(10, 13); - graph_pps_event_counter->SetPoint(graph_pps_event_counter->GetN() + 1, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); + graph_pps_event_counter->SetPoint(i_timestamp, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); + } + // Add graph points for PPS accumulated number + for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) + { + auto acc_timestamp = pps_accumulated_psec_timestamp.at(i_timestamp); + auto acc_number = pps_accumulated_number.at(i_timestamp); + graph_pps_accumulated_number_vs_psec_timestamp->SetPoint(i_timestamp, acc_timestamp, acc_number); } std::stringstream ss_pps_count; @@ -2462,6 +2483,22 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); + std::stringstream ss_pps_accumulated_number_vs_psec_timestamp; + ss_pps_accumulated_number_vs_psec_timestamp << "PPS Accumulated Number vs System Time (last " << ss_timeframe.str() << "h) " << end_time.str(); + canvas_pps_accumulated_number_vs_psec_timestamp->cd(); + canvas_pps_accumulated_number_vs_psec_timestamp->Clear(); + graph_pps_accumulated_number_vs_psec_timestamp->SetTitle(ss_pps_accumulated_number_vs_psec_timestamp.str().c_str()); + graph_pps_accumulated_number_vs_psec_timestamp->GetYaxis()->SetTitle("PPS Accumulated Number"); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeDisplay(1); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelSize(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelOffset(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeFormat("#splitline{%m/%d}{%H:%M}"); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeOffset(0.); + graph_pps_accumulated_number_vs_psec_timestamp->Draw("apl"); + std::stringstream ss_pps_accumulated_number_vs_psec_timestamp_path; + ss_pps_accumulated_number_vs_psec_timestamp_path << outpath << "LAPPDData_TimeEvolution_PPSAccumulatedNumber_vsPsecTimestamp_" << file_ending << "." << img_extension; + canvas_pps_accumulated_number_vs_psec_timestamp->SaveAs(ss_pps_accumulated_number_vs_psec_timestamp_path.str().c_str()); + std::stringstream ss_frame_count; ss_frame_count << "Data events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_frame_count->cd(); From 70d693b94570d03115d0dc967aaa1b23b7c8e0ef Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Sat, 7 Sep 2024 22:12:40 +0000 Subject: [PATCH 15/34] feat: add PPS accumulated number vs System Time graph --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 39 ++++++++++++++++++- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 2 + 2 files changed, 40 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index c498c7f6b..f71b2e771 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -364,6 +364,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() canvas_frame_count = new TCanvas("canvas_frame_count", "LAPPD Data Count", 900, 600); canvas_pps_count = new TCanvas("canvas_pps_count", "LAPPD PPS Count", 900, 600); canvas_pps_event_counter = new TCanvas("canvas_pps_event_counter", "LAPPD PPS Event Counter", 900, 600); + canvas_pps_accumulated_number_vs_psec_timestamp = new TCanvas("canvas_pps_accumulated_number_vs_psec_timestamp", "LAPPD PPS Accumulated Number vs System Time", 900, 600); // PSec timestamp is also referred to as "System Time" // Histograms // ToDo: Not hardcode the number of channels here @@ -749,14 +750,17 @@ void MonitorLAPPDData::InitializeHistsLAPPD() // Normal Graphs without board number graph_pps_count = new TGraph(); graph_pps_event_counter = new TGraph(); + graph_pps_accumulated_number_vs_psec_timestamp = new TGraph(); graph_frame_count = new TGraph(); graph_pps_count->SetName("graph_pps_count"); graph_pps_event_counter->SetName("graph_pps_event_counter"); + graph_pps_accumulated_number_vs_psec_timestamp->SetName("graph_pps_accumulated_number_vs_psec_timestamp"); graph_frame_count->SetName("graph_frame_count"); graph_pps_count->SetTitle("LAPPD PPS Events Time Evolution"); graph_pps_event_counter->SetTitle("LAPPD PPS Event Counter Time Evolution"); + graph_pps_accumulated_number_vs_psec_timestamp->SetTitle("LAPPD PPS Accumulated Number vs System Time"); graph_frame_count->SetTitle("LAPPD Data Events Time Evolution"); if (draw_marker) @@ -767,38 +771,47 @@ void MonitorLAPPDData::InitializeHistsLAPPD() graph_pps_count->SetMarkerColor(kBlack); graph_pps_event_counter->SetMarkerColor(kBlack); + graph_pps_accumulated_number_vs_psec_timestamp->SetMarkerColor(kBlack); graph_frame_count->SetMarkerColor(kBlack); graph_pps_count->SetLineColor(kBlack); graph_pps_event_counter->SetLineColor(kBlack); + graph_pps_accumulated_number_vs_psec_timestamp->SetLineColor(kBlack); graph_frame_count->SetLineColor(kBlack); graph_pps_count->SetLineWidth(2); graph_pps_event_counter->SetLineWidth(2); + graph_pps_accumulated_number_vs_psec_timestamp->SetLineWidth(2); graph_frame_count->SetLineWidth(2); graph_pps_count->SetFillColor(0); graph_pps_event_counter->SetFillColor(0); + graph_pps_accumulated_number_vs_psec_timestamp->SetFillColor(0); graph_frame_count->SetFillColor(0); graph_pps_count->GetYaxis()->SetTitle("PPS Events"); graph_pps_event_counter->GetYaxis()->SetTitle("PPS Event Counter"); + graph_pps_accumulated_number_vs_psec_timestamp->GetYaxis()->SetTitle("PPS Accumulated Number"); graph_frame_count->GetYaxis()->SetTitle("Data Events"); graph_pps_count->GetXaxis()->SetTimeDisplay(1); graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeDisplay(1); graph_frame_count->GetXaxis()->SetTimeDisplay(1); graph_pps_count->GetXaxis()->SetLabelSize(0.03); graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelSize(0.03); graph_frame_count->GetXaxis()->SetLabelSize(0.03); graph_pps_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelOffset(0.03); graph_frame_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_frame_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); // Multi-Graphs @@ -2332,6 +2345,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_count->Set(0); graph_pps_event_counter->Set(0); + graph_pps_accumulated_number_vs_psec_timestamp->Set(0); graph_frame_count->Set(0); for (int i_board = 0; i_board < (int)board_configuration.size(); i_board++) @@ -2416,7 +2430,14 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl for (int i_timestamp = 0; i_timestamp < raw_lappd_data_pps_timestamps.size(); i_timestamp++) { double timestamp_to_e13 = (double)raw_lappd_data_pps_timestamps.at(i_timestamp) / pow(10, 13); - graph_pps_event_counter->SetPoint(graph_pps_event_counter->GetN() + 1, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); + graph_pps_event_counter->SetPoint(i_timestamp, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); + } + // Add graph points for PPS accumulated number + for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) + { + auto acc_timestamp = pps_accumulated_psec_timestamp.at(i_timestamp); + auto acc_number = pps_accumulated_number.at(i_timestamp); + graph_pps_accumulated_number_vs_psec_timestamp->SetPoint(i_timestamp, acc_timestamp, acc_number); } std::stringstream ss_pps_count; @@ -2462,6 +2483,22 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); + std::stringstream ss_pps_accumulated_number_vs_psec_timestamp; + ss_pps_accumulated_number_vs_psec_timestamp << "PPS Accumulated Number vs System Time (last " << ss_timeframe.str() << "h) " << end_time.str(); + canvas_pps_accumulated_number_vs_psec_timestamp->cd(); + canvas_pps_accumulated_number_vs_psec_timestamp->Clear(); + graph_pps_accumulated_number_vs_psec_timestamp->SetTitle(ss_pps_accumulated_number_vs_psec_timestamp.str().c_str()); + graph_pps_accumulated_number_vs_psec_timestamp->GetYaxis()->SetTitle("PPS Accumulated Number"); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeDisplay(1); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelSize(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelOffset(0.03); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeFormat("#splitline{%m/%d}{%H:%M}"); + graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeOffset(0.); + graph_pps_accumulated_number_vs_psec_timestamp->Draw("apl"); + std::stringstream ss_pps_accumulated_number_vs_psec_timestamp_path; + ss_pps_accumulated_number_vs_psec_timestamp_path << outpath << "LAPPDData_TimeEvolution_PPSAccumulatedNumber_vsPsecTimestamp_" << file_ending << "." << img_extension; + canvas_pps_accumulated_number_vs_psec_timestamp->SaveAs(ss_pps_accumulated_number_vs_psec_timestamp_path.str().c_str()); + std::stringstream ss_frame_count; ss_frame_count << "Data events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_frame_count->cd(); diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 64aa009fc..f25f3882f 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -264,6 +264,7 @@ class MonitorLAPPDData: public Tool { TCanvas *canvas_frame_count = nullptr; TCanvas *canvas_pps_count = nullptr; TCanvas *canvas_pps_event_counter = nullptr; + TCanvas *canvas_pps_accumulated_number_vs_psec_timestamp = nullptr; //graphs std::map graph_pps_rate; @@ -275,6 +276,7 @@ class MonitorLAPPDData: public Tool { std::map graph_sigma; TGraph *graph_pps_count = nullptr; TGraph *graph_pps_event_counter = nullptr; + TGraph *graph_pps_accumulated_number_vs_psec_timestamp = nullptr; TGraph *graph_frame_count = nullptr; //multi-graphs From b57c25d4b4e2f62e2130183dbc1dba47749e47cc Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 9 Sep 2024 12:03:01 +0000 Subject: [PATCH 16/34] feat: persist raw LAPPD pps data per partrun file --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 29 ++++++++++--------- 1 file changed, 16 insertions(+), 13 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index f71b2e771..81c224b7b 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1223,21 +1223,24 @@ void MonitorLAPPDData::WriteToFile() "MonitorLAPPDData: WriteToFile: Board " + std::to_string(current_board_index.at(i_current)) + ". Writing data to file: " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" + std::to_string(starttime_tm.tm_hour) + ":" + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec), v_message, verbosity); } - // Push raw lappd data - for (int i_current = 0; i_current < raw_lappd_data_pps_timestamps.size(); i_current++) - { - t_raw_lappd_data_pps_counts->push_back(raw_lappd_data_pps_counts.at(i_current)); - t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); + // Once every partfun file + if (t_partrun < current_partrun) { + // Push raw lappd data + for (int i_current = 0; i_current < raw_lappd_data_pps_timestamps.size(); i_current++) + { + t_raw_lappd_data_pps_counts->push_back(raw_lappd_data_pps_counts.at(i_current)); + t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); + } + + // Push accumulated PPS event number and PSec timestamp + t_pps_accumulated_number->push_back(current_pps_count); + std::string psec_timestamp_string; + // Get the PSecTimestamp given by ParseDataMonitoring tool + m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); + // Cast PSec timestamp to long, then push it + t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); } - // Push accumulated PPS event number and PSec timestamp - t_pps_accumulated_number->push_back(current_pps_count); - std::string psec_timestamp_string; - // Get the PSecTimestamp given by ParseDataMonitoring tool - m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); - // Cast PSec timestamp to long, then push it - t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); - for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) { t_chkey->push_back(current_chkey.at(i_current)); From 6ddcc00c55c83323dc439e25b617ddaa50334e7a Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 9 Sep 2024 15:28:29 +0000 Subject: [PATCH 17/34] feat: plot, and persist PPS time vs accumulated number time --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 52 ++++++++++++++++++- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 3 ++ 2 files changed, 53 insertions(+), 2 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 81c224b7b..d1c040d84 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -365,7 +365,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() canvas_pps_count = new TCanvas("canvas_pps_count", "LAPPD PPS Count", 900, 600); canvas_pps_event_counter = new TCanvas("canvas_pps_event_counter", "LAPPD PPS Event Counter", 900, 600); canvas_pps_accumulated_number_vs_psec_timestamp = new TCanvas("canvas_pps_accumulated_number_vs_psec_timestamp", "LAPPD PPS Accumulated Number vs System Time", 900, 600); // PSec timestamp is also referred to as "System Time" - + canvas_pps_time_vs_accumulated_number = new TCanvas("canvas_pps_time_vs_accumulated_number", "LAPPD PPS Time vs Accumulated Number", 900, 600); // Histograms // ToDo: Not hardcode the number of channels here int numberOfChannels = 30; @@ -751,16 +751,19 @@ void MonitorLAPPDData::InitializeHistsLAPPD() graph_pps_count = new TGraph(); graph_pps_event_counter = new TGraph(); graph_pps_accumulated_number_vs_psec_timestamp = new TGraph(); + graph_pps_time_vs_accumulated_number = new TGraph(); graph_frame_count = new TGraph(); graph_pps_count->SetName("graph_pps_count"); graph_pps_event_counter->SetName("graph_pps_event_counter"); graph_pps_accumulated_number_vs_psec_timestamp->SetName("graph_pps_accumulated_number_vs_psec_timestamp"); + graph_pps_time_vs_accumulated_number->SetName("graph_pps_time_vs_accumulated_number"); graph_frame_count->SetName("graph_frame_count"); graph_pps_count->SetTitle("LAPPD PPS Events Time Evolution"); graph_pps_event_counter->SetTitle("LAPPD PPS Event Counter Time Evolution"); graph_pps_accumulated_number_vs_psec_timestamp->SetTitle("LAPPD PPS Accumulated Number vs System Time"); + graph_pps_time_vs_accumulated_number->SetTitle("LAPPD PPS Time vs Accumulated Number"); graph_frame_count->SetTitle("LAPPD Data Events Time Evolution"); if (draw_marker) @@ -772,46 +775,55 @@ void MonitorLAPPDData::InitializeHistsLAPPD() graph_pps_count->SetMarkerColor(kBlack); graph_pps_event_counter->SetMarkerColor(kBlack); graph_pps_accumulated_number_vs_psec_timestamp->SetMarkerColor(kBlack); + graph_pps_time_vs_accumulated_number->SetMarkerColor(kBlack); graph_frame_count->SetMarkerColor(kBlack); graph_pps_count->SetLineColor(kBlack); graph_pps_event_counter->SetLineColor(kBlack); graph_pps_accumulated_number_vs_psec_timestamp->SetLineColor(kBlack); + graph_pps_time_vs_accumulated_number->SetLineColor(kBlack); graph_frame_count->SetLineColor(kBlack); graph_pps_count->SetLineWidth(2); graph_pps_event_counter->SetLineWidth(2); graph_pps_accumulated_number_vs_psec_timestamp->SetLineWidth(2); + graph_pps_time_vs_accumulated_number->SetLineWidth(2); graph_frame_count->SetLineWidth(2); graph_pps_count->SetFillColor(0); graph_pps_event_counter->SetFillColor(0); graph_pps_accumulated_number_vs_psec_timestamp->SetFillColor(0); + graph_pps_time_vs_accumulated_number->SetFillColor(0); graph_frame_count->SetFillColor(0); graph_pps_count->GetYaxis()->SetTitle("PPS Events"); graph_pps_event_counter->GetYaxis()->SetTitle("PPS Event Counter"); graph_pps_accumulated_number_vs_psec_timestamp->GetYaxis()->SetTitle("PPS Accumulated Number"); + graph_pps_time_vs_accumulated_number->GetYaxis()->SetTitle("PPS Accumulated Number"); graph_frame_count->GetYaxis()->SetTitle("Data Events"); graph_pps_count->GetXaxis()->SetTimeDisplay(1); graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeDisplay(1); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeDisplay(1); graph_frame_count->GetXaxis()->SetTimeDisplay(1); graph_pps_count->GetXaxis()->SetLabelSize(0.03); graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelSize(0.03); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelSize(0.03); graph_frame_count->GetXaxis()->SetLabelSize(0.03); graph_pps_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelOffset(0.03); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelOffset(0.03); graph_frame_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_frame_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); // Multi-Graphs @@ -1087,6 +1099,7 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; std::vector *t_pps_accumulated_number = new std::vector; // Accumulated PPS event number, taken from current_pps_count, std::vector *t_pps_accumulated_psec_timestamp = new std::vector; + std::vector *t_raw_lappd_data_pps_timestamp_per_accumulated_number = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; @@ -1119,6 +1132,7 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); t->SetBranchAddress("pps_accumulated_number", &t_pps_accumulated_number); t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); + t->SetBranchAddress("raw_lappd_data_pps_timestamp_per_accumulated_number", &t_raw_lappd_data_pps_timestamp_per_accumulated_number); } else { @@ -1146,6 +1160,7 @@ void MonitorLAPPDData::WriteToFile() t->Branch("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); t->Branch("pps_accumulated_number", &t_pps_accumulated_number); t->Branch("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); + t->Branch("raw_lappd_data_pps_timestamp_per_accumulated_number", &t_raw_lappd_data_pps_timestamp_per_accumulated_number); } int n_entries = t->GetEntries(); @@ -1183,6 +1198,7 @@ void MonitorLAPPDData::WriteToFile() delete t_raw_lappd_data_pps_timestamps; delete t_pps_accumulated_number; delete t_pps_accumulated_psec_timestamp; + delete t_raw_lappd_data_pps_timestamp_per_accumulated_number; delete f; gROOT->cd(); @@ -1239,6 +1255,10 @@ void MonitorLAPPDData::WriteToFile() m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); // Cast PSec timestamp to long, then push it t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); + + // Push the latest LAPPD PPS timestamp, as we will use it to plot against accumulated PPS event number + auto current_raw_lappd_pps_timestamp = raw_lappd_data_pps_timestamps.back(); + t_raw_lappd_data_pps_timestamp_per_accumulated_number->push_back(current_raw_lappd_pps_timestamp); } for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) @@ -1291,6 +1311,7 @@ void MonitorLAPPDData::WriteToFile() delete t_sigma; delete t_raw_lappd_data_pps_counts; delete t_raw_lappd_data_pps_timestamps; + delete t_raw_lappd_data_pps_timestamp_per_accumulated_number; delete f; gROOT->cd(); @@ -1403,6 +1424,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; std::vector *t_pps_accumulated_number = new std::vector; std::vector *t_pps_accumulated_psec_timestamp = new std::vector; + std::vector *t_raw_lappd_data_pps_timestamp_per_accumulated_number = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; @@ -1432,6 +1454,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); t->SetBranchAddress("pps_accumulated_number", &t_pps_accumulated_number); t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); + t->SetBranchAddress("raw_lappd_data_pps_timestamp_per_accumulated_number", &t_raw_lappd_data_pps_timestamp_per_accumulated_number); nentries_tree = t->GetEntries(); @@ -1518,6 +1541,10 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) for (int i = 0; i < t_pps_accumulated_psec_timestamp->size(); i++) { pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp->at(i)); pps_accumulated_number.push_back(t_pps_accumulated_number->at(i)); + + // This and the vectors above the same length, as they are both added in an accumulated fashion, + // so we can just add them together + raw_lappd_data_pps_timestamp_per_accumulated_number.push_back(t_raw_lappd_data_pps_timestamp_per_accumulated_number->at(i)); } // Delete vectors, if we have any @@ -2441,6 +2468,10 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl auto acc_timestamp = pps_accumulated_psec_timestamp.at(i_timestamp); auto acc_number = pps_accumulated_number.at(i_timestamp); graph_pps_accumulated_number_vs_psec_timestamp->SetPoint(i_timestamp, acc_timestamp, acc_number); + + // Also add graph points for PPS time vs accumulated number + auto acc_pps_timestamp_to_e13 = (double)raw_lappd_data_pps_timestamp_per_accumulated_number.at(i_timestamp) / pow(10, 13); + graph_pps_time_vs_accumulated_number->SetPoint(i_timestamp, acc_number, acc_pps_timestamp_to_e13); } std::stringstream ss_pps_count; @@ -2499,9 +2530,26 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeOffset(0.); graph_pps_accumulated_number_vs_psec_timestamp->Draw("apl"); std::stringstream ss_pps_accumulated_number_vs_psec_timestamp_path; - ss_pps_accumulated_number_vs_psec_timestamp_path << outpath << "LAPPDData_TimeEvolution_PPSAccumulatedNumber_vsPsecTimestamp_" << file_ending << "." << img_extension; + ss_pps_accumulated_number_vs_psec_timestamp_path << outpath << "LAPPDData_TimeEvolution_PPSAccumulatedNumber_vs_PsecTimestamp_" << file_ending << "." << img_extension; canvas_pps_accumulated_number_vs_psec_timestamp->SaveAs(ss_pps_accumulated_number_vs_psec_timestamp_path.str().c_str()); + std::stringstream ss_pps_time_vs_accumulated_number; + ss_pps_time_vs_accumulated_number << "PPS time vs accumulated number time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); + canvas_pps_time_vs_accumulated_number->cd(); + canvas_pps_time_vs_accumulated_number->Clear(); + graph_pps_time_vs_accumulated_number->SetTitle(ss_pps_time_vs_accumulated_number.str().c_str()); + graph_pps_time_vs_accumulated_number->GetYaxis()->SetTitle("PPS timestamp ns (1e13)"); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTitle("PPS accumulated number"); + graph_pps_time_vs_accumulated_number->GetYaxis()->SetTimeDisplay(0); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeDisplay(0); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelSize(0.03); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelOffset(0.01); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeOffset(0.); + graph_pps_time_vs_accumulated_number->Draw("apl"); + std::stringstream ss_pps_time_vs_accumulated_number_path; + ss_pps_time_vs_accumulated_number_path << outpath << "LAPPDData_TimeEvolution_PPSTime_vs_AccumulatedNumber_" << file_ending << "." << img_extension; + canvas_pps_time_vs_accumulated_number->SaveAs(ss_pps_time_vs_accumulated_number_path.str().c_str()); + std::stringstream ss_frame_count; ss_frame_count << "Data events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_frame_count->cd(); diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index f25f3882f..7d3aae008 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -169,6 +169,7 @@ class MonitorLAPPDData: public Tool { std::vector raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds std::vector pps_accumulated_number; // PPS accumulated number of events std::vector pps_accumulated_psec_timestamp; // PSec timestamps of each PPS accumulated number + std::vector raw_lappd_data_pps_timestamp_per_accumulated_number; // PPS timestamp of each accumulated number std::vector first_entry; std::vector first_entry_pps; std::vector n_buffer; @@ -265,6 +266,7 @@ class MonitorLAPPDData: public Tool { TCanvas *canvas_pps_count = nullptr; TCanvas *canvas_pps_event_counter = nullptr; TCanvas *canvas_pps_accumulated_number_vs_psec_timestamp = nullptr; + TCanvas* canvas_pps_time_vs_accumulated_number = nullptr; //graphs std::map graph_pps_rate; @@ -277,6 +279,7 @@ class MonitorLAPPDData: public Tool { TGraph *graph_pps_count = nullptr; TGraph *graph_pps_event_counter = nullptr; TGraph *graph_pps_accumulated_number_vs_psec_timestamp = nullptr; + TGraph *graph_pps_time_vs_accumulated_number = nullptr; TGraph *graph_frame_count = nullptr; //multi-graphs From cfe3c515ab2c5973dfdff4e99c3f2d65f1312804 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 9 Sep 2024 17:12:25 +0000 Subject: [PATCH 18/34] fix: sum pps counts --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index d1c040d84..87cd63c72 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1249,7 +1249,11 @@ void MonitorLAPPDData::WriteToFile() } // Push accumulated PPS event number and PSec timestamp - t_pps_accumulated_number->push_back(current_pps_count); + int total_pps_count = current_pps_count; + for (int i_current = 0; i_current < t_pps_accumulated_number->size(); i_current++) { + total_pps_count += t_pps_accumulated_number->at(i_current); + } + t_pps_accumulated_number->push_back(total_pps_count); std::string psec_timestamp_string; // Get the PSecTimestamp given by ParseDataMonitoring tool m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); From ce3a9571b14b0d0231fd91f22ce8d33d5e1d148d Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 9 Sep 2024 17:33:59 +0000 Subject: [PATCH 19/34] fix: properly handle pps psec timestamps --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 87cd63c72..0a67fe21d 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2469,7 +2469,8 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // Add graph points for PPS accumulated number for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) { - auto acc_timestamp = pps_accumulated_psec_timestamp.at(i_timestamp); + // Convert timestamp to unix seconds + auto acc_timestamp = pps_accumulated_psec_timestamp.at(i_timestamp) / 1000; auto acc_number = pps_accumulated_number.at(i_timestamp); graph_pps_accumulated_number_vs_psec_timestamp->SetPoint(i_timestamp, acc_timestamp, acc_number); From 63886909f067097e19774f67fd8235705c995614 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 9 Sep 2024 18:45:21 +0000 Subject: [PATCH 20/34] fix: fix lappd pps timestamp --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 0a67fe21d..ac489c7c1 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1261,7 +1261,13 @@ void MonitorLAPPDData::WriteToFile() t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); // Push the latest LAPPD PPS timestamp, as we will use it to plot against accumulated PPS event number - auto current_raw_lappd_pps_timestamp = raw_lappd_data_pps_timestamps.back(); + long current_raw_lappd_pps_timestamp = 0; + for (int i_current = 0; i_current < (int)raw_lappd_data_pps_timestamps.size(); i_current++) { + long pps_timestamp = raw_lappd_data_pps_timestamps.at(i_current); + if (pps_timestamp > current_raw_lappd_pps_timestamp) { + current_raw_lappd_pps_timestamp = pps_timestamp; + } + } t_raw_lappd_data_pps_timestamp_per_accumulated_number->push_back(current_raw_lappd_pps_timestamp); } From 99e9a1b460456ed5955a4e209a83176e2402121e Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 9 Sep 2024 19:14:24 +0000 Subject: [PATCH 21/34] fix: handle duplicate timestamps in PPS event counter graph --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index ac489c7c1..31bfb9876 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2466,10 +2466,18 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // std::cout <<"pps_rate_plot.at(board_nr).size(): "< pps_event_counter_timestamps; // Add graph points for PPS event counter for (int i_timestamp = 0; i_timestamp < raw_lappd_data_pps_timestamps.size(); i_timestamp++) { double timestamp_to_e13 = (double)raw_lappd_data_pps_timestamps.at(i_timestamp) / pow(10, 13); + // skip if timestamp_to_e13 already exists + if (pps_event_counter_timestamps.count(timestamp_to_e13)) { + continue; + } + pps_event_counter_timestamps.insert(timestamp_to_e13); + + pps_event_counter_timestamps.insert(raw_lappd_data_pps_timestamps.at(i_timestamp)); graph_pps_event_counter->SetPoint(i_timestamp, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); } // Add graph points for PPS accumulated number @@ -3038,7 +3046,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ // Add pps count and timestamp for plotting raw_lappd_data_pps_counts.push_back(last_pps_count); - raw_lappd_data_pps_timestamps.push_back(pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds + raw_lappd_data_pps_timestamps.push_back((double)pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds } if (pps.size() == 32) From 4fb193b1d4632d0231ada4699b68276fd93bc85c Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Wed, 11 Sep 2024 19:16:34 +0000 Subject: [PATCH 22/34] fix: sum only preceding PPS accumulated number - We were previously summing all of the points recorded in PPS accumulated number vector, resulting in an exponential graph, which is incorrect. We now sum only the previous number - which creates a meaningful graph. --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 31bfb9876..bc55200e4 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1250,8 +1250,8 @@ void MonitorLAPPDData::WriteToFile() // Push accumulated PPS event number and PSec timestamp int total_pps_count = current_pps_count; - for (int i_current = 0; i_current < t_pps_accumulated_number->size(); i_current++) { - total_pps_count += t_pps_accumulated_number->at(i_current); + if (!t_pps_accumulated_number->empty()) { + total_pps_count += t_pps_accumulated_number->back(); } t_pps_accumulated_number->push_back(total_pps_count); std::string psec_timestamp_string; From ff5f44e1d541c5a49b4cc9a9784f51a187c04f64 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 30 Sep 2024 13:32:36 +0000 Subject: [PATCH 23/34] refactor: remove t_partrun condition when writing pps data --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 56 +++++++++---------- 1 file changed, 27 insertions(+), 29 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index bc55200e4..8488cc190 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1239,37 +1239,35 @@ void MonitorLAPPDData::WriteToFile() "MonitorLAPPDData: WriteToFile: Board " + std::to_string(current_board_index.at(i_current)) + ". Writing data to file: " + std::to_string(starttime_tm.tm_year + 1900) + "/" + std::to_string(starttime_tm.tm_mon + 1) + "/" + std::to_string(starttime_tm.tm_mday) + "-" + std::to_string(starttime_tm.tm_hour) + ":" + std::to_string(starttime_tm.tm_min) + ":" + std::to_string(starttime_tm.tm_sec), v_message, verbosity); } - // Once every partfun file - if (t_partrun < current_partrun) { - // Push raw lappd data - for (int i_current = 0; i_current < raw_lappd_data_pps_timestamps.size(); i_current++) - { - t_raw_lappd_data_pps_counts->push_back(raw_lappd_data_pps_counts.at(i_current)); - t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); - } - - // Push accumulated PPS event number and PSec timestamp - int total_pps_count = current_pps_count; - if (!t_pps_accumulated_number->empty()) { - total_pps_count += t_pps_accumulated_number->back(); - } - t_pps_accumulated_number->push_back(total_pps_count); - std::string psec_timestamp_string; - // Get the PSecTimestamp given by ParseDataMonitoring tool - m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); - // Cast PSec timestamp to long, then push it - t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); - - // Push the latest LAPPD PPS timestamp, as we will use it to plot against accumulated PPS event number - long current_raw_lappd_pps_timestamp = 0; - for (int i_current = 0; i_current < (int)raw_lappd_data_pps_timestamps.size(); i_current++) { - long pps_timestamp = raw_lappd_data_pps_timestamps.at(i_current); - if (pps_timestamp > current_raw_lappd_pps_timestamp) { - current_raw_lappd_pps_timestamp = pps_timestamp; - } + // Push raw lappd data + for (int i_current = 0; i_current < raw_lappd_data_pps_timestamps.size(); i_current++) + { + t_raw_lappd_data_pps_counts->push_back(raw_lappd_data_pps_counts.at(i_current)); + t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); + } + + // Push accumulated PPS event number and PSec timestamp + int total_pps_count = current_pps_count; + if (!t_pps_accumulated_number->empty()) { + total_pps_count += t_pps_accumulated_number->back(); + } + t_pps_accumulated_number->push_back(total_pps_count); + std::string psec_timestamp_string; + // Get the PSecTimestamp given by ParseDataMonitoring tool + m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); + // Cast PSec timestamp to long, then push it + t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); + + // Push the latest LAPPD PPS timestamp, as we will use it to plot against accumulated PPS event number + long current_raw_lappd_pps_timestamp = 0; + for (int i_current = 0; i_current < (int)raw_lappd_data_pps_timestamps.size(); i_current++) { + long pps_timestamp = raw_lappd_data_pps_timestamps.at(i_current); + if (pps_timestamp > current_raw_lappd_pps_timestamp) { + current_raw_lappd_pps_timestamp = pps_timestamp; } - t_raw_lappd_data_pps_timestamp_per_accumulated_number->push_back(current_raw_lappd_pps_timestamp); } + t_raw_lappd_data_pps_timestamp_per_accumulated_number->push_back(current_raw_lappd_pps_timestamp); + for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) { From a70c85aa58546fcceaabf109f357f56727b986e7 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 30 Sep 2024 13:42:03 +0000 Subject: [PATCH 24/34] refactor: remove code that divides pps timestamps to 1e13 - ROOT handles it anyway if the numbers get too big, so we don't need to do it --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 8488cc190..b7ca15592 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2468,15 +2468,15 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // Add graph points for PPS event counter for (int i_timestamp = 0; i_timestamp < raw_lappd_data_pps_timestamps.size(); i_timestamp++) { - double timestamp_to_e13 = (double)raw_lappd_data_pps_timestamps.at(i_timestamp) / pow(10, 13); - // skip if timestamp_to_e13 already exists - if (pps_event_counter_timestamps.count(timestamp_to_e13)) { + double timestamp = (double)raw_lappd_data_pps_timestamps.at(i_timestamp); + // skip if timestamp already exists + if (pps_event_counter_timestamps.count(timestamp)) { continue; } - pps_event_counter_timestamps.insert(timestamp_to_e13); + pps_event_counter_timestamps.insert(timestamp); pps_event_counter_timestamps.insert(raw_lappd_data_pps_timestamps.at(i_timestamp)); - graph_pps_event_counter->SetPoint(i_timestamp, timestamp_to_e13, raw_lappd_data_pps_counts.at(i_timestamp)); + graph_pps_event_counter->SetPoint(i_timestamp, timestamp, raw_lappd_data_pps_counts.at(i_timestamp)); } // Add graph points for PPS accumulated number for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) @@ -2487,8 +2487,8 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_accumulated_number_vs_psec_timestamp->SetPoint(i_timestamp, acc_timestamp, acc_number); // Also add graph points for PPS time vs accumulated number - auto acc_pps_timestamp_to_e13 = (double)raw_lappd_data_pps_timestamp_per_accumulated_number.at(i_timestamp) / pow(10, 13); - graph_pps_time_vs_accumulated_number->SetPoint(i_timestamp, acc_number, acc_pps_timestamp_to_e13); + auto acc_pps_timestamp = (double)raw_lappd_data_pps_timestamp_per_accumulated_number.at(i_timestamp); + graph_pps_time_vs_accumulated_number->SetPoint(i_timestamp, acc_number, acc_pps_timestamp); } std::stringstream ss_pps_count; @@ -2521,7 +2521,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_pps_event_counter->Clear(); graph_pps_event_counter->SetTitle(ss_pps_event_counter.str().c_str()); graph_pps_event_counter->GetYaxis()->SetTitle("PPS event counter"); - graph_pps_event_counter->GetXaxis()->SetTitle("ns (1e13)"); + graph_pps_event_counter->GetXaxis()->SetTitle("ns"); graph_pps_event_counter->GetXaxis()->SetTimeDisplay(0); graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.01); From 6bcba6d48f23b40e00ec3dfcc02e03798098db7f Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 30 Sep 2024 16:17:48 +0000 Subject: [PATCH 25/34] fix: iterate through all entries of root file when reading raw pps data --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 30 +++++++++---------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index b7ca15592..4f73b92c2 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1430,7 +1430,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; - std::vector *t_pps_accumulated_number = new std::vector; + std::vector *t_pps_accumulated_number = new std::vector; std::vector *t_pps_accumulated_psec_timestamp = new std::vector; std::vector *t_raw_lappd_data_pps_timestamp_per_accumulated_number = new std::vector; @@ -1540,21 +1540,23 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) } } } + for (int i_entry = 0; i_entry < nentries_tree; i_entry++) + { + t->GetEntry(i_entry); + for (int i = 0; i < t_raw_lappd_data_pps_timestamps->size(); i++) { + raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); + raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); + } - for (int i = 0; i < t_raw_lappd_data_pps_timestamps->size(); i++) { - raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); - raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); - } - - for (int i = 0; i < t_pps_accumulated_psec_timestamp->size(); i++) { - pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp->at(i)); - pps_accumulated_number.push_back(t_pps_accumulated_number->at(i)); + for (int i = 0; i < t_pps_accumulated_psec_timestamp->size(); i++) { + pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp->at(i)); + pps_accumulated_number.push_back(t_pps_accumulated_number->at(i)); - // This and the vectors above the same length, as they are both added in an accumulated fashion, - // so we can just add them together - raw_lappd_data_pps_timestamp_per_accumulated_number.push_back(t_raw_lappd_data_pps_timestamp_per_accumulated_number->at(i)); + // This and the vectors above the same length, as they are both added in an accumulated fashion, + // so we can just add them together + raw_lappd_data_pps_timestamp_per_accumulated_number.push_back(t_raw_lappd_data_pps_timestamp_per_accumulated_number->at(i)); + } } - // Delete vectors, if we have any delete t_time; delete t_end; @@ -2474,8 +2476,6 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl continue; } pps_event_counter_timestamps.insert(timestamp); - - pps_event_counter_timestamps.insert(raw_lappd_data_pps_timestamps.at(i_timestamp)); graph_pps_event_counter->SetPoint(i_timestamp, timestamp, raw_lappd_data_pps_counts.at(i_timestamp)); } // Add graph points for PPS accumulated number From 8bb267f2507061170c8358113beba070cbfdf8ae Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 30 Sep 2024 17:03:56 +0000 Subject: [PATCH 26/34] refactor: migrate some pps vectors to variables - turns out i didn't need to store some of the properties in vectors, as entries kind of do the same --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 56 ++++++------------- 1 file changed, 17 insertions(+), 39 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 4f73b92c2..28a3f4fbf 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1085,7 +1085,6 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_time = new std::vector; std::vector *t_end = new std::vector; std::vector *t_pps_rate = new std::vector; - std::vector *t_pps_event_counter = new std::vector; std::vector *t_frame_rate = new std::vector; std::vector *t_beamgate_rate = new std::vector; std::vector *t_int_charge = new std::vector; @@ -1097,12 +1096,10 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; - std::vector *t_pps_accumulated_number = new std::vector; // Accumulated PPS event number, taken from current_pps_count, - std::vector *t_pps_accumulated_psec_timestamp = new std::vector; - std::vector *t_raw_lappd_data_pps_timestamp_per_accumulated_number = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; + long t_raw_lappd_pps_timestamp, t_pps_accumulated_psec_timestamp; ULong64_t t_lappd_offset; TTree *t; @@ -1130,9 +1127,8 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("lappd_offset", &t_lappd_offset); t->SetBranchAddress("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); - t->SetBranchAddress("pps_accumulated_number", &t_pps_accumulated_number); t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); - t->SetBranchAddress("raw_lappd_data_pps_timestamp_per_accumulated_number", &t_raw_lappd_data_pps_timestamp_per_accumulated_number); + t->SetBranchAddress("raw_lappd_pps_timestamp", &t_raw_lappd_pps_timestamp); } else { @@ -1158,9 +1154,8 @@ void MonitorLAPPDData::WriteToFile() t->Branch("lappd_offset", &t_lappd_offset); t->Branch("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); t->Branch("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); - t->Branch("pps_accumulated_number", &t_pps_accumulated_number); t->Branch("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); - t->Branch("raw_lappd_data_pps_timestamp_per_accumulated_number", &t_raw_lappd_data_pps_timestamp_per_accumulated_number); + t->Branch("raw_lappd_pps_timestamp", &t_raw_lappd_pps_timestamp); } int n_entries = t->GetEntries(); @@ -1196,9 +1191,6 @@ void MonitorLAPPDData::WriteToFile() delete t_sigma; delete t_raw_lappd_data_pps_counts; delete t_raw_lappd_data_pps_timestamps; - delete t_pps_accumulated_number; - delete t_pps_accumulated_psec_timestamp; - delete t_raw_lappd_data_pps_timestamp_per_accumulated_number; delete f; gROOT->cd(); @@ -1219,6 +1211,8 @@ void MonitorLAPPDData::WriteToFile() t_rate->clear(); t_ped->clear(); t_sigma->clear(); + t_raw_lappd_data_pps_counts->clear(); + t_raw_lappd_data_pps_timestamps->clear(); // Get data that was processed for (int i_current = 0; i_current < (int)current_pps_rate.size(); i_current++) @@ -1247,27 +1241,19 @@ void MonitorLAPPDData::WriteToFile() } // Push accumulated PPS event number and PSec timestamp - int total_pps_count = current_pps_count; - if (!t_pps_accumulated_number->empty()) { - total_pps_count += t_pps_accumulated_number->back(); - } - t_pps_accumulated_number->push_back(total_pps_count); std::string psec_timestamp_string; // Get the PSecTimestamp given by ParseDataMonitoring tool m_data->CStore.Get("PSecTimestamp", psec_timestamp_string); // Cast PSec timestamp to long, then push it - t_pps_accumulated_psec_timestamp->push_back(std::stol(psec_timestamp_string)); + t_pps_accumulated_psec_timestamp = std::stol(psec_timestamp_string); // Push the latest LAPPD PPS timestamp, as we will use it to plot against accumulated PPS event number - long current_raw_lappd_pps_timestamp = 0; for (int i_current = 0; i_current < (int)raw_lappd_data_pps_timestamps.size(); i_current++) { long pps_timestamp = raw_lappd_data_pps_timestamps.at(i_current); - if (pps_timestamp > current_raw_lappd_pps_timestamp) { - current_raw_lappd_pps_timestamp = pps_timestamp; + if (pps_timestamp > t_raw_lappd_pps_timestamp) { + t_raw_lappd_pps_timestamp = pps_timestamp; } } - t_raw_lappd_data_pps_timestamp_per_accumulated_number->push_back(current_raw_lappd_pps_timestamp); - for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) { @@ -1307,7 +1293,6 @@ void MonitorLAPPDData::WriteToFile() delete t_time; delete t_end; delete t_pps_rate; - delete t_pps_event_counter; delete t_frame_rate; delete t_beamgate_rate; delete t_int_charge; @@ -1319,7 +1304,6 @@ void MonitorLAPPDData::WriteToFile() delete t_sigma; delete t_raw_lappd_data_pps_counts; delete t_raw_lappd_data_pps_timestamps; - delete t_raw_lappd_data_pps_timestamp_per_accumulated_number; delete f; gROOT->cd(); @@ -1430,12 +1414,10 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; - std::vector *t_pps_accumulated_number = new std::vector; - std::vector *t_pps_accumulated_psec_timestamp = new std::vector; - std::vector *t_raw_lappd_data_pps_timestamp_per_accumulated_number = new std::vector; - + int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; + long t_raw_lappd_pps_timestamp, t_pps_accumulated_psec_timestamp; ULong64_t t_lappd_offset; int nentries_tree; @@ -1460,9 +1442,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("lappd_offset", &t_lappd_offset); t->SetBranchAddress("raw_lappd_data_pps_counts", &t_raw_lappd_data_pps_counts); t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); - t->SetBranchAddress("pps_accumulated_number", &t_pps_accumulated_number); t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); - t->SetBranchAddress("raw_lappd_data_pps_timestamp_per_accumulated_number", &t_raw_lappd_data_pps_timestamp_per_accumulated_number); + t->SetBranchAddress("raw_lappd_pps_timestamp", &t_raw_lappd_pps_timestamp); nentries_tree = t->GetEntries(); @@ -1540,6 +1521,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) } } } + int accumulated_pps_count = 0; for (int i_entry = 0; i_entry < nentries_tree; i_entry++) { t->GetEntry(i_entry); @@ -1547,15 +1529,11 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); } - - for (int i = 0; i < t_pps_accumulated_psec_timestamp->size(); i++) { - pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp->at(i)); - pps_accumulated_number.push_back(t_pps_accumulated_number->at(i)); - - // This and the vectors above the same length, as they are both added in an accumulated fashion, - // so we can just add them together - raw_lappd_data_pps_timestamp_per_accumulated_number.push_back(t_raw_lappd_data_pps_timestamp_per_accumulated_number->at(i)); - } + + accumulated_pps_count += t_pps_count; + pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp); + pps_accumulated_number.push_back(accumulated_pps_count); + raw_lappd_data_pps_timestamp_per_accumulated_number.push_back(t_raw_lappd_pps_timestamp); } // Delete vectors, if we have any delete t_time; From 8a8bee38590c65605dfcade9128cfca027d224c9 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Mon, 30 Sep 2024 17:24:39 +0000 Subject: [PATCH 27/34] feat: accumulate pps number throughout multiple files --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 28a3f4fbf..f0ba12f9f 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1374,6 +1374,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) number_of_days = days_dataframe.days(); } + int accumulated_pps_count = 0; for (int i_day = 0; i_day <= number_of_days; i_day++) { @@ -1521,7 +1522,6 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) } } } - int accumulated_pps_count = 0; for (int i_entry = 0; i_entry < nentries_tree; i_entry++) { t->GetEntry(i_entry); @@ -1529,7 +1529,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); } - + accumulated_pps_count += t_pps_count; pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp); pps_accumulated_number.push_back(accumulated_pps_count); From 0d6800bc47696c1d53ce11c8123c0c08f761ae7e Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Thu, 10 Oct 2024 08:47:10 +0000 Subject: [PATCH 28/34] feat: add part file vs data events graph --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 87 ++++++++++++++++++- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 4 + 2 files changed, 88 insertions(+), 3 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index f0ba12f9f..770600541 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -358,6 +358,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() canvas_logfile_lappd = new TCanvas("canvas_logfile_lappd", "LAPPD File History", 900, 600); canvas_file_timestamp_lappd = new TCanvas("canvas_file_timestamp_lappd", "Timestamp Last File", 900, 600); canvas_events_per_channel = new TCanvas("canvas_events_per_channel", "LAPPD Events per Channel", 900, 600); + canvas_pf_vs_data_events = new TCanvas("canvas_pf_vs_data_events", "LAPPD PF# vs Data Events", 900, 600); canvas_ped_lappd = new TCanvas("canvas_ped_lappd", "LAPPD Pedestals", 900, 600); canvas_sigma_lappd = new TCanvas("canvas_sigma_lappd", "LAPPD Sigmas", 900, 600); canvas_rate_lappd = new TCanvas("canvas_rate_lappd", "LAPPD Rates", 900, 600); @@ -376,7 +377,6 @@ void MonitorLAPPDData::InitializeHistsLAPPD() hist_buffer_size_all = new TH2F("Buffer Size", "Buffer Size", numberOfChannels, 0, numberOfChannels, numberOfCards, 0, numberOfCards); hist_rate_threshold_all = new TH2F("Rate above threshold", "Rate above threshold", numberOfChannels, 0, numberOfChannels, numberOfCards, 0, numberOfCards); hist_events_per_channel = new TH2F("Events per Channel", "Events per Channel", numberOfChannels, 0, numberOfChannels, numberOfCards, 0, numberOfCards); - hist_pedestal_all->SetStats(0); hist_pedestal_difference_all->SetStats(0); hist_buffer_size_all->SetStats(0); @@ -1096,6 +1096,7 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; + std::vector *t_data_event_timestamps = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; @@ -1129,6 +1130,7 @@ void MonitorLAPPDData::WriteToFile() t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); t->SetBranchAddress("raw_lappd_pps_timestamp", &t_raw_lappd_pps_timestamp); + t->SetBranchAddress("data_event_timestamps", &t_data_event_timestamps); } else { @@ -1156,6 +1158,7 @@ void MonitorLAPPDData::WriteToFile() t->Branch("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); t->Branch("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); t->Branch("raw_lappd_pps_timestamp", &t_raw_lappd_pps_timestamp); + t->Branch("data_event_timestamps", &t_data_event_timestamps); } int n_entries = t->GetEntries(); @@ -1191,6 +1194,7 @@ void MonitorLAPPDData::WriteToFile() delete t_sigma; delete t_raw_lappd_data_pps_counts; delete t_raw_lappd_data_pps_timestamps; + delete t_data_event_timestamps; delete f; gROOT->cd(); @@ -1213,6 +1217,7 @@ void MonitorLAPPDData::WriteToFile() t_sigma->clear(); t_raw_lappd_data_pps_counts->clear(); t_raw_lappd_data_pps_timestamps->clear(); + t_data_event_timestamps->clear(); // Get data that was processed for (int i_current = 0; i_current < (int)current_pps_rate.size(); i_current++) @@ -1255,6 +1260,11 @@ void MonitorLAPPDData::WriteToFile() } } + // Push data event timestamps + for (int i_current = 0; i_current < (int)data_event_timestamps.size(); i_current++) { + t_data_event_timestamps->push_back(data_event_timestamps.at(i_current)); + } + for (int i_current = 0; i_current < (int)current_ped.size(); i_current++) { t_chkey->push_back(current_chkey.at(i_current)); @@ -1415,6 +1425,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_sigma = new std::vector; std::vector *t_raw_lappd_data_pps_counts = new std::vector; std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; + std::vector *t_data_event_timestamps = new std::vector; int t_run, t_subrun, t_partrun; int t_pps_count, t_frame_count; @@ -1445,6 +1456,7 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) t->SetBranchAddress("raw_lappd_data_pps_timestamps", &t_raw_lappd_data_pps_timestamps); t->SetBranchAddress("pps_accumulated_psec_timestamp", &t_pps_accumulated_psec_timestamp); t->SetBranchAddress("raw_lappd_pps_timestamp", &t_raw_lappd_pps_timestamp); + t->SetBranchAddress("data_event_timestamps", &t_data_event_timestamps); nentries_tree = t->GetEntries(); @@ -1530,6 +1542,12 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); } + // Initialise vector of timestamps per partrun + data_event_timestamps_per_partrun.emplace(t_partrun, std::vector()); + for (int i = 0; i < t_data_event_timestamps->size(); i++) { + data_event_timestamps_per_partrun.at(t_partrun).push_back(t_data_event_timestamps->at(i)); + } + accumulated_pps_count += t_pps_count; pps_accumulated_psec_timestamp.push_back(t_pps_accumulated_psec_timestamp); pps_accumulated_number.push_back(accumulated_pps_count); @@ -2469,6 +2487,46 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_time_vs_accumulated_number->SetPoint(i_timestamp, acc_number, acc_pps_timestamp); } + double max_allowed_data_timestamp_seconds = 250; + int max_partrun = 10; + double max_data_timestamp_seconds = .0; + std::vector hist_pf_vs_data_events_timestamps; + std::vector hist_pf_vs_data_events_partruns; + // Init graph points for PF# vs data events histogram + for (const auto &partrun_entry : data_event_timestamps_per_partrun) { + const int partrun = partrun_entry.first; + const auto& timestamps = partrun_entry.second; + max_partrun = std::max(max_partrun, partrun); + if (timestamps.size() > 0) { + const auto first_data_event_timestamp = timestamps.at(0); + + for (const auto& timestamp : timestamps) { + auto timestamp_ms_to_seconds = (timestamp - first_data_event_timestamp) / 1e9; + if (timestamp_ms_to_seconds > max_allowed_data_timestamp_seconds) { + continue; + } + + max_data_timestamp_seconds = std::max(max_data_timestamp_seconds, timestamp_ms_to_seconds); + + hist_pf_vs_data_events_timestamps.push_back(timestamp_ms_to_seconds); + hist_pf_vs_data_events_partruns.push_back(partrun); + } + } + } + int hist_bins_x = static_cast(max_data_timestamp_seconds) + 1; + int hist_bins_y = static_cast(max_partrun) + 1; + hist_pf_vs_data_events = new TH2F("PF# vs Data Events", "PF# vs Data Events", hist_bins_x, 0, hist_bins_x, hist_bins_y, 0, hist_bins_y); + hist_pf_vs_data_events->SetStats(0); + // Add graph boints + for (int i = 0; i < hist_pf_vs_data_events_timestamps.size(); i ++) { + const auto hist_timestamp = hist_pf_vs_data_events_timestamps.at(i); + const auto hist_partrun = hist_pf_vs_data_events_partruns.at(i); + if (hist_timestamp > max_data_timestamp_seconds) { + continue; + } + hist_pf_vs_data_events->Fill(hist_timestamp, hist_partrun, hist_pf_vs_data_events->GetBinContent(hist_timestamp, hist_partrun) + 1); + } + std::stringstream ss_pps_count; ss_pps_count << "PPS events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_pps_count->cd(); @@ -2533,7 +2591,7 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_pps_time_vs_accumulated_number->cd(); canvas_pps_time_vs_accumulated_number->Clear(); graph_pps_time_vs_accumulated_number->SetTitle(ss_pps_time_vs_accumulated_number.str().c_str()); - graph_pps_time_vs_accumulated_number->GetYaxis()->SetTitle("PPS timestamp ns (1e13)"); + graph_pps_time_vs_accumulated_number->GetYaxis()->SetTitle("PPS timestamp ns"); graph_pps_time_vs_accumulated_number->GetXaxis()->SetTitle("PPS accumulated number"); graph_pps_time_vs_accumulated_number->GetYaxis()->SetTimeDisplay(0); graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeDisplay(0); @@ -2545,6 +2603,23 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl ss_pps_time_vs_accumulated_number_path << outpath << "LAPPDData_TimeEvolution_PPSTime_vs_AccumulatedNumber_" << file_ending << "." << img_extension; canvas_pps_time_vs_accumulated_number->SaveAs(ss_pps_time_vs_accumulated_number_path.str().c_str()); + std::stringstream ss_pf_vs_data_events; + ss_pf_vs_data_events << "PF# vs Data Events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); + canvas_pf_vs_data_events->cd(); + canvas_pf_vs_data_events->Clear(); + hist_pf_vs_data_events->SetTitle(ss_pf_vs_data_events.str().c_str()); + hist_pf_vs_data_events->GetYaxis()->SetTitle("Part File Number"); + hist_pf_vs_data_events->GetXaxis()->SetTitle("PPS timestamp (seconds)"); + graph_pps_time_vs_accumulated_number->GetYaxis()->SetTimeDisplay(0); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeDisplay(0); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelSize(0.03); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelOffset(0.01); + graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeOffset(0.); + hist_pf_vs_data_events->Draw("colz"); + std::stringstream ss_pf_vs_data_events_path; + ss_pf_vs_data_events_path << outpath << "LAPPDData_TimeEvolution_PF_vs_DataEvents_" << file_ending << "." << img_extension; + canvas_pf_vs_data_events->SaveAs(ss_pf_vs_data_events_path.str().c_str()); + std::stringstream ss_frame_count; ss_frame_count << "Data events time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_frame_count->cd(); @@ -3022,7 +3097,12 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ // Add pps count and timestamp for plotting raw_lappd_data_pps_counts.push_back(last_pps_count); - raw_lappd_data_pps_timestamps.push_back((double)pps_63_0 * CLOCK_to_NSEC); // Use nanoseconds + + const auto timestamp_ns = (double)pps_63_0 * CLOCK_to_NSEC; // Use nanoseconds + raw_lappd_data_pps_timestamps.push_back(timestamp_ns); + + // Add data event timestamp + data_event_timestamps.push_back(timestamp_ns); } if (pps.size() == 32) @@ -3211,6 +3291,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ // std::cout << "bits_timestamp_63_0: " << bits_timestamp_63_0 << std::endl; beamgate_timestamp.push_back(beamgate_63_0); data_timestamp.push_back(timestamp_63_0); + data_event_timestamps.push_back((double)timestamp_63_0 * CLOCK_to_NSEC); // for (int i=0; i last_pps_timestamps; std::vector raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps std::vector raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds + std::vector data_event_timestamps; // Timestamp in nanoseconds + std::map> data_event_timestamps_per_partrun; // Timestamps grouped by partrun, used for Data events histogram std::vector pps_accumulated_number; // PPS accumulated number of events std::vector pps_accumulated_psec_timestamp; // PSec timestamps of each PPS accumulated number std::vector raw_lappd_data_pps_timestamp_per_accumulated_number; // PPS timestamp of each accumulated number @@ -259,6 +261,7 @@ class MonitorLAPPDData: public Tool { TCanvas *canvas_logfile_lappd = nullptr; TCanvas *canvas_file_timestamp_lappd = nullptr; TCanvas *canvas_events_per_channel = nullptr; + TCanvas *canvas_pf_vs_data_events = nullptr; TCanvas *canvas_ped_lappd = nullptr; TCanvas *canvas_sigma_lappd = nullptr; TCanvas *canvas_rate_lappd = nullptr; @@ -312,6 +315,7 @@ class MonitorLAPPDData: public Tool { TH2F* hist_rate_threshold_all = nullptr; TH1F *log_files_lappd; TH2F* hist_events_per_channel = nullptr; + TH2F* hist_pf_vs_data_events = nullptr; //text TText *text_data_title = nullptr; From 9ed1ab7a3bb14f4a1888468ecfa8c2995c9ab29c Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Fri, 25 Oct 2024 16:23:09 +0000 Subject: [PATCH 29/34] feat: store `PSECData.LAPPD_ID` in `ParseDataMonitoring` tool - `MonitorLAPPDData` also reads `LAPPD_ID` from `LAPPDTemp` now --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 2 ++ UserTools/ParseDataMonitoring/ParseDataMonitoring.cpp | 1 + 2 files changed, 3 insertions(+) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 770600541..7b3afc34a 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -3039,6 +3039,8 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ bool do_continue = false; if (entry_type == "PPS") { + int lappd_id; + Temp->Get("LAPPD_ID", lappd_id); std::vector::iterator it; int vector_idx = -1; current_pps_count++; diff --git a/UserTools/ParseDataMonitoring/ParseDataMonitoring.cpp b/UserTools/ParseDataMonitoring/ParseDataMonitoring.cpp index 9859502b0..cc4962d93 100644 --- a/UserTools/ParseDataMonitoring/ParseDataMonitoring.cpp +++ b/UserTools/ParseDataMonitoring/ParseDataMonitoring.cpp @@ -153,6 +153,7 @@ bool ParseDataMonitoring::Execute() TempData->Set("ACC",PDATA.AccInfoFrame); std::string str_pps = "PPS"; TempData->Set("Type",str_pps); + TempData->Set("LAPPD_ID",PDATA.LAPPD_ID); TempData->Save("LAPPDTemp"); TempData->Delete(); From 0c835fb0311249cd74ec9c2a782d90bd5cf1bcd3 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Tue, 5 Nov 2024 19:07:45 +0000 Subject: [PATCH 30/34] wip: seperate pps event counter by lappd id --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 126 ++++++++++-------- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 6 +- 2 files changed, 74 insertions(+), 58 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 7b3afc34a..cf5671ea2 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -749,19 +749,16 @@ void MonitorLAPPDData::InitializeHistsLAPPD() // Normal Graphs without board number graph_pps_count = new TGraph(); - graph_pps_event_counter = new TGraph(); graph_pps_accumulated_number_vs_psec_timestamp = new TGraph(); graph_pps_time_vs_accumulated_number = new TGraph(); graph_frame_count = new TGraph(); graph_pps_count->SetName("graph_pps_count"); - graph_pps_event_counter->SetName("graph_pps_event_counter"); graph_pps_accumulated_number_vs_psec_timestamp->SetName("graph_pps_accumulated_number_vs_psec_timestamp"); graph_pps_time_vs_accumulated_number->SetName("graph_pps_time_vs_accumulated_number"); graph_frame_count->SetName("graph_frame_count"); graph_pps_count->SetTitle("LAPPD PPS Events Time Evolution"); - graph_pps_event_counter->SetTitle("LAPPD PPS Event Counter Time Evolution"); graph_pps_accumulated_number_vs_psec_timestamp->SetTitle("LAPPD PPS Accumulated Number vs System Time"); graph_pps_time_vs_accumulated_number->SetTitle("LAPPD PPS Time vs Accumulated Number"); graph_frame_count->SetTitle("LAPPD Data Events Time Evolution"); @@ -773,55 +770,46 @@ void MonitorLAPPDData::InitializeHistsLAPPD() } graph_pps_count->SetMarkerColor(kBlack); - graph_pps_event_counter->SetMarkerColor(kBlack); graph_pps_accumulated_number_vs_psec_timestamp->SetMarkerColor(kBlack); graph_pps_time_vs_accumulated_number->SetMarkerColor(kBlack); graph_frame_count->SetMarkerColor(kBlack); graph_pps_count->SetLineColor(kBlack); - graph_pps_event_counter->SetLineColor(kBlack); graph_pps_accumulated_number_vs_psec_timestamp->SetLineColor(kBlack); graph_pps_time_vs_accumulated_number->SetLineColor(kBlack); graph_frame_count->SetLineColor(kBlack); graph_pps_count->SetLineWidth(2); - graph_pps_event_counter->SetLineWidth(2); graph_pps_accumulated_number_vs_psec_timestamp->SetLineWidth(2); graph_pps_time_vs_accumulated_number->SetLineWidth(2); graph_frame_count->SetLineWidth(2); graph_pps_count->SetFillColor(0); - graph_pps_event_counter->SetFillColor(0); graph_pps_accumulated_number_vs_psec_timestamp->SetFillColor(0); graph_pps_time_vs_accumulated_number->SetFillColor(0); graph_frame_count->SetFillColor(0); graph_pps_count->GetYaxis()->SetTitle("PPS Events"); - graph_pps_event_counter->GetYaxis()->SetTitle("PPS Event Counter"); graph_pps_accumulated_number_vs_psec_timestamp->GetYaxis()->SetTitle("PPS Accumulated Number"); graph_pps_time_vs_accumulated_number->GetYaxis()->SetTitle("PPS Accumulated Number"); graph_frame_count->GetYaxis()->SetTitle("Data Events"); graph_pps_count->GetXaxis()->SetTimeDisplay(1); - graph_pps_event_counter->GetXaxis()->SetTimeDisplay(1); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeDisplay(1); graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeDisplay(1); graph_frame_count->GetXaxis()->SetTimeDisplay(1); graph_pps_count->GetXaxis()->SetLabelSize(0.03); - graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelSize(0.03); graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelSize(0.03); graph_frame_count->GetXaxis()->SetLabelSize(0.03); graph_pps_count->GetXaxis()->SetLabelOffset(0.03); - graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.03); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetLabelOffset(0.03); graph_pps_time_vs_accumulated_number->GetXaxis()->SetLabelOffset(0.03); graph_frame_count->GetXaxis()->SetLabelOffset(0.03); graph_pps_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); - graph_pps_event_counter->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_pps_accumulated_number_vs_psec_timestamp->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_pps_time_vs_accumulated_number->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); graph_frame_count->GetXaxis()->SetTimeFormat("#splitline(%m/%d}{%H:%M}"); @@ -1094,8 +1082,8 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_rate = new std::vector; std::vector *t_ped = new std::vector; std::vector *t_sigma = new std::vector; - std::vector *t_raw_lappd_data_pps_counts = new std::vector; - std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; + std::map> *t_raw_lappd_data_pps_counts = new std::map>; + std::map> *t_raw_lappd_data_pps_timestamps = new std::map>; std::vector *t_data_event_timestamps = new std::vector; int t_run, t_subrun, t_partrun; @@ -1239,10 +1227,18 @@ void MonitorLAPPDData::WriteToFile() } // Push raw lappd data - for (int i_current = 0; i_current < raw_lappd_data_pps_timestamps.size(); i_current++) - { - t_raw_lappd_data_pps_counts->push_back(raw_lappd_data_pps_counts.at(i_current)); - t_raw_lappd_data_pps_timestamps->push_back(raw_lappd_data_pps_timestamps.at(i_current)); + for (auto it = raw_lappd_data_pps_timestamps.begin(); it != raw_lappd_data_pps_timestamps.end(); ++it) { + auto lappd_id = it->first; + auto current_pps_timestamps = it->second; + auto current_pps_counts = raw_lappd_data_pps_counts.at(lappd_id); + // Emplace if lappd_id is not in the map + t_raw_lappd_data_pps_counts->emplace(lappd_id, std::vector()); + t_raw_lappd_data_pps_timestamps->emplace(lappd_id, std::vector()); + for (int i_current = 0; i_current < current_pps_timestamps.size(); i_current++) + { + t_raw_lappd_data_pps_counts->at(lappd_id).push_back(current_pps_timestamps.at(i_current)); + t_raw_lappd_data_pps_timestamps->at(lappd_id).push_back(current_pps_counts.at(i_current)); + } } // Push accumulated PPS event number and PSec timestamp @@ -1253,10 +1249,12 @@ void MonitorLAPPDData::WriteToFile() t_pps_accumulated_psec_timestamp = std::stol(psec_timestamp_string); // Push the latest LAPPD PPS timestamp, as we will use it to plot against accumulated PPS event number - for (int i_current = 0; i_current < (int)raw_lappd_data_pps_timestamps.size(); i_current++) { - long pps_timestamp = raw_lappd_data_pps_timestamps.at(i_current); - if (pps_timestamp > t_raw_lappd_pps_timestamp) { - t_raw_lappd_pps_timestamp = pps_timestamp; + for (auto it = raw_lappd_data_pps_timestamps.begin(); it != raw_lappd_data_pps_timestamps.end(); ++it) { + const auto& timestamps = it->second; + for (const auto& pps_timestamp : timestamps) { + if (pps_timestamp > t_raw_lappd_pps_timestamp) { + t_raw_lappd_pps_timestamp = pps_timestamp; + } } } @@ -1423,8 +1421,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_rate = new std::vector; std::vector *t_ped = new std::vector; std::vector *t_sigma = new std::vector; - std::vector *t_raw_lappd_data_pps_counts = new std::vector; - std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; + std::map> *t_raw_lappd_data_pps_counts = new std::map>; + std::map> *t_raw_lappd_data_pps_timestamps = new std::map>; std::vector *t_data_event_timestamps = new std::vector; int t_run, t_subrun, t_partrun; @@ -1537,9 +1535,16 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) for (int i_entry = 0; i_entry < nentries_tree; i_entry++) { t->GetEntry(i_entry); - for (int i = 0; i < t_raw_lappd_data_pps_timestamps->size(); i++) { - raw_lappd_data_pps_timestamps.push_back(t_raw_lappd_data_pps_timestamps->at(i)); - raw_lappd_data_pps_counts.push_back(t_raw_lappd_data_pps_counts->at(i)); + for (auto it = t_raw_lappd_data_pps_timestamps->begin(); it != t_raw_lappd_data_pps_timestamps->end(); ++it) { + int lappd_id = it->first; + auto current_timestamps = it->second; + raw_lappd_data_pps_timestamps.emplace(lappd_id, std::vector()); + raw_lappd_data_pps_counts.emplace(lappd_id, std::vector()); + auto current_pps_counts = t_raw_lappd_data_pps_counts->at(lappd_id); + for (int i = 0; i < current_timestamps.size(); i++) { + raw_lappd_data_pps_timestamps.at(lappd_id).push_back(current_timestamps.at(i)); + raw_lappd_data_pps_counts.at(lappd_id).push_back(current_pps_counts.at(i)); + } } // Initialise vector of timestamps per partrun @@ -2380,7 +2385,6 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl } graph_pps_count->Set(0); - graph_pps_event_counter->Set(0); graph_pps_accumulated_number_vs_psec_timestamp->Set(0); graph_frame_count->Set(0); @@ -2462,17 +2466,16 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl // std::cout <<"pps_rate_plot.at(board_nr).size(): "< pps_event_counter_timestamps; + graph_pps_event_counter.clear(); // Add graph points for PPS event counter - for (int i_timestamp = 0; i_timestamp < raw_lappd_data_pps_timestamps.size(); i_timestamp++) - { - double timestamp = (double)raw_lappd_data_pps_timestamps.at(i_timestamp); - // skip if timestamp already exists - if (pps_event_counter_timestamps.count(timestamp)) { - continue; + for (auto it = raw_lappd_data_pps_timestamps.begin(); it != raw_lappd_data_pps_timestamps.end(); ++it) { + auto lappd_id = it->first; + auto timestamps = it->second; + for (int i_timestamp = 0; i_timestamp < timestamps.size(); i_timestamp++) + { + graph_pps_event_counter.emplace(lappd_id, new TGraph()); + graph_pps_event_counter.at(lappd_id)->SetPoint(i_timestamp, timestamps.at(i_timestamp), raw_lappd_data_pps_counts.at(lappd_id).at(i_timestamp)); } - pps_event_counter_timestamps.insert(timestamp); - graph_pps_event_counter->SetPoint(i_timestamp, timestamp, raw_lappd_data_pps_counts.at(i_timestamp)); } // Add graph points for PPS accumulated number for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) @@ -2553,22 +2556,27 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl std::stringstream ss_pps_event_counter; ss_pps_event_counter << "PPS event counter time evolution (last " << ss_timeframe.str() << "h) " << end_time.str(); - canvas_pps_event_counter->cd(); - canvas_pps_event_counter->Clear(); - graph_pps_event_counter->SetTitle(ss_pps_event_counter.str().c_str()); - graph_pps_event_counter->GetYaxis()->SetTitle("PPS event counter"); - graph_pps_event_counter->GetXaxis()->SetTitle("ns"); - graph_pps_event_counter->GetXaxis()->SetTimeDisplay(0); - graph_pps_event_counter->GetXaxis()->SetLabelSize(0.03); - graph_pps_event_counter->GetXaxis()->SetLabelOffset(0.01); - graph_pps_event_counter->GetXaxis()->SetTimeOffset(0.); - graph_pps_event_counter->SetMarkerSize(0.4F); - graph_pps_event_counter->SetMarkerColor(kBlue); - graph_pps_event_counter->SetMarkerStyle(kFullCircle); - graph_pps_event_counter->Draw("AP"); - std::stringstream ss_pps_event_counter_path; - ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_PPSEventCounter_" << file_ending << "." << img_extension; - canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); + for (auto it = graph_pps_event_counter.begin(); it != graph_pps_event_counter.end(); ++it) { + canvas_pps_event_counter->cd(); + canvas_pps_event_counter->Clear(); + auto lappd_id = it->first; + auto graph = it->second; + graph->Draw("apl"); + graph->SetTitle(ss_pps_event_counter.str().c_str()); + graph->GetYaxis()->SetTitle(("PPS event counter (LAPPD ID: " + std::to_string(lappd_id) + ")").c_str()); + graph->GetXaxis()->SetTitle("ns"); + graph->GetXaxis()->SetTimeDisplay(0); + graph->GetXaxis()->SetLabelSize(0.03); + graph->GetXaxis()->SetLabelOffset(0.01); + graph->GetXaxis()->SetTimeOffset(0.); + graph->SetMarkerSize(0.4F); + graph->SetMarkerColor(kBlue); + graph->SetMarkerStyle(kFullCircle); + graph->Draw("AP"); + std::stringstream ss_pps_event_counter_path; + ss_pps_event_counter_path << outpath << "LAPPDData_TimeEvolution_LAPPD_" << lappd_id << "_PPSEventCounter_" << file_ending << "." << img_extension; + canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); + } std::stringstream ss_pps_accumulated_number_vs_psec_timestamp; ss_pps_accumulated_number_vs_psec_timestamp << "PPS Accumulated Number vs System Time (last " << ss_timeframe.str() << "h) " << end_time.str(); @@ -3097,11 +3105,19 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ std::bitset<32> bits_pps_count_31_0(pps_count_31_0); last_pps_count = pps_count_31_0; + // Emplace if lappd_id is not in the map + if (raw_lappd_data_pps_counts.find(lappd_id) == raw_lappd_data_pps_counts.end()) { + raw_lappd_data_pps_counts.emplace(lappd_id, std::vector()); + } + if (raw_lappd_data_pps_timestamps.find(lappd_id) == raw_lappd_data_pps_timestamps.end()) { + raw_lappd_data_pps_timestamps.emplace(lappd_id, std::vector()); + } + // Add pps count and timestamp for plotting - raw_lappd_data_pps_counts.push_back(last_pps_count); + raw_lappd_data_pps_counts.at(lappd_id).push_back(last_pps_count); const auto timestamp_ns = (double)pps_63_0 * CLOCK_to_NSEC; // Use nanoseconds - raw_lappd_data_pps_timestamps.push_back(timestamp_ns); + raw_lappd_data_pps_timestamps.at(lappd_id).push_back(timestamp_ns); // Add data event timestamp data_event_timestamps.push_back(timestamp_ns); diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 8a4424684..274d6a987 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -165,8 +165,8 @@ class MonitorLAPPDData: public Tool { std::vector last_timestamp; std::vector first_pps_timestamps; std::vector last_pps_timestamps; - std::vector raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps - std::vector raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds + std::map> raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps + std::map> raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds std::vector data_event_timestamps; // Timestamp in nanoseconds std::map> data_event_timestamps_per_partrun; // Timestamps grouped by partrun, used for Data events histogram std::vector pps_accumulated_number; // PPS accumulated number of events @@ -280,7 +280,7 @@ class MonitorLAPPDData: public Tool { std::map graph_ped; std::map graph_sigma; TGraph *graph_pps_count = nullptr; - TGraph *graph_pps_event_counter = nullptr; + std::map graph_pps_event_counter; TGraph *graph_pps_accumulated_number_vs_psec_timestamp = nullptr; TGraph *graph_pps_time_vs_accumulated_number = nullptr; TGraph *graph_frame_count = nullptr; From c4b11d73226db51d0ad23c0532c7fdbb499f70bb Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Tue, 19 Nov 2024 20:19:20 +0000 Subject: [PATCH 31/34] feat: seperate pps event counter by lappd id --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 51 ++++++++++--------- 1 file changed, 26 insertions(+), 25 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index cf5671ea2..3044a194d 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -1082,8 +1082,8 @@ void MonitorLAPPDData::WriteToFile() std::vector *t_rate = new std::vector; std::vector *t_ped = new std::vector; std::vector *t_sigma = new std::vector; - std::map> *t_raw_lappd_data_pps_counts = new std::map>; - std::map> *t_raw_lappd_data_pps_timestamps = new std::map>; + std::vector *t_raw_lappd_data_pps_counts = new std::vector; + std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; std::vector *t_data_event_timestamps = new std::vector; int t_run, t_subrun, t_partrun; @@ -1231,13 +1231,15 @@ void MonitorLAPPDData::WriteToFile() auto lappd_id = it->first; auto current_pps_timestamps = it->second; auto current_pps_counts = raw_lappd_data_pps_counts.at(lappd_id); - // Emplace if lappd_id is not in the map - t_raw_lappd_data_pps_counts->emplace(lappd_id, std::vector()); - t_raw_lappd_data_pps_timestamps->emplace(lappd_id, std::vector()); - for (int i_current = 0; i_current < current_pps_timestamps.size(); i_current++) - { - t_raw_lappd_data_pps_counts->at(lappd_id).push_back(current_pps_timestamps.at(i_current)); - t_raw_lappd_data_pps_timestamps->at(lappd_id).push_back(current_pps_counts.at(i_current)); + + // Because ROOT doesn't support serializing std::map, we need to pack it ourselves + // to a vector + for (int i_current = 0; i_current < current_pps_timestamps.size(); i_current++) { + t_raw_lappd_data_pps_timestamps->push_back(lappd_id); + t_raw_lappd_data_pps_counts->push_back(lappd_id); + + t_raw_lappd_data_pps_timestamps->push_back(current_pps_timestamps.at(i_current)); + t_raw_lappd_data_pps_counts->push_back(current_pps_counts.at(i_current)); } } @@ -1421,8 +1423,8 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) std::vector *t_rate = new std::vector; std::vector *t_ped = new std::vector; std::vector *t_sigma = new std::vector; - std::map> *t_raw_lappd_data_pps_counts = new std::map>; - std::map> *t_raw_lappd_data_pps_timestamps = new std::map>; + std::vector *t_raw_lappd_data_pps_counts = new std::vector; + std::vector *t_raw_lappd_data_pps_timestamps = new std::vector; std::vector *t_data_event_timestamps = new std::vector; int t_run, t_subrun, t_partrun; @@ -1535,16 +1537,17 @@ void MonitorLAPPDData::ReadFromFile(ULong64_t timestamp, double time_frame) for (int i_entry = 0; i_entry < nentries_tree; i_entry++) { t->GetEntry(i_entry); - for (auto it = t_raw_lappd_data_pps_timestamps->begin(); it != t_raw_lappd_data_pps_timestamps->end(); ++it) { - int lappd_id = it->first; - auto current_timestamps = it->second; - raw_lappd_data_pps_timestamps.emplace(lappd_id, std::vector()); - raw_lappd_data_pps_counts.emplace(lappd_id, std::vector()); - auto current_pps_counts = t_raw_lappd_data_pps_counts->at(lappd_id); - for (int i = 0; i < current_timestamps.size(); i++) { - raw_lappd_data_pps_timestamps.at(lappd_id).push_back(current_timestamps.at(i)); - raw_lappd_data_pps_counts.at(lappd_id).push_back(current_pps_counts.at(i)); - } + + // Unpack vector to map + for (int i = 0; i < t_raw_lappd_data_pps_timestamps->size(); i += 2) { + // This could further be broken down to use a singular vector + // but I'd say the current solution is already hacky enough + auto lappd_id = t_raw_lappd_data_pps_timestamps->at(i); + auto pps_timestamp = t_raw_lappd_data_pps_timestamps->at(i + 1); + auto pps_count = t_raw_lappd_data_pps_counts->at(i + 1); + + raw_lappd_data_pps_timestamps[lappd_id].push_back(pps_timestamp); + raw_lappd_data_pps_counts[lappd_id].push_back(pps_count); } // Initialise vector of timestamps per partrun @@ -2471,15 +2474,13 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl for (auto it = raw_lappd_data_pps_timestamps.begin(); it != raw_lappd_data_pps_timestamps.end(); ++it) { auto lappd_id = it->first; auto timestamps = it->second; - for (int i_timestamp = 0; i_timestamp < timestamps.size(); i_timestamp++) - { + for (int i_timestamp = 0; i_timestamp < timestamps.size(); i_timestamp++) { graph_pps_event_counter.emplace(lappd_id, new TGraph()); graph_pps_event_counter.at(lappd_id)->SetPoint(i_timestamp, timestamps.at(i_timestamp), raw_lappd_data_pps_counts.at(lappd_id).at(i_timestamp)); } } // Add graph points for PPS accumulated number - for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) - { + for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) { // Convert timestamp to unix seconds auto acc_timestamp = pps_accumulated_psec_timestamp.at(i_timestamp) / 1000; auto acc_number = pps_accumulated_number.at(i_timestamp); From 34ae213aa91669d71c8d0f57f57cd45d80e62ea4 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Wed, 20 Nov 2024 21:29:02 +0000 Subject: [PATCH 32/34] wip: implement pps interval drift plot --- .../MonitorLAPPDData/MonitorLAPPDData.cpp | 77 ++++++++++++++++++- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 3 + 2 files changed, 79 insertions(+), 1 deletion(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 3044a194d..4c95ae901 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -365,6 +365,7 @@ void MonitorLAPPDData::InitializeHistsLAPPD() canvas_frame_count = new TCanvas("canvas_frame_count", "LAPPD Data Count", 900, 600); canvas_pps_count = new TCanvas("canvas_pps_count", "LAPPD PPS Count", 900, 600); canvas_pps_event_counter = new TCanvas("canvas_pps_event_counter", "LAPPD PPS Event Counter", 900, 600); + canvas_pps_interval_drift = new TCanvas("canvas_pps_interval_drift", "LAPPD PPS Interval Drift", 900, 600); canvas_pps_accumulated_number_vs_psec_timestamp = new TCanvas("canvas_pps_accumulated_number_vs_psec_timestamp", "LAPPD PPS Accumulated Number vs System Time", 900, 600); // PSec timestamp is also referred to as "System Time" canvas_pps_time_vs_accumulated_number = new TCanvas("canvas_pps_time_vs_accumulated_number", "LAPPD PPS Time vs Accumulated Number", 900, 600); // Histograms @@ -2479,6 +2480,37 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl graph_pps_event_counter.at(lappd_id)->SetPoint(i_timestamp, timestamps.at(i_timestamp), raw_lappd_data_pps_counts.at(lappd_id).at(i_timestamp)); } } + // Add graph points for PPS interval drift + graph_pps_interval_drift.clear(); + lappd_pps_interval_drift_distribution.clear(); + for (auto it = raw_lappd_data_pps_timestamps.begin(); it != raw_lappd_data_pps_timestamps.end(); ++it) { + auto lappd_id = it->first; + auto timestamps = it->second; + auto latest_pps_timestamp = timestamps.front(); + + lappd_pps_interval_drift_distribution[lappd_id] = {0, 0, 0}; + + for (int i_timestamp = 0; i_timestamp < timestamps.size(); i_timestamp++) { + graph_pps_interval_drift.emplace(lappd_id, new TH1F()); + + // Calculate t + auto curr_timestamp = timestamps.at(i_timestamp); + auto diff = timestamps.at(i_timestamp) - latest_pps_timestamp; + std::cout << "LAPPD ID: " << lappd_id << ", (t = " << diff << ", i: " << i_timestamp << ") for " << curr_timestamp << " - " << latest_pps_timestamp << std::endl; + graph_pps_interval_drift.at(lappd_id)->Fill(diff); + latest_pps_timestamp = curr_timestamp; + + // Fill in PPS interval drift distribution + if (diff == 0) { + lappd_pps_interval_drift_distribution[lappd_id].at(0)++; // For t = 0 + } else if (diff == 3.2e8 || (diff == 3.2e8 + 1) || (diff == 3.2e8 - 1)) { + lappd_pps_interval_drift_distribution[lappd_id].at(1)++; // For t = 3.2e8 +- 1 + } else { + lappd_pps_interval_drift_distribution[lappd_id].at(2)++; // For t = other + } + } + } + // Add graph points for PPS accumulated number for (int i_timestamp = 0; i_timestamp < pps_accumulated_psec_timestamp.size(); i_timestamp++) { // Convert timestamp to unix seconds @@ -2562,7 +2594,6 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_pps_event_counter->Clear(); auto lappd_id = it->first; auto graph = it->second; - graph->Draw("apl"); graph->SetTitle(ss_pps_event_counter.str().c_str()); graph->GetYaxis()->SetTitle(("PPS event counter (LAPPD ID: " + std::to_string(lappd_id) + ")").c_str()); graph->GetXaxis()->SetTitle("ns"); @@ -2579,6 +2610,50 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_pps_event_counter->SaveAs(ss_pps_event_counter_path.str().c_str()); } + // Draw PPS interval drift + for (auto it = graph_pps_interval_drift.begin(); it != graph_pps_interval_drift.end(); ++it) { + canvas_pps_interval_drift->cd(); + auto lappd_id = it->first; + auto graph = it->second; + graph->Draw("apl"); + graph->SetTitle(("PPS Interval Drift for LAPPD: " + std::to_string(lappd_id)).c_str()); + graph->GetYaxis()->SetTitle("PPS Interval Drift"); + graph->Draw("HIST"); + + auto dist = lappd_pps_interval_drift_distribution.at(lappd_id); + auto total_num_dist = dist.at(0) + dist.at(1) + dist.at(2); + auto frac0 = static_cast(dist.at(0)) / total_num_dist; // t = 0 + auto frac1 = static_cast(dist.at(1)) / total_num_dist; // t = 3.2e8 +- 1 + auto frac2 = static_cast(dist.at(2)) / total_num_dist; // t = other + + // Convert fractions to percentages with two decimal places + std::stringstream ss_frac0, ss_frac1, ss_frac2; + ss_frac0 << std::setprecision(2) << frac0 * 100.0; + ss_frac1 << std::setprecision(2) << frac1 * 100.0; + ss_frac2 << std::setprecision(2) << frac2 * 100.0; + + std::cout << "*************" << std::endl; + std::cout << "LAPPD ID: " << lappd_id << std::endl; + std::cout << "Total number of distributions: " << total_num_dist << std::endl; + std::cout << "Fraction of distributions with t = 0: " << frac0 << std::endl; + std::cout << "Fraction of distributions with t = 3.2e8 +- 1: " << frac1 << std::endl; + std::cout << "Fraction of distributions with t = other: " << frac2 << std::endl; + + auto latex_frac0 = new TLatex(0.15, 0.75, ("(#Delta t = 0): " + ss_frac0.str() + "%").c_str()); + latex_frac0->SetNDC(); + latex_frac0->Draw("SAME"); + auto latex_frac1 = new TLatex(0.15, 0.70, ("(#Delta t = 3.2e8#pm1): " + ss_frac1.str() + "%").c_str()); + latex_frac1->SetNDC(); + latex_frac1->Draw("SAME"); + auto latex_frac2 = new TLatex(0.15, 0.65, ("Other: " + ss_frac2.str() + "%").c_str()); + latex_frac2->SetNDC(); + latex_frac2->Draw("SAME"); + + std::stringstream ss_pps_interval_drift_path; + ss_pps_interval_drift_path << outpath << "LAPPDData_TimeEvolution_LAPPD_" << lappd_id << "_PPSIntervalDrift_" << file_ending << "." << img_extension; + canvas_pps_interval_drift->SaveAs(ss_pps_interval_drift_path.str().c_str()); + } + std::stringstream ss_pps_accumulated_number_vs_psec_timestamp; ss_pps_accumulated_number_vs_psec_timestamp << "PPS Accumulated Number vs System Time (last " << ss_timeframe.str() << "h) " << end_time.str(); canvas_pps_accumulated_number_vs_psec_timestamp->cd(); diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 274d6a987..6f318b4f8 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -167,6 +167,7 @@ class MonitorLAPPDData: public Tool { std::vector last_pps_timestamps; std::map> raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps std::map> raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds + std::map> lappd_pps_interval_drift_distribution; // Maps LAPPD ID to vector of PPS interval drift distributions (t = 0, t = 3.2e8+-1, t = other) std::vector data_event_timestamps; // Timestamp in nanoseconds std::map> data_event_timestamps_per_partrun; // Timestamps grouped by partrun, used for Data events histogram std::vector pps_accumulated_number; // PPS accumulated number of events @@ -268,6 +269,7 @@ class MonitorLAPPDData: public Tool { TCanvas *canvas_frame_count = nullptr; TCanvas *canvas_pps_count = nullptr; TCanvas *canvas_pps_event_counter = nullptr; + TCanvas *canvas_pps_interval_drift = nullptr; TCanvas *canvas_pps_accumulated_number_vs_psec_timestamp = nullptr; TCanvas* canvas_pps_time_vs_accumulated_number = nullptr; @@ -281,6 +283,7 @@ class MonitorLAPPDData: public Tool { std::map graph_sigma; TGraph *graph_pps_count = nullptr; std::map graph_pps_event_counter; + std::map graph_pps_interval_drift; TGraph *graph_pps_accumulated_number_vs_psec_timestamp = nullptr; TGraph *graph_pps_time_vs_accumulated_number = nullptr; TGraph *graph_frame_count = nullptr; From c057b6fb73298be47e339b65400bffcd36545ad3 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Thu, 21 Nov 2024 13:32:41 +0000 Subject: [PATCH 33/34] refactor: store pps timestamps in clock, not nanoseconds --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 7 +++---- UserTools/MonitorLAPPDData/MonitorLAPPDData.h | 2 +- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 4c95ae901..78af823d1 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2476,8 +2476,9 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl auto lappd_id = it->first; auto timestamps = it->second; for (int i_timestamp = 0; i_timestamp < timestamps.size(); i_timestamp++) { + const auto timestamp = (double)timestamps.at(i_timestamp) * CLOCK_to_NSEC; graph_pps_event_counter.emplace(lappd_id, new TGraph()); - graph_pps_event_counter.at(lappd_id)->SetPoint(i_timestamp, timestamps.at(i_timestamp), raw_lappd_data_pps_counts.at(lappd_id).at(i_timestamp)); + graph_pps_event_counter.at(lappd_id)->SetPoint(i_timestamp, timestamp, raw_lappd_data_pps_counts.at(lappd_id).at(i_timestamp)); } } // Add graph points for PPS interval drift @@ -3191,9 +3192,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ // Add pps count and timestamp for plotting raw_lappd_data_pps_counts.at(lappd_id).push_back(last_pps_count); - - const auto timestamp_ns = (double)pps_63_0 * CLOCK_to_NSEC; // Use nanoseconds - raw_lappd_data_pps_timestamps.at(lappd_id).push_back(timestamp_ns); + raw_lappd_data_pps_timestamps.at(lappd_id).push_back(pps_63_0); // Add data event timestamp data_event_timestamps.push_back(timestamp_ns); diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h index 6f318b4f8..0e7417922 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.h +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.h @@ -166,7 +166,7 @@ class MonitorLAPPDData: public Tool { std::vector first_pps_timestamps; std::vector last_pps_timestamps; std::map> raw_lappd_data_pps_counts; // PPS event counters, indexed by all_timestamps - std::map> raw_lappd_data_pps_timestamps; // Timestamp in nanoseconds + std::map> raw_lappd_data_pps_timestamps; // Timestamp in CLOCK std::map> lappd_pps_interval_drift_distribution; // Maps LAPPD ID to vector of PPS interval drift distributions (t = 0, t = 3.2e8+-1, t = other) std::vector data_event_timestamps; // Timestamp in nanoseconds std::map> data_event_timestamps_per_partrun; // Timestamps grouped by partrun, used for Data events histogram From 9c13449ecacd37ea292d128355ac926708cd2867 Mon Sep 17 00:00:00 2001 From: Furkan Bilgin Date: Thu, 21 Nov 2024 14:55:51 +0000 Subject: [PATCH 34/34] fix: fix pps interval drift histogram --- UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp | 16 ++++++++-------- 1 file changed, 8 insertions(+), 8 deletions(-) diff --git a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp index 78af823d1..497f5c7c8 100644 --- a/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp +++ b/UserTools/MonitorLAPPDData/MonitorLAPPDData.cpp @@ -2490,21 +2490,21 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl auto latest_pps_timestamp = timestamps.front(); lappd_pps_interval_drift_distribution[lappd_id] = {0, 0, 0}; + graph_pps_interval_drift.emplace(lappd_id, new TH1F("", "", 200, -22e9, 30e9)); for (int i_timestamp = 0; i_timestamp < timestamps.size(); i_timestamp++) { - graph_pps_interval_drift.emplace(lappd_id, new TH1F()); - // Calculate t auto curr_timestamp = timestamps.at(i_timestamp); auto diff = timestamps.at(i_timestamp) - latest_pps_timestamp; - std::cout << "LAPPD ID: " << lappd_id << ", (t = " << diff << ", i: " << i_timestamp << ") for " << curr_timestamp << " - " << latest_pps_timestamp << std::endl; graph_pps_interval_drift.at(lappd_id)->Fill(diff); latest_pps_timestamp = curr_timestamp; - + + // std::cout << "LAPPD ID: " << lappd_id << ", (t = " << diff << ", i: " << i_timestamp << ") for " << curr_timestamp << " - " << latest_pps_timestamp << std::endl; + // Fill in PPS interval drift distribution if (diff == 0) { lappd_pps_interval_drift_distribution[lappd_id].at(0)++; // For t = 0 - } else if (diff == 3.2e8 || (diff == 3.2e8 + 1) || (diff == 3.2e8 - 1)) { + } else if (diff == 3.2e9 || (diff == 3.2e9 + 1) || (diff == 3.2e9 - 1)) { lappd_pps_interval_drift_distribution[lappd_id].at(1)++; // For t = 3.2e8 +- 1 } else { lappd_pps_interval_drift_distribution[lappd_id].at(2)++; // For t = other @@ -2616,9 +2616,9 @@ void MonitorLAPPDData::DrawTimeEvolutionLAPPDData(ULong64_t timestamp_end, doubl canvas_pps_interval_drift->cd(); auto lappd_id = it->first; auto graph = it->second; - graph->Draw("apl"); + graph->GetXaxis()->SetTitle("#Delta t_{pps} (clock ticks)"); + graph->GetYaxis()->SetTitle("Events (normalised)"); graph->SetTitle(("PPS Interval Drift for LAPPD: " + std::to_string(lappd_id)).c_str()); - graph->GetYaxis()->SetTitle("PPS Interval Drift"); graph->Draw("HIST"); auto dist = lappd_pps_interval_drift_distribution.at(lappd_id); @@ -3195,7 +3195,7 @@ LAPPDData->Get("AccInfoFrame", AccInfoFrame);*/ raw_lappd_data_pps_timestamps.at(lappd_id).push_back(pps_63_0); // Add data event timestamp - data_event_timestamps.push_back(timestamp_ns); + data_event_timestamps.push_back((double)pps_63_0 * CLOCK_to_NSEC); } if (pps.size() == 32)