From a796dfc53afa164c5bb397113c58f5dc0311475a Mon Sep 17 00:00:00 2001 From: Steven Doran <78985334+S81D@users.noreply.github.com> Date: Tue, 13 Jun 2023 10:14:19 -0500 Subject: [PATCH 01/31] Modification to the BeamFetcher Tool, adjusting for the SQL database now being in UTC (#233) * Update BeamFetcher.cpp The SQL database now displays times in UTC, so there is no longer a need to adjust the times from Chicago time, or shift the time if it is Daylight Savings. --- UserTools/BeamFetcher/BeamFetcher.cpp | 14 +++----------- UserTools/BeamFetcher/BeamFetcher.h | 2 -- 2 files changed, 3 insertions(+), 13 deletions(-) diff --git a/UserTools/BeamFetcher/BeamFetcher.cpp b/UserTools/BeamFetcher/BeamFetcher.cpp index 3b5d9d5fb..5cf2dfdab 100644 --- a/UserTools/BeamFetcher/BeamFetcher.cpp +++ b/UserTools/BeamFetcher/BeamFetcher.cpp @@ -25,7 +25,6 @@ bool BeamFetcher::Initialise(std::string config_filename, DataModel& data) // Default values timestamp_mode = "MSEC"; //Other option: LOCALDATE, DB - DaylightSavings = false; m_variables.Get("verbose", verbosity_); @@ -36,14 +35,7 @@ bool BeamFetcher::Initialise(std::string config_filename, DataModel& data) timestamp_mode = "MSEC"; } - bool got_daylight_savings = m_variables.Get("DaylightSavings",DaylightSavings); - if (DaylightSavings != 1 && DaylightSavings != 0){ - Log("Error: DaylightSavings setting "+std::to_string(DaylightSavings)+" not recognized" - "Setting default option 0",0,verbosity_); - DaylightSavings = 0; - } - TimeZoneShift = 21600000; - if (DaylightSavings) TimeZoneShift = 18000000; + bool got_runnumber = m_variables.Get("RunNumber",RunNumber); if (timestamp_mode == "DB"){ @@ -277,11 +269,11 @@ void BeamFetcher::ConvertDateToMSec(std::string start_str,std::string end_str,ui boost::posix_time::ptime ptime_start(boost::posix_time::time_from_string(start_str)); boost::posix_time::time_duration start_duration; start_duration = boost::posix_time::time_duration(ptime_start - Epoch); - start_ms = start_duration.total_milliseconds()+TimeZoneShift; + start_ms = start_duration.total_milliseconds(); boost::posix_time::time_duration end_duration; boost::posix_time::ptime ptime_end(boost::posix_time::time_from_string(end_str)); end_duration = boost::posix_time::time_duration(ptime_end - Epoch); - end_ms = end_duration.total_milliseconds()+TimeZoneShift; + end_ms = end_duration.total_milliseconds(); if (verbosity_ > 2) std::cout <<"BeamFetcher: start_ms: "<> RunInfoDB; int RunNumber; From 64a58c8ed5f5b80f721a8a295965aae9ab2e7249 Mon Sep 17 00:00:00 2001 From: JohannMartyn <133750974+JohannMartyn@users.noreply.github.com> Date: Tue, 13 Jun 2023 18:57:56 +0200 Subject: [PATCH 02/31] Improved the VME offset functions. Included if-statements to avoid NULL-pointer errors, included 16ns offset. Tested on BeamRuns from 12.22 to 03.23. (#235) Co-authored-by: Johann Martyn --- .../ANNIEEventBuilder/ANNIEEventBuilder.cpp | 166 ++++++++++-------- .../ANNIEEventBuilder/ANNIEEventBuilder.h | 6 +- 2 files changed, 92 insertions(+), 80 deletions(-) diff --git a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp index bf9ba6f78..69eed8596 100644 --- a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp +++ b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp @@ -1236,8 +1236,8 @@ void ANNIEEventBuilder::ProcessNewTankPMTData(){ m_data->CStore.Get("FileCompleted",FileCompleted); if (FileCompleted) force_all_entries = true; - if (save_raw_data) this->Correct8nsOffsetRaw(force_all_entries); - else this->Correct8nsOffset(force_all_entries); + if (save_raw_data) this->CorrectVMEOffsetRaw(force_all_entries); + else this->CorrectVMEOffset(force_all_entries); /// ------------------------------ ///---------RAW DATA case ---------- @@ -2793,9 +2793,9 @@ std::cout <<"***NEW BEST MATCH: min_dev: "< timestamps_tank; std::map timestamps_to_shift; @@ -2806,33 +2806,36 @@ void ANNIEEventBuilder::Correct8nsOffsetRaw(bool force_all_entries){ timestamps_tank.push_back(PMTCounterTimeNs); } - //Exclude the last five (most recent) entries, since those are probably still in progress - int number_entries = (timestamps_tank.size() > 6)? timestamps_tank.size() - 5 : 1; - if (force_all_entries) number_entries = (int) timestamps_tank.size(); - //Go through the list of PMT timestamps and look for abnormally close timestamps (8ns) //Start with the second entry and always compare to previous entry - for (int i_timestamp = 1; i_timestamp < number_entries; i_timestamp++){ + for (int i_timestamp = 1; i_timestamp < timestamps_tank.size(); i_timestamp++){ uint64_t FirstTS = timestamps_tank.at(i_timestamp-1); uint64_t SecondTS = timestamps_tank.at(i_timestamp); uint64_t TSDiff = (SecondTS > FirstTS)? (SecondTS-FirstTS) : (FirstTS-SecondTS); - uint64_t ExpectedOffset = 8; - if (TSDiff == ExpectedOffset){ - //if 8ns offset is detected, map the entry with less waveforms onto the one with more waveforms + if (TSDiff == 8 || TSDiff == 16){ + //if 8ns, 16ns offset is detected between the VME crates, map the entry with less waveforms onto the one with more waveforms int waveforms_first = int(InProgressTankEvents->at(FirstTS).size()); int waveforms_second = int(InProgressTankEvents->at(SecondTS).size()); bool first_entry_larger = (waveforms_first > waveforms_second); - Log("ANNIEEventBuilder: First TS = "+std::to_string(FirstTS)+", waveforms = "+std::to_string(waveforms_first)+", Second TS = "+std::to_string(SecondTS)+", waveforms = "+std::to_string(waveforms_second)+", first_entry_larger = "+std::to_string(first_entry_larger),v_debug,verbosity); + Log("ANNIEEventBuilder::CorrectVMEOffsetRaw: First TS = "+std::to_string(FirstTS)+", waveforms = "+std::to_string(waveforms_first)+", Second TS = "+std::to_string(SecondTS)+", waveforms = "+std::to_string(waveforms_second)+", first_entry_larger = "+std::to_string(first_entry_larger),v_debug,verbosity); if (first_entry_larger) timestamps_to_shift.emplace(SecondTS,FirstTS); else timestamps_to_shift.emplace(FirstTS,SecondTS); } + else if(TSDiff < 1600){ //For the log-file, to investigate why the processing does not produce Processed files + Log("ANNIEEventBuilder::CorrectVMEOffsetRaw: Gross missmatch in TSDiff = "+std::to_string(TSDiff),v_error,verbosity); + return; + } } //Go through the timestamps to shift and apply the correction for (std::map::iterator it=timestamps_to_shift.begin(); it!= timestamps_to_shift.end(); it++){ uint64_t FirstTS = it->first; uint64_t SecondTS = it->second; - Log("ANNIEEventBuilder: Map Timestamp "+std::to_string(FirstTS)+" to timestamp "+std::to_string(SecondTS),v_debug,verbosity); + Log("ANNIEEventBuilder::CorrectVMEOffsetRaw: Map Timestamp "+std::to_string(FirstTS)+" to timestamp "+std::to_string(SecondTS),v_debug,verbosity); + if(InProgressTankEvents->count(FirstTS) == 0 || InProgressTankEvents->count(SecondTS) == 0){ //map object at FirstTS, SecondTS may not exist yet + Log("ANNIEEventBuilder::CorrectVMEOffset: InProgressTankEvents->count(FirstTS) == "+std::to_string(InProgressTankEvents->count(FirstTS))+", InProgressTankEvents->count(SecondTS) == "+std::to_string(InProgressTankEvents->count(SecondTS)),v_debug,verbosity); + break; + } std::map, std::vector> FirstTankEvents = InProgressTankEvents->at(FirstTS); std::map, std::vector> SecondTankEvents = InProgressTankEvents->at(SecondTS); @@ -2848,9 +2851,9 @@ void ANNIEEventBuilder::Correct8nsOffsetRaw(bool force_all_entries){ } -void ANNIEEventBuilder::Correct8nsOffset(bool force_all_entries){ +void ANNIEEventBuilder::CorrectVMEOffset(bool force_all_entries){ - Log("ANNIEEventBuilder: Correct8nsOffset",v_message,verbosity); + Log("ANNIEEventBuilder: CorrectVMEOffset",v_message,verbosity); std::vector timestamps_tank; std::map timestamps_to_shift; @@ -2866,78 +2869,87 @@ void ANNIEEventBuilder::Correct8nsOffset(bool force_all_entries){ uint64_t FirstTS = timestamps_tank.at(i_timestamp-1); uint64_t SecondTS = timestamps_tank.at(i_timestamp); uint64_t TSDiff = (SecondTS > FirstTS)? (SecondTS-FirstTS) : (FirstTS-SecondTS); - uint64_t ExpectedOffset = 8; - if (TSDiff == ExpectedOffset){ - //if 8ns offset is detected, map the entry with less waveforms onto the one with more waveforms + if (TSDiff == 8 || TSDiff == 16){ + //if 8ns, 16ns offset is detected between the VME crates, map the entry with less waveforms onto the one with more waveforms int waveforms_first = int(InProgressHits->at(FirstTS)->size()); int waveforms_second = int(InProgressHits->at(SecondTS)->size()); bool first_entry_larger = (waveforms_first > waveforms_second); - Log("ANNIEEventBuilder: First TS = "+std::to_string(FirstTS)+", waveforms = "+std::to_string(waveforms_first)+", Second TS = "+std::to_string(SecondTS)+", waveforms = "+std::to_string(waveforms_second)+", first_entry_larger = "+std::to_string(first_entry_larger),v_debug,verbosity); + Log("ANNIEEventBuilder::CorrectVMEOffset: TSDiff = "+std::to_string(TSDiff)+", First TS = "+std::to_string(FirstTS)+", waveforms = "+std::to_string(waveforms_first)+", Second TS = "+std::to_string(SecondTS)+", waveforms = "+std::to_string(waveforms_second)+", first_entry_larger = "+std::to_string(first_entry_larger),v_debug,verbosity); if (first_entry_larger) timestamps_to_shift.emplace(SecondTS,FirstTS); else timestamps_to_shift.emplace(FirstTS,SecondTS); } + else if(TSDiff < 1600){ //For the log-file, to investigate why the processing does not produce Processed files + Log("ANNIEEventBuilder::CorrectVMEOffset: Gross missmatch in TSDiff = "+std::to_string(TSDiff),v_error,verbosity); + return; + } } //Go through the timestamps to shift and apply the correction - for (std::map::iterator it=timestamps_to_shift.begin(); it!= timestamps_to_shift.end(); it++){ - uint64_t FirstTS = it->first; - uint64_t SecondTS = it->second; - Log("ANNIEEventBuilder: Map Timestamp "+std::to_string(FirstTS)+" to timestamp "+std::to_string(SecondTS),v_debug,verbosity); - - //Get InProgress* {Hits, Chkey, and RecoADCHits} objects - std::map>* FirstTankHits = InProgressHits->at(FirstTS); - std::map>* SecondTankHits = InProgressHits->at(SecondTS); - std::vector FirstChankey = InProgressChkey->at(FirstTS); - std::vector SecondChankey = InProgressChkey->at(SecondTS); - std::map>* FirstTankHitsAux = InProgressHitsAux->at(FirstTS); - std::map>* SecondTankHitsAux = InProgressHitsAux->at(SecondTS); - std::map>> FirstRecoADCHits = InProgressRecoADCHits->at(FirstTS); - std::map>> SecondRecoADCHits = InProgressRecoADCHits->at(SecondTS); - std::map>> FirstRecoADCHitsAux = InProgressRecoADCHitsAux->at(FirstTS); - std::map>> SecondRecoADCHitsAux = InProgressRecoADCHitsAux->at(SecondTS); - - //Merge the two hits maps - SecondTankHits->insert(FirstTankHits->begin(), FirstTankHits->end()); - Log("ANNIEEventBuilder: Size of Merged Hits map: "+std::to_string(SecondTankHits->size()),v_debug,verbosity); - - //Merge the two aux hits maps - SecondTankHitsAux->insert(FirstTankHitsAux->begin(), FirstTankHitsAux->end()); - Log("ANNIEEventBuilder: Size of Merged AuxHits map: "+std::to_string(SecondTankHitsAux->size()),v_debug,verbosity); - - //Merge the two channelkey vectors - SecondChankey.insert(SecondChankey.end(), FirstChankey.begin(), FirstChankey.end()); - Log("ANNIEEventBuilder: Size of Merged Chkey vector: "+std::to_string(SecondChankey.size()),v_debug,verbosity); - - //Merge the two RecoADCHits maps - SecondRecoADCHits.insert(FirstRecoADCHits.begin(),FirstRecoADCHits.end()); - Log("ANNIEEventBuilder: Size of Merged RecoADCHits map: "+std::to_string(SecondRecoADCHits.size()),v_debug,verbosity); - - //Merge the two RecoADCHitsAux maps - SecondRecoADCHitsAux.insert(FirstRecoADCHitsAux.begin(),FirstRecoADCHitsAux.end()); - Log("ANNIEEventBuilder: Size of Merged RecoADCHitsAux map: "+std::to_string(SecondRecoADCHitsAux.size()),v_debug,verbosity); + if( InProgressHitsAux != NULL && InProgressRecoADCHitsAux != NULL ){ //InProgressHitsAux,InProgressRecoADCHitsAux may exist yet + for (std::map::iterator it=timestamps_to_shift.begin(); it!= timestamps_to_shift.end(); it++){ + uint64_t FirstTS = it->first; + uint64_t SecondTS = it->second; + Log("ANNIEEventBuilder::CorrectVMEOffset: Map Timestamp "+std::to_string(FirstTS)+" to timestamp "+std::to_string(SecondTS),v_debug,verbosity); + if(InProgressHits->count(FirstTS) == 0 || InProgressHits->count(SecondTS) == 0){ //map object at FirstTS, SecondTS may not exist yet + Log("ANNIEEventBuilder::CorrectVMEOffset: InProgressHits->count(FirstTS) == "+std::to_string(InProgressHits->count(FirstTS))+", InProgressHits->count(SecondTS) == "+std::to_string(InProgressHits->count(SecondTS)),v_debug,verbosity); + break; + } - //Associated merged map with preferred TS, delete other TS - (*InProgressHits)[SecondTS] = SecondTankHits; - InProgressHits->erase(FirstTS); - Log("ANNIEEventBuilder: Size of merged TS in InProgressHits: "+std::to_string(InProgressHits->at(SecondTS)->size()),v_debug,verbosity); - - (*InProgressHitsAux)[SecondTS] = SecondTankHitsAux; - InProgressHitsAux->erase(FirstTS); - Log("ANNIEEventBuilder: Size of merged TS in InProgressHitsAux: "+std::to_string(InProgressHitsAux->at(SecondTS)->size()),v_debug,verbosity); - - //Do the same for Chkey map - (*InProgressChkey)[SecondTS] = SecondChankey; - InProgressChkey->erase(FirstTS); - Log("ANNIEEventBuilder: Size of merged TS in InProgressChkey: "+std::to_string(InProgressChkey->at(SecondTS).size()),v_debug,verbosity); - - (*InProgressRecoADCHits)[SecondTS] = SecondRecoADCHits; - InProgressRecoADCHits->erase(FirstTS); - Log("ANNIEEventBuilder: Size of merged TS in InProgressRecoADCHits: "+std::to_string(InProgressRecoADCHits->at(SecondTS).size()),v_debug,verbosity); - - (*InProgressRecoADCHitsAux)[SecondTS] = SecondRecoADCHitsAux; - InProgressRecoADCHitsAux->erase(FirstTS); - Log("ANNIEEventBuilder: Size of merged TS in InProgressRecoADCHitsAux: "+std::to_string(InProgressRecoADCHitsAux->at(SecondTS).size()),v_debug,verbosity); + //Get InProgress* {Hits, Chkey, and RecoADCHits} objects + std::map>* FirstTankHits = InProgressHits->at(FirstTS); + std::map>* SecondTankHits = InProgressHits->at(SecondTS); + std::vector FirstChankey = InProgressChkey->at(FirstTS); + std::vector SecondChankey = InProgressChkey->at(SecondTS); + std::map>* FirstTankHitsAux = InProgressHitsAux->at(FirstTS); + std::map>* SecondTankHitsAux = InProgressHitsAux->at(SecondTS); + std::map>> FirstRecoADCHits = InProgressRecoADCHits->at(FirstTS); + std::map>> SecondRecoADCHits = InProgressRecoADCHits->at(SecondTS); + std::map>> FirstRecoADCHitsAux = InProgressRecoADCHitsAux->at(FirstTS); + std::map>> SecondRecoADCHitsAux = InProgressRecoADCHitsAux->at(SecondTS); + + //Merge the two hits maps + SecondTankHits->insert(FirstTankHits->begin(), FirstTankHits->end()); + Log("ANNIEEventBuilder: Size of Merged Hits map: "+std::to_string(SecondTankHits->size()),v_debug,verbosity); + + //Merge the two aux hits maps + SecondTankHitsAux->insert(FirstTankHitsAux->begin(), FirstTankHitsAux->end()); + Log("ANNIEEventBuilder: Size of Merged AuxHits map: "+std::to_string(SecondTankHitsAux->size()),v_debug,verbosity); + + //Merge the two channelkey vectors + SecondChankey.insert(SecondChankey.end(), FirstChankey.begin(), FirstChankey.end()); + Log("ANNIEEventBuilder: Size of Merged Chkey vector: "+std::to_string(SecondChankey.size()),v_debug,verbosity); + + //Merge the two RecoADCHits maps + SecondRecoADCHits.insert(FirstRecoADCHits.begin(),FirstRecoADCHits.end()); + Log("ANNIEEventBuilder: Size of Merged RecoADCHits map: "+std::to_string(SecondRecoADCHits.size()),v_debug,verbosity); + + //Merge the two RecoADCHitsAux maps + SecondRecoADCHitsAux.insert(FirstRecoADCHitsAux.begin(),FirstRecoADCHitsAux.end()); + Log("ANNIEEventBuilder: Size of Merged RecoADCHitsAux map: "+std::to_string(SecondRecoADCHitsAux.size()),v_debug,verbosity); + + //Associated merged map with preferred TS, delete other TS + (*InProgressHits)[SecondTS] = SecondTankHits; + InProgressHits->erase(FirstTS); + Log("ANNIEEventBuilder: Size of merged TS in InProgressHits: "+std::to_string(InProgressHits->at(SecondTS)->size()),v_debug,verbosity); + + (*InProgressHitsAux)[SecondTS] = SecondTankHitsAux; + InProgressHitsAux->erase(FirstTS); + Log("ANNIEEventBuilder: Size of merged TS in InProgressHitsAux: "+std::to_string(InProgressHitsAux->at(SecondTS)->size()),v_debug,verbosity); + + //Do the same for Chkey map + (*InProgressChkey)[SecondTS] = SecondChankey; + InProgressChkey->erase(FirstTS); + Log("ANNIEEventBuilder: Size of merged TS in InProgressChkey: "+std::to_string(InProgressChkey->at(SecondTS).size()),v_debug,verbosity); + + (*InProgressRecoADCHits)[SecondTS] = SecondRecoADCHits; + InProgressRecoADCHits->erase(FirstTS); + Log("ANNIEEventBuilder: Size of merged TS in InProgressRecoADCHits: "+std::to_string(InProgressRecoADCHits->at(SecondTS).size()),v_debug,verbosity); + + (*InProgressRecoADCHitsAux)[SecondTS] = SecondRecoADCHitsAux; + InProgressRecoADCHitsAux->erase(FirstTS); + Log("ANNIEEventBuilder: Size of merged TS in InProgressRecoADCHitsAux: "+std::to_string(InProgressRecoADCHitsAux->at(SecondTS).size()),v_debug,verbosity); + } } } diff --git a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.h b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.h index 44202aea3..69ab7dbd8 100644 --- a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.h +++ b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.h @@ -96,9 +96,9 @@ class ANNIEEventBuilder: public Tool { bool FetchWaveformsHits(); - //Functions to correct 8ns offset error - void Correct8nsOffsetRaw(bool force_all_entries); - void Correct8nsOffset(bool force_all_entries); + //Functions to correct VME crate offset error + void CorrectVMEOffsetRaw(bool force_all_entries); + void CorrectVMEOffset(bool force_all_entries); //Methods for getting all timestamps encountered by decoder tools void ProcessNewTankPMTData(); From cd9352a49ed5c5340272978b9a290d662c4fa54f Mon Sep 17 00:00:00 2001 From: rory42edwards <83559460+rory42edwards@users.noreply.github.com> Date: Thu, 29 Jun 2023 19:14:14 +0100 Subject: [PATCH 03/31] Stage1 data (#234) * Adding Stage1DataBuilder Tool * Set a default value for LAPPDPaused variable * Add documentation for Stage 1 data building * Add option to not save separate partfiles for Stage 1 Building * Add Stage1DataBuilder to DataDecoder * Remove unneccesary lines from Factory.cpp and Unity.h * Remove unnecessary printouts, clean up code, add in checks --- .../ANNIEEventBuilder/ANNIEEventBuilder.cpp | 44 ++++++- .../ANNIEEventBuilder/ANNIEEventBuilder.h | 3 + UserTools/ANNIEEventBuilder/README.md | 3 + UserTools/Factory/Factory.cpp | 1 + UserTools/LoadRawData/LoadRawData.cpp | 2 + UserTools/Stage1DataBuilder/README.md | 25 ++++ .../Stage1DataBuilder/Stage1DataBuilder.cpp | 110 ++++++++++++++++++ .../Stage1DataBuilder/Stage1DataBuilder.h | 50 ++++++++ UserTools/Unity.h | 1 + .../DataDecoder/ANNIEEventBuilderConfig | 5 +- .../DataDecoder/Stage1DataBuilderConfig | 3 + configfiles/DataDecoder/ToolsConfig | 1 + 12 files changed, 246 insertions(+), 2 deletions(-) create mode 100644 UserTools/Stage1DataBuilder/README.md create mode 100644 UserTools/Stage1DataBuilder/Stage1DataBuilder.cpp create mode 100644 UserTools/Stage1DataBuilder/Stage1DataBuilder.h create mode 100644 configfiles/DataDecoder/Stage1DataBuilderConfig diff --git a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp index 69eed8596..ecfadcd1a 100644 --- a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp +++ b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp @@ -49,6 +49,8 @@ bool ANNIEEventBuilder::Initialise(std::string configfile, DataModel &data){ m_variables.Get("SaveRawData",save_raw_data); m_variables.Get("StoreBeamStatus",store_beam_status); m_variables.Get("LAPPDOffsetFile",LAPPDOffsetFile); + m_variables.Get("BuildStage1Data",BuildStage1Data); + m_variables.Get("SaveSeparatePartfiles",SaveSeparatePartfiles); pause_threshold*=1E9; if(BuildType == "TankAndMRD" || BuildType == "TankAndMRDAndCTC" || BuildType == "TankAndMRDAndCTCAndLAPPD"){ @@ -108,6 +110,11 @@ bool ANNIEEventBuilder::Initialise(std::string configfile, DataModel &data){ bool ANNIEEventBuilder::Execute(){ + if(BuildStage1Data){ + m_data->Stores.at("ANNIEEvent")->Delete(); + m_data->Stores["ANNIEEvent"] = new BoostStore(false, 0); + } + bool NewEntryAvailable; m_data->CStore.Get("NewRawDataEntryAccessed",NewEntryAvailable); if(!NewEntryAvailable){ //Something went wrong processing raw data. Stop and save what's left @@ -189,6 +196,7 @@ bool ANNIEEventBuilder::Execute(){ this->BuildANNIEEventRunInfo(RunNumber,SubRunNumber,PartNumber,RunType,StarTime); this->BuildANNIEEventTankRaw(PMTCounterTime, aWaveMap); ANNIEEvent->Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(CurrentRunNum,CurrentSubRunNum,CurrentPartNum); //Erase this entry from the InProgressTankEventsMap if(verbosity>4) std::cout << "Counter time will be erased from InProgressTankEvents: " << PMTCounterTime << std::endl; @@ -210,6 +218,7 @@ bool ANNIEEventBuilder::Execute(){ this->BuildANNIEEventRunInfo(RunNumber,SubRunNumber,PartNumber,RunType,StarTime); this->BuildANNIEEventTankHits(PMTCounterTime, aFinishedHits, aFinishedRecoADCHits, aFinishedHitsAux, aFinishedRecoADCHitsAux, RawAcqSize); ANNIEEvent->Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(CurrentRunNum,CurrentSubRunNum,CurrentPartNum); //Erase this entry from the InProgressTankEventsMap if(verbosity>4) std::cout << "Counter time will be erased from InProgressTankEvents: " << PMTCounterTime << std::endl; @@ -293,6 +302,7 @@ bool ANNIEEventBuilder::Execute(){ this->BuildANNIEEventRunInfo(RunNumber,SubRunNumber,PartNumber,RunType,StarTime); this->BuildANNIEEventMRD(MRDHits, MRDTimeStamp, MRDTriggerType, beam_tdc, cosmic_tdc); ANNIEEvent->Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(RunNumber,SubRunNumber,PartNumber); //Erase this entry from the InProgressTankEventsMap MRDEventsToDelete.push_back(MRDTimeStamp); @@ -425,6 +435,7 @@ bool ANNIEEventBuilder::Execute(){ } this->BuildANNIEEventMRD(MRDHits, MRDTimeStamp, MRDTriggerType, beam_tdc, cosmic_tdc); ANNIEEvent->Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(CurrentRunNum,CurrentSubRunNum,CurrentPartNum); if(verbosity>4) std::cout << "BUILT AN ANNIE EVENT (TANK + MRD) SUCCESSFULLY" << std::endl; //Erase this entry from maps/vectors used when pairing completed events @@ -650,6 +661,7 @@ std::cout<at(CTCtimestamp); ANNIEEvent->Set("BeamStatus",beam_status); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("BeamStatus",beam_status); BeamStatusMap->erase(CTCtimestamp); } } @@ -725,6 +737,7 @@ std::cout<BuildANNIEEventLAPPD(empty_psec,default_lappdtimestamp,lappd_time_offset); } ANNIEEvent->Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(CurrentRunNum,CurrentSubRunNum,CurrentPartNum); if(verbosity>4) std::cout << "BUILT AN ANNIE EVENT (TANK + MRD + CTC) SUCCESSFULLY" << std::endl; } @@ -854,6 +867,7 @@ std::cout<at(CTCtimestamp); ANNIEEvent->Set("BeamStatus",beam_status); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("BeamStatus",beam_status); BeamStatusMap->erase(CTCtimestamp); } } @@ -880,6 +894,7 @@ std::cout<Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(CurrentRunNum,CurrentSubRunNum,CurrentPartNum); if(verbosity>4) std::cout << "BUILT AN ANNIE EVENT (TANK + CTC) SUCCESSFULLY" << std::endl; } @@ -1010,6 +1025,7 @@ std::cout<at(CTCtimestamp); ANNIEEvent->Set("BeamStatus",beam_status); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("BeamStatus",beam_status); BeamStatusMap->erase(CTCtimestamp); } } @@ -1030,6 +1046,7 @@ std::cout<Set("DataStreams",DataStreams); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("DataStreams",DataStreams); this->SaveEntryToFile(CurrentRunNum,CurrentSubRunNum,CurrentPartNum); if(verbosity>4) std::cout << "BUILT AN ANNIE EVENT (MRD + CTC) SUCCESSFULLY" << std::endl; } @@ -2306,10 +2323,14 @@ void ANNIEEventBuilder::BuildANNIEEventMRD(std::vectorsize()),v_debug,verbosity); ANNIEEvent->Set("TDCData",TDCData,true); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("TDCData",TDCData,true); TimeClass timeclass_timestamp(MRDTimeStamp); ANNIEEvent->Set("EventTimeMRD",timeclass_timestamp); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("EventTimeMRD",timeclass_timestamp); ANNIEEvent->Set("MRDTriggerType",MRDTriggerType); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("MRDTriggerType",MRDTriggerType); ANNIEEvent->Set("MRDLoopbackTDC",mrd_loopback_tdc); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("MRDLoopbackTDC",mrd_loopback_tdc); return; } @@ -2328,11 +2349,17 @@ void ANNIEEventBuilder::BuildANNIEEventRunInfo(int RunNumber, int SubRunNumber, { if(verbosity>v_message)std::cout << "Building an ANNIE Event Run Info" << std::endl; ANNIEEvent->Set("EventNumber",ANNIEEventNum); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("EventNumber",ANNIEEventNum); ANNIEEvent->Set("RunNumber",RunNumber); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RunNumber",RunNumber); ANNIEEvent->Set("SubrunNumber",SubRunNumber); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("SubrunNumber",SubRunNumber); ANNIEEvent->Set("PartNumber",PartNumber); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("PartNumber",PartNumber); ANNIEEvent->Set("RunType",RunType); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RunType",RunType); ANNIEEvent->Set("RunStartTime",StartTime); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RunStartTime",StartTime); return; } @@ -2340,8 +2367,11 @@ void ANNIEEventBuilder::BuildANNIEEventCTC(uint64_t CTCTime, uint32_t CTCWord, i { if(verbosity>v_message)std::cout << "Building an ANNIE Event CTC Info" << std::endl; ANNIEEvent->Set("CTCTimestamp",CTCTime); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("CTCTimestamp",CTCTime); ANNIEEvent->Set("TriggerWord",CTCWord); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("TriggerWord",CTCWord); ANNIEEvent->Set("TriggerExtended",CTCWordExtended); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("TriggerExtended",CTCWordExtended); //Build a TriggerClass object to be more in line with the ANNIEEvent spreadsheet TimeClass TriggerTime(CTCTime); std::string TriggerName = ""; @@ -2351,6 +2381,7 @@ void ANNIEEventBuilder::BuildANNIEEventCTC(uint64_t CTCTime, uint32_t CTCWord, i else if (CTCWord == 36) TriggerName = "MRDCR"; TriggerClass TriggerData(TriggerName,CTCWord,CTCWordExtended,true,TriggerTime); ANNIEEvent->Set("TriggerData",TriggerData); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("TriggerData",TriggerData); if (verbosity > 2) std::cout <<"Done setting ANNIE Event CTC Info"<Set("RawADCData",RawADCData); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RawADCData",RawADCData); ANNIEEvent->Set("RawADCAuxData",RawADCAuxData); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RawADCAuxData",RawADCAuxData); ANNIEEvent->Set("EventTimeTank",ClockTime); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("EventTimeTank",ClockTime); if(verbosity>v_debug) std::cout << "ANNIEEventBuilder: ANNIE Event "+ to_string(ANNIEEventNum)+" built." << std::endl; return; @@ -2415,11 +2449,17 @@ void ANNIEEventBuilder::BuildANNIEEventTankHits(uint64_t ClockTime, //std::cout << "Setting ANNIE Event information" << std::endl; ANNIEEvent->Set("Hits",PMTHits, true); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("Hits",PMTHits,true); ANNIEEvent->Set("RecoADCData",PMTRecoADCHits); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RecoADCData",PMTRecoADCHits); ANNIEEvent->Set("AuxHits",PMTHitsAux,true); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("AuxHits",PMTHitsAux,true); ANNIEEvent->Set("RecoAuxADCData",PMTRecoADCHitsAux); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RecoAuxADCData",PMTRecoADCHitsAux); ANNIEEvent->Set("RawAcqSize",PMTRawAcqSize); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("RawAcqSize",PMTRawAcqSize); ANNIEEvent->Set("EventTimeTank",ClockTime); + if (BuildStage1Data) m_data->Stores["ANNIEEvent"]->Set("EventTimeTank",ClockTime); if(verbosity>v_debug) std::cout << "ANNIEEventBuilder: ANNIE Event "+ to_string(ANNIEEventNum)+" built." << std::endl; return; @@ -2476,7 +2516,9 @@ void ANNIEEventBuilder::SaveEntryToFile(int RunNum, int SubRunNum, int PartNum) /*if(verbosity>4)*/ std::cout << "ANNIEEvent: Saving ANNIEEvent entry"+to_string(ANNIEEventNum) << std::endl; std::string Filename = SavePath + ProcessedFilesBasename + "_"+BuildType+"_R" + to_string(RunNum) + "S" + to_string(SubRunNum) + "p" + to_string(PartNum); - ANNIEEvent->Save(Filename); + if (SaveSeparatePartfiles) ANNIEEvent->Save(Filename); + std::cout<<"ANNIEEvent: "<Print(false); //std::cout <<"ANNIEEvent saved, now delete"<Delete(); //Delete() will delete the last entry in the store from memory and enable us to set a new pointer (won't erase the entry from saved file) //std::cout <<"ANNIEEvent deleted"<CStore.Set("FileProcessingComplete",false); return true; } diff --git a/UserTools/Stage1DataBuilder/README.md b/UserTools/Stage1DataBuilder/README.md new file mode 100644 index 000000000..6e4742de9 --- /dev/null +++ b/UserTools/Stage1DataBuilder/README.md @@ -0,0 +1,25 @@ +# Stage1DataBuilder +Stage1DataBuilder + +This tool is used to separate LAPPD data into separate BoostStores (1 per LAPPD), and save these with ANNIEEvent BoostStores created by DataDecoder upstream. + +## Data + +Describe any data formats Stage1DataBuilder creates, destroys, changes, or analyzes. E.G. + +LAPPD1Data (BoostStore) +ANNIEEvent_noLAPPD (BoostStore) +Stage1Data (multientry BoostStore) + +## Configuration + +Describe any configuration variables for Stage1DataBuilder. + +``` +verbosity (int) + +BaseName (string) +The base name of the output Stage1Data file + +RunNumber (int) +``` diff --git a/UserTools/Stage1DataBuilder/Stage1DataBuilder.cpp b/UserTools/Stage1DataBuilder/Stage1DataBuilder.cpp new file mode 100644 index 000000000..a2ffc9c8d --- /dev/null +++ b/UserTools/Stage1DataBuilder/Stage1DataBuilder.cpp @@ -0,0 +1,110 @@ +#include "Stage1DataBuilder.h" + +Stage1DataBuilder::Stage1DataBuilder():Tool(){} + + +bool Stage1DataBuilder::Initialise(std::string configfile, DataModel &data){ + + /////////////////// Useful header /////////////////////// + if(configfile!="") m_variables.Initialise(configfile); // loading config file + //m_variables.Print(); + + m_data= &data; //assigning transient data pointer + ///////////////////////////////////////////////////////////////// + + m_variables.Get("Verbosity",verbosity); + m_variables.Get("Basename",Basename); + + + Stage1Data = new BoostStore(false,2); + + return true; +} + + +bool Stage1DataBuilder::Execute(){ + Stage1Data->Delete(); + int RunNumber; + m_data->Stores.at("ANNIEEvent")->Get("RunNumber",RunNumber); + PsecData* LData = nullptr; + m_data->CStore.Get("LAPPDData",LData); + if (LData == nullptr){ + Log("No LAPPD Data retrieved from CStore! Moving on...", v_debug, verbosity); + return true; + } + if (verbosity > v_debug){ + std::cout<<"LData: "<Print(); + } + int lappdid = LData->LAPPD_ID; + Log("LAPPD ID: " + std::to_string(lappdid), v_debug, verbosity); + + std::string key = "LAPPD" + std::to_string(lappdid) + "Data"; + LAPPD1Data = new BoostStore(false,0); + LAPPD1Data->Set("LAPPDData",*LData); + Stage1Data->Set(key, LAPPD1Data); + + GetANNIEEvent(); + Stage1Data->Set("ANNIEEvent_noLAPPD",ANNIEEvent1); + + std::string filename = Basename + "R" + std::to_string(RunNumber); + Stage1Data->Save(filename); + + + return true; +} + + +bool Stage1DataBuilder::Finalise(){ + Stage1Data->Set("LAPPD0Data",LAPPD1Data); + Stage1Data->Set("ANNIEEvent_noLAPPD",ANNIEEvent1); + Stage1Data->Close(); + delete Stage1Data; + return true; +} + +void Stage1DataBuilder::GetANNIEEvent(){ + ANNIEEvent1->Delete(); + std::map> *AuxHits = nullptr; + std::map> *Hits = nullptr; + std::map> *TDCData = nullptr; + BeamStatus BeamStatus; + uint64_t CTCTimestamp, RunStartTime; + std::map DataStreams; + uint32_t EventNumber, TriggerWord; + TimeClass EventTimeMRD, EventTimeTank; + std::map MRDLoopbackTDC; + std::string MRDTriggerType; + std::map> RawAcqSize; + std::map>> RecoADCData, RecoAuxADCData; + int PartNumber, RunNumber, RunType, SubrunNumber, TriggerExtended; + TriggerClass TriggerData; + + + m_data->Stores["ANNIEEvent"]->Get("DataStreams",DataStreams); ANNIEEvent1->Set("DataStreams",DataStreams); + m_data->Stores["ANNIEEvent"]->Get("AuxHits",AuxHits); + if (AuxHits != nullptr) ANNIEEvent1->Set("AuxHits",AuxHits,true); + m_data->Stores["ANNIEEvent"]->Get("Hits",Hits); + if (Hits != nullptr) ANNIEEvent1->Set("Hits",Hits, true); + m_data->Stores["ANNIEEvent"]->Get("TDCData",TDCData); + if (TDCData != nullptr) ANNIEEvent1->Set("TDCData",TDCData,true); + + m_data->Stores["ANNIEEvent"]->Get("BeamStatus",BeamStatus); ANNIEEvent1->Set("BeamStatus",BeamStatus); + m_data->Stores["ANNIEEvent"]->Get("RunStartTime",RunStartTime); ANNIEEvent1->Set("RunStartTime",RunStartTime); + m_data->Stores["ANNIEEvent"]->Get("EventNumber",EventNumber); ANNIEEvent1->Set("EventNumber",EventNumber); + m_data->Stores["ANNIEEvent"]->Get("TriggerWord",TriggerWord); ANNIEEvent1->Set("TriggerWord",TriggerWord); + m_data->Stores["ANNIEEvent"]->Get("EventTimeMRD",EventTimeMRD); ANNIEEvent1->Set("EventTimeMRD",EventTimeMRD); + m_data->Stores["ANNIEEvent"]->Get("EventTimeTank",EventTimeTank); ANNIEEvent1->Set("EventTimeTank",EventTimeTank); + m_data->Stores["ANNIEEvent"]->Get("MRDLoopbackTDC",MRDLoopbackTDC); ANNIEEvent1->Set("MRDLoopbackTDC",MRDLoopbackTDC); + m_data->Stores["ANNIEEvent"]->Get("MRDTriggerType",MRDTriggerType); ANNIEEvent1->Set("MRDTriggerType",MRDTriggerType); + m_data->Stores["ANNIEEvent"]->Get("RawAcqSize",RawAcqSize); ANNIEEvent1->Set("RawAcqSize",RawAcqSize); + m_data->Stores["ANNIEEvent"]->Get("RecoADCData",RecoADCData); ANNIEEvent1->Set("RecoADCData",RecoADCData); + m_data->Stores["ANNIEEvent"]->Get("RecoAuxADCData",RecoAuxADCData); ANNIEEvent1->Set("RecoAuxADCData",RecoAuxADCData); + m_data->Stores["ANNIEEvent"]->Get("PartNumber",PartNumber); ANNIEEvent1->Set("PartNumber",PartNumber); + m_data->Stores["ANNIEEvent"]->Get("RunNumber",RunNumber); ANNIEEvent1->Set("RunNumber",RunNumber); + m_data->Stores["ANNIEEvent"]->Get("RunType",RunType); ANNIEEvent1->Set("RunType",RunType); + m_data->Stores["ANNIEEvent"]->Get("SubrunNumber",SubrunNumber); ANNIEEvent1->Set("SubrunNumber",SubrunNumber); + m_data->Stores["ANNIEEvent"]->Get("TriggerExtended",TriggerExtended); ANNIEEvent1->Set("TriggerExtended",TriggerExtended); + m_data->Stores["ANNIEEvent"]->Get("TriggerData",TriggerData); ANNIEEvent1->Set("TriggerData",TriggerData); + +} \ No newline at end of file diff --git a/UserTools/Stage1DataBuilder/Stage1DataBuilder.h b/UserTools/Stage1DataBuilder/Stage1DataBuilder.h new file mode 100644 index 000000000..d669be7c7 --- /dev/null +++ b/UserTools/Stage1DataBuilder/Stage1DataBuilder.h @@ -0,0 +1,50 @@ +#ifndef Stage1DataBuilder_H +#define Stage1DataBuilder_H + +#include +#include + +#include "Tool.h" +#include "BoostStore.h" +#include "PsecData.h" +#include "ADCPulse.h" + + +/** + * \class Stage1DataBuilder + * + * This is a blank template for a Tool used by the script to generate a new custom tool. Please fill out the description and author information. +* +* $Author: B.Richards $ +* $Date: 2019/05/28 10:44:00 $ +* Contact: b.richards@qmul.ac.uk +*/ +class Stage1DataBuilder: public Tool { + + + public: + + Stage1DataBuilder(); ///< Simple constructor + bool Initialise(std::string configfile,DataModel &data); ///< Initialise Function for setting up Tool resources. @param configfile The path and name of the dynamic configuration file to read in. @param data A reference to the transient data class used to pass information between Tools. + bool Execute(); ///< Execute function used to perform Tool purpose. + bool Finalise(); ///< Finalise function used to clean up resources. + void GetANNIEEvent(); + + + private: + int verbosity; + int v_debug = 3; + + std::string Basename; + BoostStore* Stage1Data = nullptr; + BoostStore* LAPPD1Data = nullptr; + BoostStore* ANNIEEvent1 = nullptr; + + + + + +}; + + +#endif diff --git a/UserTools/Unity.h b/UserTools/Unity.h index 43c1d772e..5f37936fd 100644 --- a/UserTools/Unity.h +++ b/UserTools/Unity.h @@ -164,3 +164,4 @@ #include "PythonScript.h" #include "ReweightEventsGenie.h" #include "FilterLAPPDEvents.h" +#include "Stage1DataBuilder.h" diff --git a/configfiles/DataDecoder/ANNIEEventBuilderConfig b/configfiles/DataDecoder/ANNIEEventBuilderConfig index 950e817e3..0b5169283 100644 --- a/configfiles/DataDecoder/ANNIEEventBuilderConfig +++ b/configfiles/DataDecoder/ANNIEEventBuilderConfig @@ -1,4 +1,4 @@ -verbosity 2 +verbosity 0 BuildType TankAndMRDAndCTC ProcessedFilesBasename ProcessedRawData @@ -15,3 +15,6 @@ MaxStreamMatchingTimeSeparation 60 // seconds. If one stream is ahead of the oth SaveRawData 0 StoreBeamStatus 1 + +BuildStage1Data true +SaveSeparatePartfiles true \ No newline at end of file diff --git a/configfiles/DataDecoder/Stage1DataBuilderConfig b/configfiles/DataDecoder/Stage1DataBuilderConfig new file mode 100644 index 000000000..5a226c3b8 --- /dev/null +++ b/configfiles/DataDecoder/Stage1DataBuilderConfig @@ -0,0 +1,3 @@ +Verbosity 0 +Basename Stage1Data +RunNumber 4226 \ No newline at end of file diff --git a/configfiles/DataDecoder/ToolsConfig b/configfiles/DataDecoder/ToolsConfig index 9924ba425..3f45eccd4 100644 --- a/configfiles/DataDecoder/ToolsConfig +++ b/configfiles/DataDecoder/ToolsConfig @@ -7,3 +7,4 @@ BeamDecoder BeamDecoder ./configfiles/DataDecoder/BeamDecoderConfig PhaseIIADCCalibrator PhaseIIADCCalibrator ./configfiles/DataDecoder/PhaseIIADCCalibratorConfig PhaseIIADCHitFinder PhaseIIADCHitFinder ./configfiles/DataDecoder/PhaseIIADCHitFinderConfig ANNIEEventBuilder ANNIEEventBuilder ./configfiles/DataDecoder/ANNIEEventBuilderConfig +Stage1DataBuilder Stage1DataBuilder ./configfiles/DataDecoder/Stage1DataBuilderConfig \ No newline at end of file From b3afe70a64cb7b1c727bda0dabe53d68359edd00 Mon Sep 17 00:00:00 2001 From: jminock Date: Thu, 29 Jun 2023 14:18:57 -0400 Subject: [PATCH 04/31] LoadGenieEvent Update (#237) * Add dependencies for GENIE REWEIGHT * Added GENIE REWEIGHT and LHAPDF LHAPDF and its PDF's are necessary for the function of GENIE REWEIGHT and cross analysis studies with MicroBooNE * Added paths for GENIE REWEIGHT and LHAPDF * Added paths for GENIE REWEIGHT and LHAPDF * Separate LHAPDF from GENIE and save space by deleting unnecessary files from root6 * Typo GENIE directory * Typo GENIE directory * Delete GENIE src directory after install Free up some space * Re-include source, needed * Change GENIE path * include CLHEP * Fix Log4cpp include path * Updated Dockerfile.base and copied xml files to correct GENIE directory * Include GENIE make install Fix GENIE Reweight error * Add ReweightEventsGenie Tool * Update tempbuild.yml source setup file for building * Updated and includes LoadGenieEvent Tool * Fixed errors of update * Fix LoadGenie Direction error * Fixed Direction class Unit error --------- Co-authored-by: James Minock Co-authored-by: marc1uk --- DataModel/Direction.h | 10 + DataModel/GenieInfo.h | 56 ++- UserTools/Factory/Factory.cpp | 2 +- UserTools/LoadGenieEvent/LoadGenieEvent.cpp | 325 +++++++++++------- UserTools/LoadGenieEvent/LoadGenieEvent.h | 99 ++++-- UserTools/LoadGenieEvent/README.md | 21 ++ UserTools/Unity.h | 2 +- .../LoadGenieEvents/LoadGenieEventConfig | 6 + configfiles/LoadGenieEvents/ToolsConfig | 2 +- .../ReweightEventsGenie/LoadGenieEventConfig | 15 + configfiles/ReweightEventsGenie/ToolsConfig | 14 +- 11 files changed, 365 insertions(+), 187 deletions(-) create mode 100644 configfiles/ReweightEventsGenie/LoadGenieEventConfig diff --git a/DataModel/Direction.h b/DataModel/Direction.h index f99ae9e0c..a43edf5ea 100644 --- a/DataModel/Direction.h +++ b/DataModel/Direction.h @@ -56,6 +56,16 @@ class Direction : public SerialisableObject{ return true; } + + inline Direction Unit(){ + double thismag = Mag(); + Direction unitvec(x/thismag,y/thismag,z/thismag); + return unitvec; + } + + inline double Mag2() const { return x*x + y*y + z*z; } + + inline double Mag() const { return sqrt(Mag2()); } private: double x; // meters diff --git a/DataModel/GenieInfo.h b/DataModel/GenieInfo.h index 240fce517..55ecc593e 100644 --- a/DataModel/GenieInfo.h +++ b/DataModel/GenieInfo.h @@ -47,8 +47,8 @@ class GenieInfo { int probepdg=-1; std::string probepartname=""; //FourVector* probemomentum=0; // GeV/c? - Position probethreemomentum=Position(0.,0.,0.); // GeV/c? - Position probemomentumdir=Position(0.,0.,0.); // unit vector + Direction probethreemomentum=Direction(0.,0.,0.); // GeV/c? + Direction probemomentumdir=Direction(0.,0.,0.); // unit vector double probeanglex=0.; // rads double probeangley=0.; // rads double probeangle=0.; // rads @@ -57,7 +57,7 @@ class GenieInfo { //genie::GHepParticle* targetnucleon=0; int targetnucleonpdg=-1; std::string targetnucleonname=""; // pdg if name not known - Position targetnucleonthreemomentum=Position(0.,0.,0.); // GeV/c? only defined if there is a target nucleon: not true for all events + Direction targetnucleonthreemomentum=Direction(0.,0.,0.); // GeV/c? only defined if there is a target nucleon: not true for all events double targetnucleonenergy=0.; // GeV. only defined if there is a target nucleon // target nucleus: @@ -74,15 +74,25 @@ class GenieInfo { // final state lepton: std::string fsleptonname=""; // "n/a" if not defined double fsleptonenergy=0.; // GeV. -1 if not defined + int fsleptonpdg=-1; // -1 if not defined + double fsleptonm=0; // -1 if not defined + Direction fsleptonmomentum=Direction(0.,0.,0.); // GeV/c. 0 if not defined + Direction fsleptonmomentumdir=Direction(0.,0.,0.); // unit vector. 0 if not defined + Position fsleptonvtx=Position(0.,0.,0.); // cm. 0 if not defined + double fsleptont=0.; // ns. -1 if not deined - // other remnants: TODO: this information is NOT being correctly read in - int numfsprotons=-1; - int numfsneutrons=-1; - int numfspi0=-1; - int numfspiplus=-1; - int numfspiminus=-1; - int numfskplus=-1; - int numfskminus=-1; + // other remnants: TODO: this information is NOT being correctly read in + int numfsprotons=-1; + int numfsneutrons=-1; + int numfspi0=-1; + int numfspiplus=-1; + int numfspipluscher=-1; + int numfspiminus=-1; + int numfspiminuscher=-1; + int numfskplus=-1; + int numfskpluscher=-1; + int numfskminus=-1; + int numfskminuscher=-1; // kinematic information //FourVector* k1=0; // GeV/c? Neutrino incoming momentum vector @@ -130,13 +140,23 @@ class GenieInfo { ar & remnantnucleusenergy; ar & fsleptonname; ar & fsleptonenergy; - ar & numfsprotons; - ar & numfsneutrons; - ar & numfspi0; - ar & numfspiplus; - ar & numfspiminus; - ar & numfskplus; - ar & numfskminus; + ar & fsleptonpdg; + ar & fsleptonm; + ar & fsleptonmomentum; + ar & fsleptonmomentumdir; + ar & fsleptonvtx; + ar & fsleptont; + ar & numfsprotons; + ar & numfsneutrons; + ar & numfspi0; + ar & numfspiplus; + ar & numfspipluscher; + ar & numfspiminus; + ar & numfspiminuscher; + ar & numfskplus; + ar & numfskpluscher; + ar & numfskminus; + ar & numfskminuscher; ar & q; ar & costhfsl; ar & fslangle; diff --git a/UserTools/Factory/Factory.cpp b/UserTools/Factory/Factory.cpp index b5dffc23f..23bd35bef 100644 --- a/UserTools/Factory/Factory.cpp +++ b/UserTools/Factory/Factory.cpp @@ -95,7 +95,7 @@ if (tool=="MCHitToHitComparer") ret=new MCHitToHitComparer; if (tool=="MCPropertiesToTree") ret=new MCPropertiesToTree; if (tool=="CalcClassificationVars") ret=new CalcClassificationVars; if (tool=="StoreClassificationVars") ret=new StoreClassificationVars; -//if (tool=="LoadGenieEvent") ret=new LoadGenieEvent; +if (tool=="LoadGenieEvent") ret=new LoadGenieEvent; //if (tool=="PrintGenieEvent") ret=new PrintGenieEvent; if (tool=="PlotWaveforms") ret=new PlotWaveforms; if (tool=="PMTDataDecoder") ret=new PMTDataDecoder; diff --git a/UserTools/LoadGenieEvent/LoadGenieEvent.cpp b/UserTools/LoadGenieEvent/LoadGenieEvent.cpp index a6d5b7f4a..c09dd6a63 100644 --- a/UserTools/LoadGenieEvent/LoadGenieEvent.cpp +++ b/UserTools/LoadGenieEvent/LoadGenieEvent.cpp @@ -49,17 +49,17 @@ Genie 2.8.6 GNTP files: /pnfs/annie/persistent/users/vfischer/genie/BNB_Water_10 - these files contain genie::NtpMCEventRecord objects that contain details of the neutrino event - input event information is passed into a genie::flux::GNuMIFluxPassThroughInfo object -Zarko's Files +James's Files ------------- -Genie 2.12 GNTP files: /pnfs/annie/persistent/users/moflaher/genie/BNB_World_10k_11-03-18_gsimpleflux/gntp.1000.ghep.root -- these files also contain genie::NtpMCEventRecord objects to describe details of the neutrino event +Genie 3.0.4.ub3 GNTP files: /pnfs/annie/persistent/simulation/genie3/G1810a0211a/standard/tank/gntp.1000.ghep.root +- these files contain genie::NtpMCEventRecord objects to describe details of the neutrino event - input event information is passed to a genie::flux::GSimpleNtpEntry and genie::flux::GSimpleNtpNuMI object - */ LoadGenieEvent::LoadGenieEvent():Tool(){} Position TVector3ToPosition(TVector3 tvecin); +Direction TVector3ToDirection(TVector3 tvecin); FourVector TLorentzVectorToFourVector(TLorentzVector tlvecin); bool LoadGenieEvent::Initialise(std::string configfile, DataModel &data){ @@ -71,13 +71,13 @@ bool LoadGenieEvent::Initialise(std::string configfile, DataModel &data){ m_data= &data; //assigning transient data pointer ///////////////////////////////////////////////////////////////// -#if LOADED_GENIE==1 // only load the Tool if genie is available m_variables.Get("verbosity",verbosity); m_variables.Get("FluxVersion",fluxver); // flux version: 0=rhatcher files, 1=zarko files m_variables.Get("FileDir",filedir); m_variables.Get("FilePattern",filepattern); m_variables.Get("ManualFileMatching",manualmatch); + m_variables.Get("FileEvents",fileevents); // create a store for holding Genie information to pass to downstream Tools // will be a single entry BoostStore containing a vector of single entry BoostStores @@ -88,8 +88,9 @@ bool LoadGenieEvent::Initialise(std::string configfile, DataModel &data){ /////////////////////// Log("Tool LoadGenieEvent: Opening TChain",v_debug,verbosity); loadwcsimsource = (filepattern=="LoadWCSimTool"); - if(not loadwcsimsource){ + if(not loadwcsimsource && not manualmatch){ // construct a new TChain and add all the files at once + // this is for use of looking at stand alone Genie file, with no WCSim std::string inputfiles = filedir+"/"+filepattern; tchainentrynum=0; flux = new TChain("gtree"); @@ -104,7 +105,7 @@ bool LoadGenieEvent::Initialise(std::string configfile, DataModel &data){ std::string wcsimfile; m_data->Stores.at("ANNIEEvent")->Get("MCFile",wcsimfile); //Strip WCSim file name of its prefix path - std::string wcsim_prefix = "wcsim_0."; + std::string wcsim_prefix = "wcsim_"; wcsimfile.erase(0,wcsimfile.find(wcsim_prefix)+wcsim_prefix.length()); wcsimfile.erase(wcsimfile.find(".root"),wcsimfile.find(".root")+5); std::string wcsimev = wcsimfile; @@ -121,55 +122,52 @@ bool LoadGenieEvent::Initialise(std::string configfile, DataModel &data){ curf=TFile::Open(inputfile.c_str()); flux=(TChain*)curf->Get("gtree"); SetBranchAddresses(); - tchainentrynum = wcsimevnumber*500; + tchainentrynum = wcsimevnumber*fileevents; } - -#else - Log("Tool LoadGenieEvent is disabled as Genie is not loaded",v_warning,verbosity); -#endif - + return true; } bool LoadGenieEvent::Execute(){ -#if LOADED_GENIE==1 - - if(loadwcsimsource && !manualmatch){ - // retrieve the genie file and entry number from the LoadWCSim tool - std::string inputfiles; - get_ok = m_data->CStore.Get("GenieFile",inputfiles); - if(!get_ok){ - Log("Tool LoadGenieEvent: Failed to find GenieFile in CStore",v_error,verbosity); - return false; - } - // XXX WCSim currently only records the genie file name, but not absolute path! - // we still need to provide the path via config file! - if(filedir!="NA") inputfiles = filedir+"/"+inputfiles; - m_data->CStore.Get("GenieEntry",tchainentrynum); - if(!get_ok){ - Log("Tool LoadGenieEvent: Failed to find GenieEntry in CStore",v_error,verbosity); - return false; - } - - std::string curfname = ((curf) ? curf->GetName() : ""); - // check if this is a new file - if(inputfiles!=curfname){ - // we need to load the new file - if(flux) flux->ResetBranchAddresses(); - if(curf) curf->Close(); - Log("Tool LoadGenieEvent: Loading new file "+inputfiles,v_debug,verbosity); - curf=TFile::Open(inputfiles.c_str()); - flux=(TChain*)curf->Get("gtree"); - SetBranchAddresses(); - } - } + if(loadwcsimsource && !manualmatch){ + // retrieve the genie file and entry number from the LoadWCSim tool + std::string inputfiles; + get_ok = m_data->CStore.Get("GenieFile",inputfiles); + if(!get_ok){ + if(verbosity) std::cout << "Tool LoadGenieEvent: Failed to find GenieFile in CStore" << std::endl; + return false; + } + if(filedir!="NA"){ + std::string genie_prefix = "gntp."; + inputfiles.erase(0, inputfiles.find(genie_prefix)); + inputfiles = filedir+"/"+inputfiles; + if(verbosity) std::cout << "Tool LoadGenieEvent: Loading Genie file: " << inputfiles << std::endl; + } + m_data->CStore.Get("GenieEntry",tchainentrynum); + if(!get_ok){ + if(verbosity) std::cout << "Tool LoadGenieEvent: Failed to find GenieEntry in CStore" << std::endl; + return false; + } + + std::string curfname = ((curf) ? curf->GetName() : ""); + // check if this is a new file + if(inputfiles!=curfname){ + // we need to load the new file + if(flux) flux->ResetBranchAddresses(); + if(curf) curf->Close(); + if(verbosity) std::cout <<"Tool LoadGenieEvent: Loading new file "<Get("gtree"); + SetBranchAddresses(); + } + } Log("Tool LoadGenieEvent: Loading tchain entry "+to_string(tchainentrynum),v_debug,verbosity); local_entry = flux->LoadTree(tchainentrynum); Log("Tool LoadGenieEvent: localentry is "+to_string(local_entry),v_debug,verbosity); - if(local_entry<0){ + if(local_entry<0||local_entry!=tchainentrynum){ Log("Tool LoadGenieEvent: Reached end of file, returning",v_message,verbosity); m_data->vars.Set("StopLoop",1); return true; @@ -228,9 +226,9 @@ bool LoadGenieEvent::Execute(){ // convenience type conversions parentdecayvtx = Position(parentdecayvtx_x,parentdecayvtx_y,parentdecayvtx_z); - parentdecaymom = Position(parentdecaymom_x,parentdecaymom_y,parentdecaymom_z); - parentprodmom = Position(parentprodmom_x,parentprodmom_y,parentprodmom_z); - parenttgtexitmom = Position(parenttgtexitmom_x,parenttgtexitmom_y,parenttgtexitmom_z); + parentdecaymom = Direction(parentdecaymom_x,parentdecaymom_y,parentdecaymom_z); + parentprodmom = Direction(parentprodmom_x,parentprodmom_y,parentprodmom_z); + parenttgtexitmom = Direction(parenttgtexitmom_x,parenttgtexitmom_y,parenttgtexitmom_z); //parenttypestring = (fluxstage==0) ? GnumiToString(parentpdg) : PdgToString(parentpdg); //parenttypestringattgtexit = (fluxstage==0) ? parenttypestring = (pcodes==0) ? GnumiToString(parentpdg) : PdgToString(parentpdg); @@ -260,12 +258,21 @@ bool LoadGenieEvent::Execute(){ parenttgtexitmom_x = gsimplenumientry->tpx; parenttgtexitmom_y = gsimplenumientry->tpy; parenttgtexitmom_z = gsimplenumientry->tpz; + + fluxentryno = gsimplenumientry->entryno; + fluxrun = gsimplenumientry->run; + double flux_energy = gsimpleentry->E; + fluxnenergyn = flux_energy; + fluxnenergyf = flux_energy; + fluxevtno = gsimplenumientry->evtno; + fluxntype = gsimpleentry->pdg; + fluxnimpwt = gsimpleentry->wgt; // convenience type conversions parentdecayvtx = Position(parentdecayvtx_x,parentdecayvtx_y,parentdecayvtx_z); - parentdecaymom = Position(parentdecaymom_x,parentdecaymom_y,parentdecaymom_z); - parentprodmom = Position(parentprodmom_x,parentprodmom_y,parentprodmom_z); - parenttgtexitmom = Position(parenttgtexitmom_x,parenttgtexitmom_y,parenttgtexitmom_z); + parentdecaymom = Direction(parentdecaymom_x,parentdecaymom_y,parentdecaymom_z); + parentprodmom = Direction(parentprodmom_x,parentprodmom_y,parentprodmom_z); + parenttgtexitmom = Direction(parenttgtexitmom_x,parenttgtexitmom_y,parenttgtexitmom_z); parenttypestring = PdgToString(parentpdg); parenttypestringattgtexit = PdgToString(parentpdgattgtexit); parentdecaystring = DecayTypeToString(parentdecaymode); @@ -323,6 +330,14 @@ bool LoadGenieEvent::Execute(){ } else { isinfiducialvol = false; } fsleptonname = std::string(thegenieinfo.fsleptonname); + fsleptonenergy = thegenieinfo.fsleptonenergy; + fsleptonpdg = thegenieinfo.fsleptonpdg; + fsleptonm = thegenieinfo.fsleptonm; + fsleptonmomentum = thegenieinfo.fsleptonmomentum; + fsleptonmomentumdir = thegenieinfo.fsleptonmomentumdir; + fsleptonvtx = thegenieinfo.fsleptonvtx; // cm + fsleptont = thegenieinfo.fsleptont; // ns + // this data does not appear to be populated... // Edit: Maybe due to the numbers for the exclusive tag being evaluated before Final State Interactions // Compare e.g. documentation here: https://internal.dunescience.org/doxygen/classgenie_1_1XclsTag.html @@ -334,34 +349,18 @@ bool LoadGenieEvent::Execute(){ numfspiminus = thegenieinfo.numfspiminus = genieint->ExclTag().NPiMinus(); */ //The following is more cumbersome, but seems to work (we count the number of final state particles by hand) - numfsprotons = 0; - numfsneutrons = 0; - numfspi0 = 0; - numfspiplus= 0; - numfspiminus = 0; - numfskplus = 0; - numfskminus = 0; + numfsprotons = thegenieinfo.numfsprotons; + numfsneutrons = thegenieinfo.numfsneutrons; + numfspi0 = thegenieinfo.numfspi0; + numfspiplus= thegenieinfo.numfspiplus; + numfspipluscher = thegenieinfo.numfspipluscher; + numfspiminus = thegenieinfo.numfspiminus; + numfspiminuscher = thegenieinfo.numfspiminuscher; + numfskplus = thegenieinfo.numfskplus; + numfskpluscher = thegenieinfo.numfskpluscher; + numfskminus = thegenieinfo.numfskminus; + numfskminuscher = thegenieinfo.numfskminuscher; - TObjArrayIter iter(gevtRec); - genie::GHepParticle * p = 0; - - //Loop over event particles - while ((p = dynamic_cast(iter.Next()))) { - - int pdgc = p->Pdg(); - int status = p->Status(); - - if (status != genie::kIStStableFinalState) continue; - - if (pdgc == genie::kPdgNeutron) numfsneutrons++; - else if (pdgc == genie::kPdgProton) numfsprotons++; - else if (pdgc == genie::kPdgPiP) numfspiplus++; - else if (pdgc == genie::kPdgPiM) numfspiminus++; - else if (pdgc == genie::kPdgPi0) numfspi0++; - else if (pdgc == genie::kPdgKP) numfskplus++; - else if (pdgc == genie::kPdgKM) numfskminus++; - } - Log("Tool LoadGenieEvent: Passing information to the GenieEvent store",v_debug,verbosity); // Update the Store with all the current event information @@ -393,6 +392,13 @@ bool LoadGenieEvent::Execute(){ geniestore->Set("ParentTgtExitMom_X",parenttgtexitmom_x); geniestore->Set("ParentTgtExitMom_Y",parenttgtexitmom_y); geniestore->Set("ParentTgtExitMom_Z",parenttgtexitmom_z); + geniestore->Set("ParentEntryNo",fluxentryno); + geniestore->Set("ParentRunNo",fluxrun); + geniestore->Set("ParentNEnergyN",fluxnenergyn); + geniestore->Set("ParentNEnergyF",fluxnenergyf); + geniestore->Set("ParentEventNo",fluxevtno); + geniestore->Set("ParentNType",fluxntype); + geniestore->Set("ParentWgt",fluxnimpwt); geniestore->Set("IsQuasiElastic",IsQuasiElastic); geniestore->Set("IsResonant",IsResonant); @@ -421,13 +427,24 @@ bool LoadGenieEvent::Execute(){ geniestore->Set("MuonEnergy",muonenergy); geniestore->Set("MuonAngle",muonangle); geniestore->Set("FSLeptonName",fsleptonname); - geniestore->Set("NumFSProtons",numfsprotons); - geniestore->Set("NumFSNeutrons",numfsneutrons); - geniestore->Set("NumFSPi0",numfspi0); - geniestore->Set("NumFSPiPlus",numfspiplus); - geniestore->Set("NumFSPiMinus",numfspiminus); - geniestore->Set("NumFSKPlus",numfskplus); - geniestore->Set("NumFSKMinus",numfskminus); + geniestore->Set("FSLeptonPdg",fsleptonpdg); + geniestore->Set("FSLeptonMass",fsleptonm); + geniestore->Set("FSLeptonEnergy",fsleptonenergy); + geniestore->Set("FSLeptonMomentum",fsleptonmomentum); + geniestore->Set("FSLeptonMomentumDir",fsleptonmomentumdir); + geniestore->Set("FSLeptonVertex",fsleptonvtx); + geniestore->Set("FSLeptonTime",fsleptont); + geniestore->Set("NumFSProtons",numfsprotons); + geniestore->Set("NumFSNeutrons",numfsneutrons); + geniestore->Set("NumFSPi0",numfspi0); + geniestore->Set("NumFSPiPlus",numfspiplus); + geniestore->Set("NumFSPiPlusCher",numfspipluscher); + geniestore->Set("NumFSPiMinus",numfspiminus); + geniestore->Set("NumFSPiMinusCher",numfspiminuscher); + geniestore->Set("NumFSKPlus",numfskplus); + geniestore->Set("NumFSKPlusCher",numfskpluscher); + geniestore->Set("NumFSKMinus",numfskminus); + geniestore->Set("NumFSKMinusCher",numfskminuscher); geniestore->Set("GenieInfo",thegenieinfo); //geniestore->Set("TheGenieInfoPtr",&thegenieinfo,false); //intptr_t thegenieinfoptr = reinterpret_cast(&thegenieinfo); @@ -438,26 +455,20 @@ bool LoadGenieEvent::Execute(){ Log("Tool LoadGenieEvent: done",v_debug,verbosity); return true; - -#else - return true; -#endif // LOADED_GENIE } bool LoadGenieEvent::Finalise(){ -#if LOADED_GENIE==1 if(flux){ flux->ResetBranchAddresses(); if (not loadwcsimsource) delete flux; //only need to delete in case it was created with "new" --> only in not-loadwcsimource case. Otherwise double-free corruption flux=nullptr; } -#endif + Log("Tool LoadGenieEvent: exiting",v_debug,verbosity); return true; } -#if LOADED_GENIE==1 void LoadGenieEvent::SetBranchAddresses(){ Log("Tool LoadGenieEvent: Setting branch addresses",v_debug,verbosity); @@ -469,7 +480,7 @@ void LoadGenieEvent::SetBranchAddresses(){ flux->SetBranchAddress("flux",&gnumipassthruentry); flux->GetBranch("flux")->SetAutoDelete(kTRUE); } else { // zarko files - flux->Print(); + // flux->Print(); flux->SetBranchAddress("numi",&gsimplenumientry); flux->GetBranch("numi")->SetAutoDelete(kTRUE); flux->SetBranchAddress("simple",&gsimpleentry); @@ -524,7 +535,7 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter logmessage+= ", ProbeMomentum[0] = "+to_string(probemomentum->E()); Log(logmessage,v_warning,verbosity); } - /*TVector3*/ thegenieinfo.probethreemomentum = TVector3ToPosition(probemomentum->Vect()); + /*TVector3*/ thegenieinfo.probethreemomentum = TVector3ToDirection(probemomentum->Vect()); /*TVector3*/ thegenieinfo.probemomentumdir = thegenieinfo.probethreemomentum.Unit(); /*Double_t*/ thegenieinfo.probeanglex = TMath::ATan(thegenieinfo.probethreemomentum.X()/thegenieinfo.probethreemomentum.Z()); @@ -543,11 +554,11 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter } else { thegenieinfo.targetnucleonname = std::to_string(thegenieinfo.targetnucleonpdg); } - /*TVector3*/ thegenieinfo.targetnucleonthreemomentum=Position(0.,0.,0.); + /*TVector3*/ thegenieinfo.targetnucleonthreemomentum=Direction(0.,0.,0.); /*Double_t*/ thegenieinfo.targetnucleonenergy=0.; if(targetnucleon){ TLorentzVector* targetnucleonmomentum = targetnucleon->P4(); - thegenieinfo.targetnucleonthreemomentum = TVector3ToPosition(targetnucleonmomentum->Vect()); + thegenieinfo.targetnucleonthreemomentum = TVector3ToDirection(targetnucleonmomentum->Vect()); thegenieinfo.targetnucleonenergy = targetnucleonmomentum->Energy(); //GeV } @@ -570,14 +581,30 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter } // final state lepton: - int fsleppos = gevtRec->FinalStatePrimaryLeptonPosition(); - /*TString*/ thegenieinfo.fsleptonname="n/a"; - /*Double_t*/ thegenieinfo.fsleptonenergy=-1.; - if(fsleppos>-1){ - thegenieinfo.fsleptonname = gevtRec->Particle(fsleppos)->Name(); - thegenieinfo.fsleptonenergy = gevtRec->Particle(fsleppos)->Energy(); - } - + int fsleppos = gevtRec->FinalStatePrimaryLeptonPosition(); + /*TString*/ thegenieinfo.fsleptonname="n/a"; + /*Double_t*/ thegenieinfo.fsleptonenergy=-1.; + /*Int_t*/ thegenieinfo.fsleptonpdg=-1; + /*Double_t*/ thegenieinfo.fsleptonm=-1.; + /*Double_t*/ thegenieinfo.fsleptont=-1.; + /*TVector3*/ thegenieinfo.fsleptonmomentum=Direction(0.,0.,0.); + /*TVector3*/ thegenieinfo.fsleptonmomentumdir=Direction(0.,0.,0.); + /*TVector3*/ thegenieinfo.fsleptonvtx=Position(0.,0.,0.); + if(fsleppos>-1){ + thegenieinfo.fsleptonname = gevtRec->Particle(fsleppos)->Name(); + thegenieinfo.fsleptonenergy = gevtRec->Particle(fsleppos)->Energy(); + thegenieinfo.fsleptonpdg = gevtRec->Particle(fsleppos)->Pdg(); + thegenieinfo.fsleptonm = gevtRec->Particle(fsleppos)->Mass(); + thegenieinfo.fsleptonmomentum = Direction(gevtRec->Particle(fsleppos)->Px(), + gevtRec->Particle(fsleppos)->Py(), + gevtRec->Particle(fsleppos)->Pz()); + thegenieinfo.fsleptonmomentumdir = thegenieinfo.fsleptonmomentum.Unit(); + thegenieinfo.fsleptonvtx = Position(gevtRec->Particle(fsleppos)->Vx()*100, + gevtRec->Particle(fsleppos)->Vy()*100, + gevtRec->Particle(fsleppos)->Vz()*100); //meters -> cm + thegenieinfo.fsleptont = gevtRec->Particle(fsleppos)->Vt()*1000000000; //sec -> ns + } + // other remnants: TEMP FIX: this information is NOT being correctly read in // Edit: Maybe due to the numbers for the exclusive tag being evaluated before Final State Interactions // Compare e.g. documentation here: https://internal.dunescience.org/doxygen/classgenie_1_1XclsTag.html @@ -588,33 +615,62 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter /*Int_t*/ //thegenieinfo.numfspiminus = genieint->ExclTag().NPiMinus(); //The following is more cumbersome, but seems to work (we count the number of final state particles by hand) - thegenieinfo.numfsprotons = 0; - thegenieinfo.numfsneutrons = 0; - thegenieinfo.numfspi0 = 0; - thegenieinfo.numfspiplus= 0; - thegenieinfo.numfspiminus = 0; - thegenieinfo.numfskplus = 0; - thegenieinfo.numfskminus = 0; + thegenieinfo.numfsprotons = 0; + thegenieinfo.numfsneutrons = 0; + thegenieinfo.numfspi0 = 0; + thegenieinfo.numfspiplus= 0; + thegenieinfo.numfspipluscher = 0; + thegenieinfo.numfspiminus = 0; + thegenieinfo.numfspiminuscher = 0; + thegenieinfo.numfskplus = 0; + thegenieinfo.numfskpluscher = 0; + thegenieinfo.numfskminus = 0; + thegenieinfo.numfskminuscher = 0; TObjArrayIter iter(gevtRec); genie::GHepParticle * p = 0; //Loop over event particles - while ((p = dynamic_cast(iter.Next()))) { - - int pdgc = p->Pdg(); - int status = p->Status(); - - if (status != genie::kIStStableFinalState) continue; - - if (pdgc == genie::kPdgNeutron) thegenieinfo.numfsneutrons++; - else if (pdgc == genie::kPdgProton) thegenieinfo.numfsprotons++; - else if (pdgc == genie::kPdgPiP) thegenieinfo.numfspiplus++; - else if (pdgc == genie::kPdgPiM) thegenieinfo.numfspiminus++; - else if (pdgc == genie::kPdgPi0) thegenieinfo.numfspi0++; - else if (pdgc == genie::kPdgKP) thegenieinfo.numfskplus++; - else if (pdgc == genie::kPdgKM) thegenieinfo.numfskminus++; - } + while ((p = dynamic_cast(iter.Next()))) { + + int pdgc = p->Pdg(); + int status = p->Status(); + double wclimit = 0.160; //water Cherenkov momentum threshold + + if (status != genie::kIStStableFinalState) continue; + + if (pdgc == genie::kPdgNeutron) thegenieinfo.numfsneutrons++; + else if (pdgc == genie::kPdgProton) thegenieinfo.numfsprotons++; + else if (pdgc == genie::kPdgPiP) { + thegenieinfo.numfspiplus++; + double pipx = p->Px(); + double pipy = p->Py(); + double pipz = p->Pz(); + if (std::sqrt(pipx*pipx + pipy*pipy + pipz*pipz) > wclimit) thegenieinfo.numfspipluscher++; + } + else if (pdgc == genie::kPdgPiM) { + thegenieinfo.numfspiminus++; + double pipx = p->Px(); + double pipy = p->Py(); + double pipz = p->Pz(); + if (std::sqrt(pipx*pipx + pipy*pipy + pipz*pipz) > wclimit) thegenieinfo.numfspiminuscher++; + } + else if (pdgc == genie::kPdgPi0) thegenieinfo.numfspi0++; + else if (pdgc == genie::kPdgKP) { + thegenieinfo.numfskplus++; + double pipx = p->Px(); + double pipy = p->Py(); + double pipz = p->Pz(); + if (std::sqrt(pipx*pipx + pipy*pipy + pipz*pipz) > wclimit) thegenieinfo.numfskpluscher++; + } + else if (pdgc == genie::kPdgKM) { + thegenieinfo.numfskminus++; + double pipx = p->Px(); + double pipy = p->Py(); + double pipz = p->Pz(); + if (std::sqrt(pipx*pipx + pipy*pipy + pipz*pipz) > wclimit) thegenieinfo.numfskminuscher++; + } + } // kinematic information Double_t NucleonM = genie::constants::kNucleonMass; @@ -670,10 +726,10 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter << " N(n) = " << thegenieinfo.numfsneutrons << endl << " N(pi^0) = " << thegenieinfo.numfspi0 - << " N(pi^+) = " << thegenieinfo.numfspiplus - << " N(pi^-) = " << thegenieinfo.numfspiminus - << " N(K^+) = " << thegenieinfo.numfskplus - << " N(K^-) = " << thegenieinfo.numfskminus + << " N(pi^+)(over CT) = " << thegenieinfo.numfspiplus << "(" << thegenieinfo.numfspipluscher << ")" + << " N(pi^-)(over CT) = " << thegenieinfo.numfspiminus << "(" << thegenieinfo.numfspiminuscher << ")" + << " N(K^+)(over CT) = " << thegenieinfo.numfskplus << "(" << thegenieinfo.numfskpluscher << ")" + << " N(K^-)(over CT) = " << thegenieinfo.numfskminus << "(" << thegenieinfo.numfskminuscher << ")" <* LoadGenieEvent::GenerateMediumMap(){ return &mediummap; } -#endif // LOADED_GENIE==1 Position TVector3ToPosition(TVector3 tvecin){ Position pos(0,0,0); @@ -887,6 +942,14 @@ Position TVector3ToPosition(TVector3 tvecin){ return pos; } +Direction TVector3ToDirection(TVector3 tvecin){ + Direction dir(0,0,0); + dir.SetX(tvecin.X()); + dir.SetY(tvecin.Y()); + dir.SetZ(tvecin.Z()); + return dir; +} + FourVector TLorentzVectorToFourVector(TLorentzVector tlvecin){ FourVector vec(0,0,0,0); vec.SetT(tlvecin.T()); diff --git a/UserTools/LoadGenieEvent/LoadGenieEvent.h b/UserTools/LoadGenieEvent/LoadGenieEvent.h index 00e74d92d..a52b9b367 100644 --- a/UserTools/LoadGenieEvent/LoadGenieEvent.h +++ b/UserTools/LoadGenieEvent/LoadGenieEvent.h @@ -3,29 +3,44 @@ #include #include +#include +#include +#include +#include +#include +#include +#include +#include + #include "Tool.h" #include "GenieInfo.h" - -// legacy -#define LOADED_GENIE 1 - -#if LOADED_GENIE==1 // disable this tool unless Genie is loaded (FNAL) -//GENIE +#include "CLHEP/Random/RandGaussQ.h" +#include "CLHEP/Random/JamesRandom.h" +#include "Framework/Conventions/KineVar.h" +#include "Framework/EventGen/EventRecord.h" +#include "Framework/Interaction/Interaction.h" +#include "Framework/Interaction/Kinematics.h" +//#include "Framework/Messenger/Messenger.h" +#include "Framework/Utils/AppInit.h" #include #include -#include // neut reaction codes -#include -#include -#include -#include -#include -#include -#include +#include // neut reaction codes +#include +#include +#include +#include +#include +#include +#include #include -#include -// other -#endif // LOADED_GENIE==1 +#include "TChain.h" +#include "TFile.h" +#include "TTree.h" +#include "TVector3.h" +#include "TLorentzVector.h" + +#include "MRDspecs.hh" class LoadGenieEvent: public Tool { @@ -47,7 +62,6 @@ class LoadGenieEvent: public Tool { private: -#if LOADED_GENIE==1 // function to load the branch addresses void SetBranchAddresses(); @@ -76,7 +90,8 @@ class LoadGenieEvent: public Tool { TFile* curf = nullptr; // keep track of file changes TFile* curflast = nullptr; genie::NtpMCEventRecord* genieintx = nullptr; // = new genie::NtpMCEventRecord; -// // for fluxver 0 files + genie::NtpMCTreeHeader* geniehdr = nullptr; + // for fluxver 0 files genie::flux::GNuMIFluxPassThroughInfo* gnumipassthruentry = nullptr; // for fluxver 1 files genie::flux::GSimpleNtpEntry* gsimpleentry = nullptr; @@ -88,7 +103,8 @@ class LoadGenieEvent: public Tool { std::string currentfilestring; unsigned long local_entry=0; // unsigned int tchainentrynum=0; // - bool manualmatch=1; //to be used when GENIE information is not stored properly in file + bool manualmatch=0; //to be used when GENIE information is not stored properly in file + int fileevents=0; // common input/output variables to both Robert/Zarko filesets int parentpdg; @@ -98,19 +114,25 @@ class LoadGenieEvent: public Tool { float parentdecayvtx_x, parentdecayvtx_y, parentdecayvtx_z; Position parentdecayvtx; float parentdecaymom_x, parentdecaymom_y, parentdecaymom_z; - Position parentdecaymom; + Direction parentdecaymom; float parentprodmom_x, parentprodmom_y, parentprodmom_z; - Position parentprodmom; + Direction parentprodmom; int parentprodmedium; // they're all 0 std::string parentprodmediumstring; // do we even have this mapping? --> There seems to be a mapping here: https://minos-docdb.fnal.gov/cgi-bin/sso/RetrieveFile?docid=6316&filename=flugg_doc.pdf&version=10 int parentpdgattgtexit; std::string parenttypestringattgtexit; - Position parenttgtexitmom; + Direction parenttgtexitmom; float parenttgtexitmom_x, parenttgtexitmom_y, parenttgtexitmom_z; int pcodes; // Needed to evaluate whether the particle codes are stored in GEANT format or in PDG format - // Additional zarko-only information - // TODO fillme + // Additional zarko-only information, needed for flux systematic reweighting + int fluxrun; + int fluxentryno; + int fluxevtno; + int fluxntype; + double fluxnimpwt; + double fluxnenergyn; + double fluxnenergyf; // store the neutrino info from gntp files // a load of variables to specify interaction type @@ -142,16 +164,25 @@ class LoadGenieEvent: public Tool { double muonenergy=-1; double muonangle=-1; std::string fsleptonname; // assumed to be muon, but we should confirm + double fsleptonenergy; + int fsleptonpdg; + double fsleptonm; + Direction fsleptonmomentum; + Direction fsleptonmomentumdir; + Position fsleptonvtx; // cm + double fsleptont; // ns // these may not be properly copied... --> temp fix applied that seems to be working - int numfsprotons; - int numfsneutrons; - int numfspi0; - int numfspiplus; - int numfspiminus; - int numfskplus; - int numfskminus; - -#endif // LOADED_GENIE==1 + int numfsprotons; + int numfsneutrons; + int numfspi0; + int numfspiplus; + int numfspipluscher; // reach Cherenkov threshold + int numfspiminus; + int numfspiminuscher; // reach Cherenkov threshold + int numfskplus; + int numfskpluscher; // reach Cherenkov threshold + int numfskminus; + int numfskminuscher; // reach Cherenkov threshold }; diff --git a/UserTools/LoadGenieEvent/README.md b/UserTools/LoadGenieEvent/README.md index d3a0d9cc5..5e1c9f807 100644 --- a/UserTools/LoadGenieEvent/README.md +++ b/UserTools/LoadGenieEvent/README.md @@ -30,6 +30,13 @@ The information is loaded from the GENIE file and saved into the "GenieInfo" Boo * **ParentTypeAtTgtExitString** `string`: Name of parent particle at exit of target * **ParentTgtExitMom** `Position`: momentum of parent particle at exit of target * **ParentTgtExitMom_X/Y/Z** `float`: x/y/z component of parent particle momentum at exit of target +* **ParentEntryNo** `int`: entry number of parent particle that produced neutrino +* **ParentEventNo** `int`: event number of parent particle that produced neutrino +* **ParentRunNo** `int`: run number of flux file +* **ParentNEnergyN** `double`: The energy of the parent particle +* **ParentNEnergyF** `double`: The energy of the parent particle +* **ParentNType** `int`: The PDG code of the parent particle specific to gsimple file +* **ParentWgt** `double`: The weight of the parent particle * **IsQuasiElastic** `bool`: Neutrino interaction was quasi-elastic * **IsResonant** `bool`: Neutrino interaction was RES @@ -55,13 +62,24 @@ The information is loaded from the GENIE file and saved into the "GenieInfo" Boo * **MuonEnergy** `double`: Energy of produced muon * **MuonAngle** `double`: Angle of produced muon * **FSLeptonName** `string`: Final State Lepton name +* **FSLeptonEnergy** `double`: Final State Lepton energy +* **FSLeptonPdg** `int`: Final State Lepton PDG code +* **FSLeptonMass** `double`: Final State Lepton mass +* **FSLeptonMomentum** `Position`: Final State Lepton momentum vector +* **FSLeptonMomentumDir** `Position`: Final State Lepton momentum unit vector +* **FSLeptonVertex** `Position`: Final State Lepton initial vertex +* **FSLeptonTime** `double`: Final State Lepton time of initial vertex * **NumFSProtons** `int`: Number of final state protons * **NumFSNeutrons** `int`: Number of final state neutrons * **NumFSPi0** `int`: Number of final state pi^0 * **NumFSPiPlus** `int`: Number of final state pi^+ +* **NumFSPiPlusCher** `int`: Number of final state pi^+ that pass Cherenkov threshold * **NumFSPiMinus** `int`: Number of final state pi^- +* **NumFSPiMinusCher** `int`: Number of final state pi^- that pass Cherenkov threshold * **NumFSKPlus** `int`: Number of final state K^+ +* **NumFSKPlusCher** `int`: Number of final state K^+ that pass Cherenkov threshold * **NumFSKMinus** `int`: Number of final state K^- +* **NumFSKMinusCher** `int`: Number of final state K^- that pass Cherenkov threshold * **GenieInfo** `GenieInfo`: GenieInfo object containing most of the listed properties (see DataModel header-file) ## Configuration file ## @@ -78,4 +96,7 @@ FileDir /pnfs/annie/persistent/users/vfischer/genie_files/BNB_Water_10k_22-05-17 FilePattern LoadWCSimTool ## use this pattern to load corresponding genie info with the LoadWCSimTool ## N.B: FileDir must still be specified for now! (WCSim files do not record their directory) ManualFileMatching 1 ## If the corresponding GENIE files are not saved reliably, a manual matching of WCSim files to GENIE files can take place +FileEvents 500 ## Number of events per WCSim file + ## 500 events for Marcus files + ## 1000 events for James files ``` diff --git a/UserTools/Unity.h b/UserTools/Unity.h index 5f37936fd..107493137 100644 --- a/UserTools/Unity.h +++ b/UserTools/Unity.h @@ -103,7 +103,7 @@ #include "MCPropertiesToTree.h" #include "CalcClassificationVars.h" #include "StoreClassificationVars.h" -//#include "LoadGenieEvent.h" +#include "LoadGenieEvent.h" //#include "PrintGenieEvent.h" #include "PlotWaveforms.h" #include "PMTDataDecoder.h" diff --git a/configfiles/LoadGenieEvents/LoadGenieEventConfig b/configfiles/LoadGenieEvents/LoadGenieEventConfig index 61156df5f..d4ecc33f5 100644 --- a/configfiles/LoadGenieEvents/LoadGenieEventConfig +++ b/configfiles/LoadGenieEvents/LoadGenieEventConfig @@ -4,6 +4,12 @@ FluxVersion 0 # use 0 to load genie files based on bnb_annie_0000.root etc file FileDir NA # specify "NA" for newer files: full path is saved in WCSim #FileDir /pnfs/annie/persistent/users/vfischer/genie_files/BNB_Water_10k_22-05-17 #FileDir /pnfs/annie/persistent/users/moflaher/genie/BNB_World_10k_11-03-18_gsimpleflux +#FileDir /pnfs/annie/persistent/simulations/genie3/G1810a0211a/standard/tank +#FileDir . ## Use with grid #FilePattern gntp.*.ghep.root ## for specifying specific files to load FilePattern LoadWCSimTool ## use this pattern to load corresponding genie info with the LoadWCSimTool ## N.B: FileDir must still be specified for now! (WCSim files do not record their directory) +ManualFileMatching 0 ## to manually match GENIE event to corresponding WCSim event +FileEvents 1000 ## number of events in the WCSim file + ## 500 for Marcus files + ## 1000 for James files diff --git a/configfiles/LoadGenieEvents/ToolsConfig b/configfiles/LoadGenieEvents/ToolsConfig index de0f0b9c8..0775dc9af 100644 --- a/configfiles/LoadGenieEvents/ToolsConfig +++ b/configfiles/LoadGenieEvents/ToolsConfig @@ -1,3 +1,3 @@ myLoadWCSim LoadWCSim configfiles/LoadGenieEvents/LoadWCSimConfig myLoadGenieEvent LoadGenieEvent configfiles/LoadGenieEvents/LoadGenieEventConfig -myPrintGenieEvent PrintGenieEvent configfiles/LoadGenieEvents/PrintGenieEventConfig +#myPrintGenieEvent PrintGenieEvent configfiles/LoadGenieEvents/PrintGenieEventConfig diff --git a/configfiles/ReweightEventsGenie/LoadGenieEventConfig b/configfiles/ReweightEventsGenie/LoadGenieEventConfig new file mode 100644 index 000000000..d4ecc33f5 --- /dev/null +++ b/configfiles/ReweightEventsGenie/LoadGenieEventConfig @@ -0,0 +1,15 @@ +verbosity 100 +FluxVersion 0 # use 0 to load genie files based on bnb_annie_0000.root etc files + # use 1 to load files based on beammc_annie_0000.root etc files +FileDir NA # specify "NA" for newer files: full path is saved in WCSim +#FileDir /pnfs/annie/persistent/users/vfischer/genie_files/BNB_Water_10k_22-05-17 +#FileDir /pnfs/annie/persistent/users/moflaher/genie/BNB_World_10k_11-03-18_gsimpleflux +#FileDir /pnfs/annie/persistent/simulations/genie3/G1810a0211a/standard/tank +#FileDir . ## Use with grid +#FilePattern gntp.*.ghep.root ## for specifying specific files to load +FilePattern LoadWCSimTool ## use this pattern to load corresponding genie info with the LoadWCSimTool + ## N.B: FileDir must still be specified for now! (WCSim files do not record their directory) +ManualFileMatching 0 ## to manually match GENIE event to corresponding WCSim event +FileEvents 1000 ## number of events in the WCSim file + ## 500 for Marcus files + ## 1000 for James files diff --git a/configfiles/ReweightEventsGenie/ToolsConfig b/configfiles/ReweightEventsGenie/ToolsConfig index ce3117323..c8416646d 100644 --- a/configfiles/ReweightEventsGenie/ToolsConfig +++ b/configfiles/ReweightEventsGenie/ToolsConfig @@ -1,2 +1,14 @@ +myLoadGeometry LoadGeometry configfiles/LoadGeometry/LoadGeometryConfig myLoadWCSim LoadWCSim configfiles/ReweightEventsGenie/LoadWCSimConfig -myReweightEventsGenie ReweightEventsGenie configfiles/ReweightEventsGenie/ReweightEventsGenieConfig +myLoadWCSimLAPPD LoadWCSimLAPPD configfiles/ReweightEventsGenie/LoadWCSimLAPPDConfig +myLoadGenieEvent LoadGenieEvent configfiles/ReweightEventsGenie/LoadGenieEventConfig +#myReweightEventsGenie ReweightEventsGenie configfiles/ReweightEventsGenie/ReweightEventsGenieConfig +myMCParticleProperties MCParticleProperties configfiles/ReweightEventsGenie/MCParticlePropertiesConfig +myMCRecoEventLoader MCRecoEventLoader configfiles/ReweightEventsGenie/MCRecoEventLoaderConfig +myTimeClustering TimeClustering configfiles/ReweightEventsGenie/TimeClusteringConfig +myFindMrdTracks FindMrdTracks configfiles/ReweightEventsGenie/FindMrdTracksConfig +myClusterFinder ClusterFinder configfiles/ReweightEventsGenie/ClusterFinderConfig +myClusterClassifiers ClusterClassifiers configfiles/ReweightEventsGenie/ClusterClassifiersConfig +myDigitBuilder DigitBuilder configfiles/ReweightEventsGenie/DigitBuilderConfig +myEventSelector EventSelector configfiles/ReweightEventsGenie/EventSelectorConfig +myPhaseIITreeMaker PhaseIITreeMaker configfiles/ReweightEventsGenie/PhaseIITreeMakerConfig From f95c173bad217f60aee44e2eabc9a1778d1e87e3 Mon Sep 17 00:00:00 2001 From: Michael Nieslony <41126346+mnieslony@users.noreply.github.com> Date: Tue, 25 Jul 2023 14:02:38 +0200 Subject: [PATCH 05/31] Filter Events (#239) * Add FilterEvents tools * Update README.md of FilterEvents toolchain * removed FilterName config setting from FilterEvents tool * add FilteredEvent tag to FilterEvents output file * removed unnecessary Set(EventNumber) --- UserTools/EventSelector/EventSelector.cpp | 4 + UserTools/EventSelector/EventSelector.h | 1 + UserTools/Factory/Factory.cpp | 1 + UserTools/FilterEvents/FilterEvents.cpp | 140 ++++++++++++++++++ UserTools/FilterEvents/FilterEvents.h | 52 +++++++ UserTools/FilterEvents/README.md | 26 ++++ UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp | 8 +- UserTools/Unity.h | 1 + .../PhaseIITreeMakerConfig | 3 +- .../FilterEvents/ClusterClassifiersConfig | 1 + configfiles/FilterEvents/ClusterFinderConfig | 12 ++ configfiles/FilterEvents/FilterEventsConfig | 5 + configfiles/FilterEvents/FindMrdTracksConfig | 12 ++ configfiles/FilterEvents/LoadANNIEEventConfig | 4 + configfiles/FilterEvents/README.md | 38 +++++ configfiles/FilterEvents/TimeClusteringConfig | 13 ++ configfiles/FilterEvents/ToolChainConfig | 26 ++++ configfiles/FilterEvents/ToolsConfig | 8 + configfiles/FilterEvents/my_inputs.txt | 40 +++++ configfiles/Filters/BeamTriggerFilter | 30 ++++ configfiles/Filters/CosmicTriggerFilter | 30 ++++ configfiles/Filters/DirtCandidateFilter | 30 ++++ configfiles/Filters/NeutrinoCandidateFilter | 30 ++++ configfiles/Filters/ThroughgoingFilter | 30 ++++ 24 files changed, 541 insertions(+), 4 deletions(-) create mode 100644 UserTools/FilterEvents/FilterEvents.cpp create mode 100644 UserTools/FilterEvents/FilterEvents.h create mode 100644 UserTools/FilterEvents/README.md create mode 100644 configfiles/FilterEvents/ClusterClassifiersConfig create mode 100644 configfiles/FilterEvents/ClusterFinderConfig create mode 100644 configfiles/FilterEvents/FilterEventsConfig create mode 100644 configfiles/FilterEvents/FindMrdTracksConfig create mode 100644 configfiles/FilterEvents/LoadANNIEEventConfig create mode 100644 configfiles/FilterEvents/README.md create mode 100644 configfiles/FilterEvents/TimeClusteringConfig create mode 100644 configfiles/FilterEvents/ToolChainConfig create mode 100644 configfiles/FilterEvents/ToolsConfig create mode 100644 configfiles/FilterEvents/my_inputs.txt create mode 100644 configfiles/Filters/BeamTriggerFilter create mode 100644 configfiles/Filters/CosmicTriggerFilter create mode 100644 configfiles/Filters/DirtCandidateFilter create mode 100644 configfiles/Filters/NeutrinoCandidateFilter create mode 100644 configfiles/Filters/ThroughgoingFilter diff --git a/UserTools/EventSelector/EventSelector.cpp b/UserTools/EventSelector/EventSelector.cpp index 80c3dd5d3..2f353fee5 100644 --- a/UserTools/EventSelector/EventSelector.cpp +++ b/UserTools/EventSelector/EventSelector.cpp @@ -46,6 +46,7 @@ bool EventSelector::Initialise(std::string configfile, DataModel &data){ m_variables.Get("SaveStatusToStore", fSaveStatusToStore); m_variables.Get("IsMC",fIsMC); m_variables.Get("RecoPDG",fRecoPDG); + m_variables.Get("CutConfiguration",fCutConfigurationName); if (!fIsMC){fMCFVCut = false; fMCPMTVolCut = false; fMCMRDCut = false; fMCPiKCut = false; fMCIsMuonCut = false; fMCIsElectronCut = false; fMCIsSingleRingCut = false; fMCIsMultiRingCut = false; fMCProjectedMRDHit = false; fMCEnergyCut = false; fPromptTrigOnly = false;} @@ -69,6 +70,9 @@ bool EventSelector::Initialise(std::string configfile, DataModel &data){ m_data->CStore.Get("ChannelNumToTankPMTSPEChargeMap",ChannelNumToTankPMTSPEChargeMap); + m_data->CStore.Set("CutConfiguration",fCutConfigurationName); + + return true; } diff --git a/UserTools/EventSelector/EventSelector.h b/UserTools/EventSelector/EventSelector.h index cecbbc299..3e65cd47f 100644 --- a/UserTools/EventSelector/EventSelector.h +++ b/UserTools/EventSelector/EventSelector.h @@ -237,6 +237,7 @@ class EventSelector: public Tool { bool fIsMC; int fTriggerWord; int fRecoPDG; + std::string fCutConfigurationName; bool get_mrd = false; double pmt_time = 0; diff --git a/UserTools/Factory/Factory.cpp b/UserTools/Factory/Factory.cpp index 23bd35bef..706d3e4f1 100644 --- a/UserTools/Factory/Factory.cpp +++ b/UserTools/Factory/Factory.cpp @@ -156,6 +156,7 @@ if (tool=="LAPPDDataDecoder") ret=new LAPPDDataDecoder; if (tool=="PythonScript") ret=new PythonScript; if (tool=="ReweightEventsGenie") ret=new ReweightEventsGenie; if (tool=="FilterLAPPDEvents") ret=new FilterLAPPDEvents; +if (tool=="FilterEvents") ret=new FilterEvents; if (tool=="Stage1DataBuilder") ret=new Stage1DataBuilder; return ret; } diff --git a/UserTools/FilterEvents/FilterEvents.cpp b/UserTools/FilterEvents/FilterEvents.cpp new file mode 100644 index 000000000..3d3912524 --- /dev/null +++ b/UserTools/FilterEvents/FilterEvents.cpp @@ -0,0 +1,140 @@ +#include "FilterEvents.h" + +FilterEvents::FilterEvents():Tool(){} + + +bool FilterEvents::Initialise(std::string configfile, DataModel &data){ + + /////////////////// Useful header /////////////////////// + if(configfile!="") m_variables.Initialise(configfile); // loading config file + //m_variables.Print(); + + m_data= &data; //assigning transient data pointer + ///////////////////////////////////////////////////////////////// + + m_variables.Get("verbosity",verbosity); + m_variables.Get("FilteredFilesBasename",FilteredFilesBasename); + m_variables.Get("SavePath",SavePath); + + matched = 0; + + FilteredEvents = new BoostStore(false,2); + + std::string EventSelectorCutConfiguration; + m_data->CStore.Get("CutConfiguration",EventSelectorCutConfiguration); + FilterName = EventSelectorCutConfiguration; + + FilteredEvents->Header->Set("FilteredEvent",true); + FilteredEvents->Header->Set("FilterName",FilterName); + + return true; +} + + +bool FilterEvents::Execute(){ + + std::map dataStreams; + int runNumber, eventNumber, localEventNumber, partNumber; + m_data->Stores["ANNIEEvent"]->Get("DataStreams",dataStreams); + m_data->Stores["ANNIEEvent"]->Get("RunNumber",runNumber); + m_data->Stores["ANNIEEvent"]->Get("EventNumber",eventNumber); + m_data->Stores["ANNIEEvent"]->Get("LocalEventNumber",localEventNumber); + m_data->Stores["ANNIEEvent"]->Get("PartNumber",partNumber); + + + bool pass_filter = false; + m_data->Stores.at("RecoEvent")->Get("EventCutStatus", pass_filter); + + if (pass_filter){ + this->SetAndSaveEvent(); + matched++; + } + + return true; +} + + +bool FilterEvents::Finalise(){ + + FilteredEvents->Close(); + FilteredEvents->Delete(); + delete FilteredEvents; + std::cout<<"Number of matched run numbers, part numbers, and (local) event numbers: "< DataStreams; + std::string MRDTriggerType; + std::map MRDLoopbackTDC; + TriggerClass TriggerData; + BeamStatus BeamStatus; + std::map>* TDCData; + std::map> *Hits, *AuxHits; + std::map> RawAcqSize; + std::map>> RecoADCData, RecoAuxADCData; + PsecData LAPPDData; + + std::map> *NewTDCData = new std::map>; + std::map> *NewHits = new std::map>; + std::map> *NewAuxHits = new std::map>; + + // Get and Set all variables in the event to the new booststore + m_data->Stores["ANNIEEvent"]->Get("AuxHits",AuxHits); + for (auto&& entry : (*AuxHits)){ + NewAuxHits->emplace(entry.first,entry.second); + } + FilteredEvents->Set("AuxHits",NewAuxHits,true); + + m_data->Stores["ANNIEEvent"]->Get("BeamStatus",BeamStatus); FilteredEvents->Set("BeamStatus",BeamStatus); + m_data->Stores["ANNIEEvent"]->Get("CTCTimestamp",CTCTimestamp); FilteredEvents->Set("CTCTimestamp",CTCTimestamp); + m_data->Stores["ANNIEEvent"]->Get("DataStreams",DataStreams); FilteredEvents->Set("DataStreams",DataStreams); + m_data->Stores["ANNIEEvent"]->Get("EventNumber",EventNumber); FilteredEvents->Set("EventNumber",EventNumber); + m_data->Stores["ANNIEEvent"]->Get("EventTimeLAPPD",EventTimeLAPPD); FilteredEvents->Set("EventTimeLAPPD",EventTimeLAPPD); + m_data->Stores["ANNIEEvent"]->Get("EventTimeMRD",EventTimeMRD); FilteredEvents->Set("EventTimeMRD",EventTimeMRD); + m_data->Stores["ANNIEEvent"]->Get("EventTimeTank",EventTimeTank); FilteredEvents->Set("EventTimeTank",EventTimeTank); + m_data->Stores["ANNIEEvent"]->Get("Hits",Hits); + for (auto&& entry : (*Hits)){ + NewHits->emplace(entry.first,entry.second); + } + FilteredEvents->Set("Hits",NewHits,true); + +/* + m_data->Stores["ANNIEEvent"]->Get("LAPPDData",LAPPDData); FilteredEvents->Set("LAPPDData",LAPPDData); + m_data->Stores["ANNIEEvent"]->Get("LAPPDOffset",LAPPDOffset); FilteredEvents->Set("LAPPDOffset",LAPPDOffset); +*/ + m_data->Stores["ANNIEEvent"]->Get("LocalEventNumber",LocalEventNumber); FilteredEvents->Set("LocalEventNumber",LocalEventNumber); + m_data->Stores["ANNIEEvent"]->Get("MRDLoopbackTDC",MRDLoopbackTDC); FilteredEvents->Set("MRDLoopbackTDC",MRDLoopbackTDC); + m_data->Stores["ANNIEEvent"]->Get("MRDTriggerType",MRDTriggerType); FilteredEvents->Set("MRDTriggerType",MRDTriggerType); + m_data->Stores["ANNIEEvent"]->Get("PartNumber",PartNumber); FilteredEvents->Set("PartNumber",PartNumber); + m_data->Stores["ANNIEEvent"]->Get("RawAcqSize",RawAcqSize); FilteredEvents->Set("RawAcqSize",RawAcqSize); + m_data->Stores["ANNIEEvent"]->Get("RecoADCData",RecoADCData); FilteredEvents->Set("RecoADCData",RecoADCData); + m_data->Stores["ANNIEEvent"]->Get("RecoAuxADCData",RecoAuxADCData); FilteredEvents->Set("RecoAuxADCData",RecoAuxADCData); + m_data->Stores["ANNIEEvent"]->Get("RunNumber",RunNumber); FilteredEvents->Set("RunNumber",RunNumber); + m_data->Stores["ANNIEEvent"]->Get("RunStartTime",RunStartTime); FilteredEvents->Set("RunStartTime",RunStartTime); + m_data->Stores["ANNIEEvent"]->Get("RunType",RunType); FilteredEvents->Set("RunType",RunType); + m_data->Stores["ANNIEEvent"]->Get("SubrunNumber",SubrunNumber); FilteredEvents->Set("SubrunNumber",SubrunNumber); + m_data->Stores["ANNIEEvent"]->Get("TDCData",TDCData); + for (auto&& entry : (*TDCData)){ + NewTDCData->emplace(entry.first,entry.second); + } + + FilteredEvents->Set("TDCData",NewTDCData,true); + m_data->Stores["ANNIEEvent"]->Get("TriggerData",TriggerData); FilteredEvents->Set("TriggerData",TriggerData); + m_data->Stores["ANNIEEvent"]->Get("TriggerExtended",TriggerExtended); FilteredEvents->Set("TriggerExtended",TriggerExtended); + m_data->Stores["ANNIEEvent"]->Get("TriggerWord",TriggerWord); FilteredEvents->Set("TriggerWord",TriggerWord); + + std::string Filename = SavePath + "/" + FilteredFilesBasename + "_" + FilterName; + + if (verbosity>0) std::cout<<"Filename is "<Save(Filename); + FilteredEvents->Delete(); + +} diff --git a/UserTools/FilterEvents/FilterEvents.h b/UserTools/FilterEvents/FilterEvents.h new file mode 100644 index 000000000..4d88282c9 --- /dev/null +++ b/UserTools/FilterEvents/FilterEvents.h @@ -0,0 +1,52 @@ +#ifndef FilterEvents_H +#define FilterEvents_H + +#include +#include + +#include "Tool.h" + +#include "ADCPulse.h" +#include "PsecData.h" +#include "Hit.h" + +/** + * \class FilterEvents + * + * This is a blank template for a Tool used by the script to generate a new custom tool. Please fill out the description and author information. +* +* $Author: B.Richards $ +* $Date: 2019/05/28 10:44:00 $ +* Contact: b.richards@qmul.ac.uk +*/ +class FilterEvents: public Tool { + + + public: + + FilterEvents(); ///< Simple constructor + bool Initialise(std::string configfile,DataModel &data); ///< Initialise Function for setting up Tool resources. @param configfile The path and name of the dynamic configuration file to read in. @param data A reference to the transient data class used to pass information between Tools. + bool Execute(); ///< Execute function used to perform Tool purpose. + bool Finalise(); ///< Finalise function used to clean up resources. + + void SetAndSaveEvent(); + + private: + + std::string FilterName; + std::string FilteredFilesBasename; + std::string SavePath; + int verbosity; + BoostStore* FilteredEvents = nullptr; + int matched; + + int v_error = 0; + int v_warning = 1; + int v_message = 2; + int v_debug = 3; + int vv_debug = 4; + +}; + + +#endif diff --git a/UserTools/FilterEvents/README.md b/UserTools/FilterEvents/README.md new file mode 100644 index 000000000..626a17d5d --- /dev/null +++ b/UserTools/FilterEvents/README.md @@ -0,0 +1,26 @@ +# FilterEvents + +The `FilterEvents` tool reads in ANNIEEvent BoostStore files and saves them to a Filtered output BoostStore files in case selected cuts were passed for a given event. The cuts themselves are defined in the `EventSelector` tool and official filters should be defined in the `configfiles/Filters/` directory. + +## Data + +The `FilterEvents` tool reads in the complete `ANNIEEvent` BoostStore file and saves all the objects to a new, filtered output BoostStore file. + +* Input data: `ANNIEEvent` BoostStore (typically loaded with the `LoadANNIEEvent` tool) +* Output data: `ANNIEEvent` BoostStore, saved to a new file. Only events which passed the cuts specified in the `EventSelector` tool are saved to this output BoostStore file + +Within the output BoostStore file, a separate flag indicates that the events have been filtered. This flag is a Boolean and is called "FilteredEvent". In addition, the FilterName is also saved to the output BoostStore: + +* `FilteredEvent (bool)`: indicates whether the object is part of a filtered output BoostStore file +* `FilterName (string)`: The name of the applied filter in the `EventSelector` tool. + +## Configuration + +`FilterEvents` uses the following configuration variables: + +``` +verbosity 2 #how much logging output do you want? +FilteredFilesBasename FilteredEvents #base name of the BoostStore output files + #the name of the Filter will be appended automatically to this basename +SavePath /path/to/output/ #where should the output files be stored +``` diff --git a/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp b/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp index 44c12418a..c0185d63d 100644 --- a/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp +++ b/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp @@ -271,13 +271,15 @@ bool LoadANNIEEvent::Execute() { if ((int)current_entry_ != offset_evnum) m_data->Stores["ANNIEEvent"]->Delete(); //ensures that we can access pointers without problems m_data->Stores["ANNIEEvent"]->GetEntry(current_entry_); - if (!m_data->Stores["ANNIEEvent"]->Has("LocalEventNumber")){ m_data->Stores["ANNIEEvent"]->Set("LocalEventNumber",current_entry_); } + bool has_local = (m_data->Stores["ANNIEEvent"]->Has("LocalEventNumber")); + bool has_global = (m_data->Stores["ANNIEEvent"]->Has("EventNumber")); + if (!has_local){ m_data->Stores["ANNIEEvent"]->Set("LocalEventNumber",current_entry_);} ++current_entry_; - if (global_evnr && !m_data->Stores["ANNIEEvent"]->Has("LocalEventNumber")){ m_data->Stores["ANNIEEvent"]->Set("EventNumber",global_ev); } - global_ev++; + if (global_evnr && !has_local){ m_data->Stores["ANNIEEvent"]->Set("EventNumber",global_ev); } + global_ev++; if ( current_entry_ >= total_entries_in_file_ ) { ++current_file_; diff --git a/UserTools/Unity.h b/UserTools/Unity.h index 107493137..7fab6b155 100644 --- a/UserTools/Unity.h +++ b/UserTools/Unity.h @@ -164,4 +164,5 @@ #include "PythonScript.h" #include "ReweightEventsGenie.h" #include "FilterLAPPDEvents.h" +#include "FilterEvents.h" #include "Stage1DataBuilder.h" diff --git a/configfiles/BeamClusterAnalysis/PhaseIITreeMakerConfig b/configfiles/BeamClusterAnalysis/PhaseIITreeMakerConfig index 127319f9a..eee2e9cb4 100644 --- a/configfiles/BeamClusterAnalysis/PhaseIITreeMakerConfig +++ b/configfiles/BeamClusterAnalysis/PhaseIITreeMakerConfig @@ -13,4 +13,5 @@ MCTruth_fill 0 Reco_fill 0 RecoDebug_fill 0 muonTruthRecoDiff_fill 0 - +IsData 1 +HasGenie 0 diff --git a/configfiles/FilterEvents/ClusterClassifiersConfig b/configfiles/FilterEvents/ClusterClassifiersConfig new file mode 100644 index 000000000..752200268 --- /dev/null +++ b/configfiles/FilterEvents/ClusterClassifiersConfig @@ -0,0 +1 @@ +verbosity 0 diff --git a/configfiles/FilterEvents/ClusterFinderConfig b/configfiles/FilterEvents/ClusterFinderConfig new file mode 100644 index 000000000..337d7fc2e --- /dev/null +++ b/configfiles/FilterEvents/ClusterFinderConfig @@ -0,0 +1,12 @@ +# ClusterFinder Config File + +verbosity 0 +HitStore Hits #Either MCHits or Hits (accessed in ANNIEEvent store) +OutputFile BeamRun_ClusterFinder_DefaultOutput #Output root prefix name for the current run +ClusterFindingWindow 100 # in ns, size of the window used to "clusterize" +AcqTimeWindow 70000 # in ns, size of the acquisition window +ClusterIntegrationWindow 100 # in ns, all hits with +/- 1/2 of this window are considered in the cluster +MinHitsPerCluster 5 # group of hits are considered clusters above this amount of hits +end_of_window_time_cut 0.95 # from o to 1, length of the window you want to loop over with respect to acq. window (1 for full window, 0.95 for 95% from the start) +Plots2D 0 #Draw 2D charge-vs-time plots? +ChankeyToPMTIDMap ./configfiles/EventDisplay/Data-RecoEvent/Chankey_WCSimID.dat diff --git a/configfiles/FilterEvents/FilterEventsConfig b/configfiles/FilterEvents/FilterEventsConfig new file mode 100644 index 000000000..be8fd03a6 --- /dev/null +++ b/configfiles/FilterEvents/FilterEventsConfig @@ -0,0 +1,5 @@ +# FilterEvents config file + +verbosity 2 +FilteredFilesBasename FilteredEvents_R2630 +SavePath . diff --git a/configfiles/FilterEvents/FindMrdTracksConfig b/configfiles/FilterEvents/FindMrdTracksConfig new file mode 100644 index 000000000..5ba5e8f77 --- /dev/null +++ b/configfiles/FilterEvents/FindMrdTracksConfig @@ -0,0 +1,12 @@ +# FindMrdTracks Config File +# all variables retrieved with m_variables.Get() must be defined here! + +verbosity 0 +IsData 1 +OutputDirectory . +OutputFile STEC_MRDTracks_cluster40ns +DrawTruthTracks 0 # whether to add MC Truth track info for drawing in MrdPaddlePlot Tool + ## note you need to run that tool to actually view the tracks! +WriteTracksToFile 0 # should the track information be written to a ROOT-file? +SelectTriggerType 0 #should the loaded data be filtered by trigger type? +TriggerType Beam #options: Cosmic, Beam, No Loopback diff --git a/configfiles/FilterEvents/LoadANNIEEventConfig b/configfiles/FilterEvents/LoadANNIEEventConfig new file mode 100644 index 000000000..e156c4b29 --- /dev/null +++ b/configfiles/FilterEvents/LoadANNIEEventConfig @@ -0,0 +1,4 @@ +verbose 0 +FileForListOfInputs ./configfiles/FilterEvents/my_inputs.txt +EventOffset 0 +GlobalEvNr 1 diff --git a/configfiles/FilterEvents/README.md b/configfiles/FilterEvents/README.md new file mode 100644 index 000000000..d8fcaf99e --- /dev/null +++ b/configfiles/FilterEvents/README.md @@ -0,0 +1,38 @@ +# FilterEvents toolchain + +*********************** +# Description +********************** + +The `FilterEvents` toolchain uses cuts from the `EventSelector` tool to filter out events passing the selected cuts. The filtered events are then saved to a new dedicated output BoostStore that only contains the filtered events. The output BoostStore file will contain all the variables from the `ANNIEEvent` BoostStore and can be used in a toolchain like a regular processed data file. + +Filters that define the specific event selection cuts should be defined in the `configfiles/Filters/` directory. Currently the following filters are defined: + +* NeutrinoCandidate +* DirtCandidate +* Throughgoing +* BeamTrigger +* CosmicTrigger + +Each filter is defined by a unique name, which is passed on to the `FilterEvents` tool via the common `CStore`. The variable is then used as a part of the output BoostStore file. This guarantees that the output BoostStore will contain the name of the official Filter and it is easily recognizable which filter was used for a specific file. + +************************ +# ToolsConfig +************************ + +The following tools are in the `FilterEvents` toolchain: + +``` +myLoadANNIEEvent LoadANNIEEvent ./configfiles/FilterEvents/LoadANNIEEventConfig +myLoadGeometry LoadGeometry ./configfiles/LoadGeometry/LoadGeometryConfig +myTimeClustering TimeClustering configfiles/FilterEvents/TimeClusteringConfig +myFindMrdTracks FindMrdTracks configfiles/FilterEvents/FindMrdTracksConfig +myClusterFinder ClusterFinder ./configfiles/FilterEvents/ClusterFinderConfig +myClusterClassifiers ClusterClassifiers ./configfiles/FilterEvents/ClusterClassifiersConfig +myEventSelector EventSelector ./configfiles/Filters/NeutrinoCandidateFilter +myFilterEvents FilterEvents ./configfiles/FilterEvents/FilterEventsConfig +``` + +The `EventSelector` row can be adjusted if a different filter should be used. + +New filters can be defined in the `configfiles/Filters` directory. However, old filters should not be changed in any way to preserve the uniqueness of filters. If a filter needs to be updated, one should rather define a new filter with a unique name, e.g. `NeutrinoCandidate_v2` for updated neutrino candidate cuts. diff --git a/configfiles/FilterEvents/TimeClusteringConfig b/configfiles/FilterEvents/TimeClusteringConfig new file mode 100644 index 000000000..e778247fc --- /dev/null +++ b/configfiles/FilterEvents/TimeClusteringConfig @@ -0,0 +1,13 @@ +#TimeClustering config file + +verbosity 0 +MinDigitsForTrack 3 +MaxMrdSubEventDuration 30 +MinSubeventTimeSep 30 +MakeMrdDigitTimePlot 0 +LaunchTApplication 0 +IsData 1 +#OutputROOTFile TimeClustering_MRDTest28_cluster40ns +OutputROOTFile STEC_TimeClusteringOut +MapChankey_WCSimID ./configfiles/SimpleTankEnergyCalibrator/MRD_Chankey_WCSimID.dat + diff --git a/configfiles/FilterEvents/ToolChainConfig b/configfiles/FilterEvents/ToolChainConfig new file mode 100644 index 000000000..3914a3384 --- /dev/null +++ b/configfiles/FilterEvents/ToolChainConfig @@ -0,0 +1,26 @@ +#ToolChain dynamic setup file + +##### Runtime Parameters ##### +verbose 1 ## Verbosity level of ToolChain +error_level 0 # 0= do not exit, 1= exit on unhandled errors only, 2= exit on unhandled errors and handled errors +attempt_recover 1 ## 1= will attempt to finalise if an execute fails +remote_port 24002 +IO_Threads 1 ## Number of threads for network traffic (~ 1/Gbps) + +###### Logging ##### +log_mode Interactive # Interactive=cout , Remote= remote logging system "serservice_name Remote_Logging" , Local = local file log; +log_local_path ./log +log_service LogStore + + +###### Service discovery ##### Ignore these settings for local analysis +service_publish_sec -1 +service_kick_sec -1 + +##### Tools To Add ##### +Tools_File configfiles/FilterEvents/ToolsConfig ## list of tools to run and their config files + +##### Run Type ##### +Inline -1 ## number of Execute steps in program, -1 infinite loop that is ended by user +Interactive 0 ## set to 1 if you want to run the code interactively + diff --git a/configfiles/FilterEvents/ToolsConfig b/configfiles/FilterEvents/ToolsConfig new file mode 100644 index 000000000..fb87974e1 --- /dev/null +++ b/configfiles/FilterEvents/ToolsConfig @@ -0,0 +1,8 @@ +myLoadANNIEEvent LoadANNIEEvent ./configfiles/FilterEvents/LoadANNIEEventConfig +myLoadGeometry LoadGeometry ./configfiles/LoadGeometry/LoadGeometryConfig +myTimeClustering TimeClustering configfiles/FilterEvents/TimeClusteringConfig +myFindMrdTracks FindMrdTracks configfiles/FilterEvents/FindMrdTracksConfig +myClusterFinder ClusterFinder ./configfiles/FilterEvents/ClusterFinderConfig +myClusterClassifiers ClusterClassifiers ./configfiles/FilterEvents/ClusterClassifiersConfig +myEventSelector EventSelector ./configfiles/Filters/NeutrinoCandidateFilter +myFilterEvents FilterEvents ./configfiles/FilterEvents/FilterEventsConfig diff --git a/configfiles/FilterEvents/my_inputs.txt b/configfiles/FilterEvents/my_inputs.txt new file mode 100644 index 000000000..104d12651 --- /dev/null +++ b/configfiles/FilterEvents/my_inputs.txt @@ -0,0 +1,40 @@ +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p0 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p1 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p2 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p3 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p4 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p5 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p6 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p7 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p8 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p9 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p10 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p11 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p12 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p13 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p14 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p15 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p16 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p17 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p18 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p19 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p20 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p21 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p22 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p23 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p24 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p25 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p26 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p27 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p28 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p29 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p30 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p31 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p32 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p33 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p34 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p35 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p36 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p37 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p38 +/pnfs/annie/persistent/processed/processed_hits/R2630/ProcessedRawData_TankAndMRDAndCTC_R2630S0p39 diff --git a/configfiles/Filters/BeamTriggerFilter b/configfiles/Filters/BeamTriggerFilter new file mode 100644 index 000000000..c64479202 --- /dev/null +++ b/configfiles/Filters/BeamTriggerFilter @@ -0,0 +1,30 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 0 +MCMRDCut 0 +MCPiKCut 0 +MCIsMuonCut 0 +MCIsElectronCut 0 +MCIsSingleRingCut 0 +MCIsMultiRingCut 0 +MCProjectedMRDHit 0 +MCEnergyCut 0 +Emin 0 #Minimum energy in MeV +Emax 1000 #Maximum energy in MeV +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 0 +NHitmin 4 #Minimum number of hit digits +PMTMRDCoincCut 0 +PMTMRDOffset 745 +PromptTrigOnly 0 +TriggerWord 5 +SaveStatusToStore 1 +NoVeto 0 +Veto 0 +ThroughGoing 0 +IsMC 0 #MC or Data? +CutConfiguration BeamTrigger diff --git a/configfiles/Filters/CosmicTriggerFilter b/configfiles/Filters/CosmicTriggerFilter new file mode 100644 index 000000000..b868f86bc --- /dev/null +++ b/configfiles/Filters/CosmicTriggerFilter @@ -0,0 +1,30 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 0 +MCMRDCut 0 +MCPiKCut 0 +MCIsMuonCut 0 +MCIsElectronCut 0 +MCIsSingleRingCut 0 +MCIsMultiRingCut 0 +MCProjectedMRDHit 0 +MCEnergyCut 0 +Emin 0 #Minimum energy in MeV +Emax 1000 #Maximum energy in MeV +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 0 +NHitmin 4 #Minimum number of hit digits +PMTMRDCoincCut 0 +PMTMRDOffset 745 +PromptTrigOnly 0 +TriggerWord 36 +SaveStatusToStore 1 +NoVeto 0 +Veto 0 +ThroughGoing 0 +IsMC 0 #MC or Data? +CutConfiguration CosmicTrigger diff --git a/configfiles/Filters/DirtCandidateFilter b/configfiles/Filters/DirtCandidateFilter new file mode 100644 index 000000000..bf16f9a78 --- /dev/null +++ b/configfiles/Filters/DirtCandidateFilter @@ -0,0 +1,30 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 0 +MCMRDCut 0 +MCPiKCut 0 +MCIsMuonCut 0 +MCIsElectronCut 0 +MCIsSingleRingCut 0 +MCIsMultiRingCut 0 +MCProjectedMRDHit 0 +MCEnergyCut 0 +Emin 0 #Minimum energy in MeV +Emax 1000 #Maximum energy in MeV +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 0 +NHitmin 4 #Minimum number of hit digits +PMTMRDCoincCut 1 +PMTMRDOffset 745 +PromptTrigOnly 0 +TriggerWord 5 +SaveStatusToStore 1 +NoVeto 0 +Veto 1 +ThroughGoing 0 +IsMC 0 #MC or Data? +CutConfiguration DirtCandidate diff --git a/configfiles/Filters/NeutrinoCandidateFilter b/configfiles/Filters/NeutrinoCandidateFilter new file mode 100644 index 000000000..ea56f2fbb --- /dev/null +++ b/configfiles/Filters/NeutrinoCandidateFilter @@ -0,0 +1,30 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 0 +MCMRDCut 0 +MCPiKCut 0 +MCIsMuonCut 0 +MCIsElectronCut 0 +MCIsSingleRingCut 0 +MCIsMultiRingCut 0 +MCProjectedMRDHit 0 +MCEnergyCut 0 +Emin 0 #Minimum energy in MeV +Emax 1000 #Maximum energy in MeV +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 0 +NHitmin 4 #Minimum number of hit digits +PMTMRDCoincCut 1 +PMTMRDOffset 745 +PromptTrigOnly 0 +TriggerWord 5 +SaveStatusToStore 1 +NoVeto 1 +Veto 0 +ThroughGoing 0 +IsMC 0 #MC or Data? +CutConfiguration NeutrinoCandidate diff --git a/configfiles/Filters/ThroughgoingFilter b/configfiles/Filters/ThroughgoingFilter new file mode 100644 index 000000000..44d42c291 --- /dev/null +++ b/configfiles/Filters/ThroughgoingFilter @@ -0,0 +1,30 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 0 +MCMRDCut 0 +MCPiKCut 0 +MCIsMuonCut 0 +MCIsElectronCut 0 +MCIsSingleRingCut 0 +MCIsMultiRingCut 0 +MCProjectedMRDHit 0 +MCEnergyCut 0 +Emin 0 #Minimum energy in MeV +Emax 1000 #Maximum energy in MeV +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 0 +NHitmin 4 #Minimum number of hit digits +PMTMRDCoincCut 1 +PMTMRDOffset 745 +PromptTrigOnly 0 +TriggerWord -1 +SaveStatusToStore 1 +NoVeto 0 +Veto 1 +ThroughGoing 1 +IsMC 0 #MC or Data? +CutConfiguration Throughgoing From 209cf53ae0283a37d3170c8b1c7243361de81cba Mon Sep 17 00:00:00 2001 From: Andrew Sutton <75585895+atcsutton@users.noreply.github.com> Date: Tue, 25 Jul 2023 07:09:49 -0500 Subject: [PATCH 06/31] New BeamFetcher (#241) * Here's a new BeamFetcher tool that grabs things based on the trigger timestamp * Committing the other files to make the new BeamFetcher work --- DataModel/BeamDataPoint.h | 11 +- UserTools/BeamFetcherV2/BeamFetcherV2.cpp | 283 +++++++++++++ UserTools/BeamFetcherV2/BeamFetcherV2.h | 75 ++++ .../BeamFetcherV2/IFBeamDBInterfaceV2.cpp | 377 ++++++++++++++++++ UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.h | 90 +++++ UserTools/BeamFetcherV2/README.md | 48 +++ UserTools/Factory/Factory.cpp | 1 + UserTools/Unity.h | 1 + 8 files changed, 882 insertions(+), 4 deletions(-) create mode 100644 UserTools/BeamFetcherV2/BeamFetcherV2.cpp create mode 100644 UserTools/BeamFetcherV2/BeamFetcherV2.h create mode 100644 UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.cpp create mode 100644 UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.h create mode 100644 UserTools/BeamFetcherV2/README.md diff --git a/DataModel/BeamDataPoint.h b/DataModel/BeamDataPoint.h index 3680456d6..2412ead2c 100644 --- a/DataModel/BeamDataPoint.h +++ b/DataModel/BeamDataPoint.h @@ -18,22 +18,25 @@ struct BeamDataPoint : public SerialisableObject { friend class boost::serialization::access; - BeamDataPoint() : value(0.), unit("") {} - BeamDataPoint(double Value, const std::string& Unit) - : value(Value), unit(Unit) {} + BeamDataPoint() : value(0.), unit(""), time(0) {} + BeamDataPoint(double Value, const std::string& Unit, uint64_t time=0) + : value(Value), unit(Unit), time(0) {} double value; std::string unit; + uint64_t time; template void serialize(Archive & ar, const unsigned int version) { ar & value; ar & unit; + ar & time; } virtual bool Print() override { std::cout << "Value : " << value << '\n'; - std::cout << "Unit : " << unit << '\n'; + std::cout << "Unit : " << unit << '\n'; + std::cout << "Time : " << time << '\n'; return true; } diff --git a/UserTools/BeamFetcherV2/BeamFetcherV2.cpp b/UserTools/BeamFetcherV2/BeamFetcherV2.cpp new file mode 100644 index 000000000..5831fb4ed --- /dev/null +++ b/UserTools/BeamFetcherV2/BeamFetcherV2.cpp @@ -0,0 +1,283 @@ +// standard library includes +#include +#include + +// ToolAnalysis includes +#include "BeamFetcherV2.h" +#include "IFBeamDBInterfaceV2.h" + +namespace { + constexpr uint64_t TWO_HOURS = 7200000ull; // ms + constexpr uint64_t THIRTY_SECONDS = 30000ull; // ms +} + +BeamFetcherV2::BeamFetcherV2():Tool() +{} + +//------------------------------------------------------------------------------ +bool BeamFetcherV2::Initialise(std::string config_filename, DataModel& data) +{ + // Load configuration file variables + if ( !config_filename.empty() ) m_variables.Initialise(config_filename); + + // Assign a transient data pointer + m_data = &data; + + // Get the things + bool got_verbosity = m_variables.Get("verbose", verbosity); + bool got_bundleflag = m_variables.Get("IsBundle", fIsBundle); + bool got_devicesfile = m_variables.Get("DevicesFile", fDevicesFile); + bool got_saveroot = m_variables.Get("SaveROOT", fSaveROOT); + bool got_chunkMSec = m_variables.Get("TimeChunkStepInMilliseconds", fChunkStepMSec); + + + // Check the config parameters and set default values if necessary + if (!got_verbosity) verbosity = 1; + + if (!got_devicesfile) { + logmessage = ("Error (BeamFetcherV2): You must define which devices to poll" + " via a DevicesFile."); + Log(logmessage, v_error, verbosity); + return false; + } else { + // Grab the stuff from the file + std::ifstream devicesFile(fDevicesFile); + if ( devicesFile.good() ) { + std::string line; + while (std::getline(devicesFile, line)) + fDevices.push_back(line); + + if (!fDevices.size()) { + logmessage = ("Error (BeamFetcherV2): No devices specified in your" + " Devices file."); + Log(logmessage, v_error, verbosity); + return false; + } + } else{ + logmessage = ("Error (BeamFetcherV2): Devices file " + "\"" + fDevicesFile + "\"" + " does not exists"); + Log(logmessage, v_error, verbosity); + return false; + } + devicesFile.close(); + } + + if (!got_saveroot) { + logmessage = ("Warning (BeamFetcherV2): SaveROOT was not" + " set in the config file. Using default \"false\""); + Log(logmessage, v_warning, verbosity); + fSaveROOT = false; + } + + + if (!got_chunkMSec) { + logmessage = ("Warning (BeamFetcherV2): TimeChunkStepInMilliseconds was not" + " set in the config file. Using default \"7200000\""); + Log(logmessage, v_warning, verbosity); + fChunkStepMSec = 7200000; + } + + + if (!got_bundleflag || (fIsBundle !=0 && fIsBundle != 1)) { + logmessage = ("Error (BeamFetcherV2): IsBundle flag was not set correctly" + " in the config file."); + Log(logmessage, v_error, verbosity); + return 0; + } + + if (fSaveROOT) this->SetupROOTFile(); + + return true; +} + + +//------------------------------------------------------------------------------ +bool BeamFetcherV2::Execute() +{ + // Do the things + bool goodFetch = this->FetchFromTrigger(); + + if (goodFetch) { + // Emplace fBeamDataToSave to CStore for other tools to use + m_data->CStore.Set("BeamData",fBeamDataToSave); + goodFetch = true; + } + + if (fSaveROOT) this->WriteTrees(); + + // Clear for the next Fetch + fBeamDataToSave.clear(); + + + return goodFetch; +} + +//------------------------------------------------------------------------------ +bool BeamFetcherV2::Finalise() +{ + if (fSaveROOT) this->SaveROOTFile(); + + std::cout << "BeamFetcherV2 tool exitting" << std::endl; + + return true; +} + +//------------------------------------------------------------------------------ +bool BeamFetcherV2::FetchFromTrigger() +{ + // Get a const reference to the beam database interface + const auto& db = IFBeamDBInterfaceV2::Instance(); + + // Need to get the trigger times + std::map>* TimeToTriggerWordMap=nullptr; + bool get_ok = m_data->CStore.Get("TimeToTriggerWordMap",TimeToTriggerWordMap); + + // Now loop over the CTC timestamps + if (get_ok && TimeToTriggerWordMap) { + for (auto iterator : *TimeToTriggerWordMap) { + // We only want to get beam info for beam triggers (word 5) + bool hasBeamTrig = false; + for (auto word : iterator.second) + if (word == 5) hasBeamTrig = true; + if (!hasBeamTrig) continue; + + uint64_t trigTimestamp = iterator.first; + + // Need to drop from ns to ms. This means that some timestamps will + // already be recorded. We can skip these cases + trigTimestamp = trigTimestamp/1E6; + if (fBeamDataToSave.find(trigTimestamp) != fBeamDataToSave.end()) + continue; + + // Check if we already have the info we need + bool fetch = false; + std::map >::iterator low, prev; + low = fBeamData.lower_bound(trigTimestamp); + if (low == fBeamData.end()) { + fetch = true; + logmessage = ("BeamFetcherV2: I'm going to query the DB"); + Log(logmessage, v_message, verbosity); + } + + // We'll pull fChunkStepMSec worth of data at a time to avoid rapid queries + if (fetch) { + if (fIsBundle) { + fBeamData = db.QueryBeamDBBundleSpan(fDevices[0], trigTimestamp, trigTimestamp+fChunkStepMSec); + } else { + std::map > tempMap; + + for (auto device : fDevices) { + auto tempMap = db.QueryBeamDBSingleSpan(device, trigTimestamp, trigTimestamp+fChunkStepMSec); + fBeamData.insert(tempMap.begin(), tempMap.end()); + } + } + } + + // Now we can match the Beam info to CTC timestamps for saving to the CStore + low = fBeamData.lower_bound(trigTimestamp); + if (low == fBeamData.end()) { + logmessage = ("Error (BeamFetcherV2): We fetched the data based on the CTC" + " but somehow didn't turn anything up!?"); + Log(logmessage, v_error, verbosity); + return false; + } else if (low == fBeamData.begin()) { + fBeamDataToSave[trigTimestamp] = low->second; + } else { + // Check the previous DB timestamp to see if it's closer in time + prev = std::prev(low); + if ((trigTimestamp - prev->first) < (low->first - trigTimestamp)) + fBeamDataToSave[trigTimestamp] = prev->second; + else + fBeamDataToSave[trigTimestamp] = low->second; + } + }// end loop over trigger times + } else { + logmessage = ("Error (BeamFetcherV2): Could not load CTC information for" + " timestamps. Did you run TriggerDataDecoder?"); + Log(logmessage, v_error, verbosity); + return false; + } + + return true; +} + +//------------------------------------------------------------------------------ +bool BeamFetcherV2::SaveToFile() +{ + BoostStore fBeamDBStore(false, BOOST_STORE_MULTIEVENT_FORMAT); + fBeamDBStore.Set("BeamData", fBeamData); + fBeamDBStore.Save(fOutFileName); + fBeamDBStore.Delete(); + + fBeamDBStore.Header->Set("BeamDBIndex", fBeamDBIdx); + + // Find the range of times covered by the entire downloaded database + uint64_t overall_start_ms = std::numeric_limits::max(); + uint64_t overall_end_ms = 0ull; + + for (const auto& pair : fBeamDBIdx) { + uint64_t temp_start_ms = pair.second.first; + uint64_t temp_end_ms = pair.second.second; + if (temp_start_ms < overall_start_ms) overall_start_ms = temp_start_ms; + if (temp_end_ms > overall_end_ms) overall_end_ms = temp_end_ms; + } + + fBeamDBStore.Header->Set("StartMillisecondsSinceEpoch", overall_start_ms); + fBeamDBStore.Header->Set("EndMillisecondsSinceEpoch", overall_end_ms); + + fBeamDBStore.Close(); + + logmessage = "Retrieval of beam status data complete"; + Log(logmessage, v_warning, verbosity); + + return true; +} + +//------------------------------------------------------------------------------ +void BeamFetcherV2::SetupROOTFile() +{ + fOutFile = new TFile("beamfetcher_tree.root", "RECREATE"); + fOutTree = new TTree("BeamTree", "BeamTree"); + fOutTree->Branch("Timestamp", &fTimestamp); +} + +//------------------------------------------------------------------------------ +void BeamFetcherV2::WriteTrees() +{ + // Loop over timestamps + int devCounter = 0; + for (const auto iterTS : fBeamDataToSave) { + fTimestamp = iterTS.first; + + // Loop over devices + for (const auto iterDev : iterTS.second) { + std::string device = iterDev.first; + std::replace( device.begin(), device.end(), ':', '_'); + + BeamDataPoint tempPoint = iterDev.second; + + // Dynamically create branches for each new device + if (fDevIdx.find(device) == fDevIdx.end()) { + fDevIdx[device] = devCounter; + fOutTree->Branch(device.c_str(), + &fValues[fDevIdx.at(device)]); + ++devCounter; + } + + fValues[fDevIdx.at(device)] = tempPoint.value; + }// end loop over devices + + fOutTree->Fill(); + }// end loop over timestamps + +} + +//------------------------------------------------------------------------------ +void BeamFetcherV2::SaveROOTFile() +{ + fOutFile->cd(); + fOutTree->Write(); + fOutFile->Close(); +} + diff --git a/UserTools/BeamFetcherV2/BeamFetcherV2.h b/UserTools/BeamFetcherV2/BeamFetcherV2.h new file mode 100644 index 000000000..94056ea72 --- /dev/null +++ b/UserTools/BeamFetcherV2/BeamFetcherV2.h @@ -0,0 +1,75 @@ +// Tool to download beam information from the Intensity Frontier +// beam database and save it to the CStore. Modified from the original BeamFetcher +// +// Steven Gardiner +// Andrew Sutton + +#pragma once + +// standard library includes +#include +#include + +// Boost includes +#include +#include + +// ToolAnalysis includes +#include "Tool.h" + +// ROOT includes +#include "TFile.h" +#include "TTree.h" + + +class BeamFetcherV2: public Tool { + + public: + BeamFetcherV2(); + bool Initialise(std::string configfile, DataModel& data); + bool Execute(); + bool Finalise(); + + protected: + bool FetchFromTrigger(); + bool SaveToFile(); + + void SetupROOTFile(); + void WriteTrees(); + void SaveROOTFile(); + + + // Holder for the retrieved data and the stuff we'll save + std::map > fBeamData; + std::map > fBeamDataToSave; + + // For saving out to a file + std::map > fBeamDBIdx; + + // Holder for the devices we're going to look up + std::vector fDevices; + + // For ROOT file + TFile *fOutFile; + TTree *fOutTree; + uint64_t fTimestamp; + double fValues[100]; + std::map fDevIdx; // map from device string to idx in fValues + + + // Configuration variables + int verbosity; + bool fIsBundle; + bool fSaveROOT; + std::string fDevicesFile; + std::string fOutFileName; + uint64_t fChunkStepMSec; + + // Verbosity things + int v_error = 0; + int v_warning = 1; + int v_message = 2; + int v_debug = 3; + int vv_debug = 4; + std::string logmessage; +}; diff --git a/UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.cpp b/UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.cpp new file mode 100644 index 000000000..99e0a5148 --- /dev/null +++ b/UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.cpp @@ -0,0 +1,377 @@ +// standard library includes +#include +#include +#include +#include +#include +#include +#include + +// ToolAnalysis includes +#include "ANNIEconstants.h" +#include "IFBeamDBInterfaceV2.h" + +IFBeamDBInterfaceV2::IFBeamDBInterfaceV2() +{ + fCurl = curl_easy_init(); + if (!fCurl) throw std::runtime_error("IFBeamDBInterfaceV2 failed to" + " initialize libcurl"); +} + +IFBeamDBInterfaceV2::~IFBeamDBInterfaceV2() +{ + curl_easy_cleanup(fCurl); +} + +//////////////////////////////////////////////////////////////////////////////// +const IFBeamDBInterfaceV2& IFBeamDBInterfaceV2::Instance() { + + // Create the IFBeamDBInterfaceV2 using a static variable. This ensures that + // the singleton instance is only created once. + static std::unique_ptr the_instance( + new IFBeamDBInterfaceV2()); + + // Return a reference to the singleton instance + return *the_instance; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > + IFBeamDBInterfaceV2::QueryBeamDBSingleSpan(std::string device, uint64_t t0, uint64_t t1) + const +{ + std::stringstream url_stream; + url_stream << "http://ifb-data.fnal.gov:8089/ifbeam/data/data?e=e,1d&v="; + url_stream << device; + url_stream << std::fixed << std::setprecision(3) << (t0 - 1)/1000.; + url_stream << "&t1=" << (t1 + 1)/1000.; + url_stream << "&f=csv"; + + std::string response; + int code = RunQuery(url_stream, response); + + if (code != CURLE_OK) throw std::runtime_error("Error accessing" + " IF beam database. Please check your internet connection."); + + auto beam_data = ParseDBResponseSingleSpan(response); + + return beam_data; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > + IFBeamDBInterfaceV2::QueryBeamDBBundleSpan(std::string bundle, uint64_t t0, uint64_t t1) + const +{ + std::stringstream url_stream; + url_stream << "http://ifb-data.fnal.gov:8089/ifbeam/data/data?e=e,1d&b="; + url_stream << bundle; + url_stream << "&t0="; + url_stream << std::fixed << std::setprecision(3) << (t0 - 1)/1000.; + url_stream << "&t1=" << (t1 + 1)/1000.; + url_stream << "&f=csv"; + + std::string response; + int code = RunQuery(url_stream, response); + + if (code != CURLE_OK) throw std::runtime_error("Error accessing" + " IF beam database. Please check your internet connection."); + + auto beam_data = ParseDBResponseBundleSpan(response); + + return beam_data; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > + IFBeamDBInterfaceV2::QueryBeamDBSingle(std::string device, uint64_t time) const +{ + std::stringstream url_stream; + url_stream << "http://ifb-data.fnal.gov:8089/ifbeam/data/data?e=e,1d&v="; + url_stream << device; + url_stream << "&t=" << std::fixed << std::setprecision(3) << time/1000.; + url_stream << "&f=xml"; + + std::string response; + int code = RunQuery(url_stream, response); + + if (code != CURLE_OK) throw std::runtime_error("Error accessing" + " IF beam database. Please check your internet connection."); + + auto beam_data = ParseDBResponseSingle(response); + + return beam_data; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > + IFBeamDBInterfaceV2::QueryBeamDBBundle(std::string bundle, uint64_t time) const +{ + std::stringstream url_stream; + url_stream << "http://ifb-data.fnal.gov:8089/ifbeam/data/data?e=e,1d&b="; + url_stream << bundle; + url_stream << "&t=" << std::fixed << std::setprecision(3) << time/1000.; + url_stream << "&f=csv"; + + std::string response; + int code = RunQuery(url_stream, response); + + if (code != CURLE_OK) throw std::runtime_error("Error accessing" + " IF beam database. Please check your internet connection."); + + auto beam_data = ParseDBResponseBundle(response); + + return beam_data; +} + +int IFBeamDBInterfaceV2::RunQuery(const std::stringstream &url_stream, std::string &response_string) + const +{ + if (!fCurl) { + throw std::runtime_error("IFBeamDBInterfaceV2::RunQuery() called" + " without inititalizing libcurl"); + return -1; + } + + //std::cout << "IFBeamDBInterfaceV2: sending the following query: " << url_stream.str() << std::endl; + + curl_easy_setopt(fCurl, CURLOPT_URL, url_stream.str().c_str()); + + response_string.clear(); + + curl_easy_setopt(fCurl, CURLOPT_WRITEFUNCTION, + static_cast( + [](char* ptr, size_t size, + size_t num_members, std::string* data) -> size_t + { + data->append(ptr, size * num_members); + return size * num_members; + } + ) + ); + + curl_easy_setopt(fCurl, CURLOPT_WRITEDATA, &response_string); + + int code = curl_easy_perform(fCurl); + + // Check the HTTP response code from the IF beam database server. If + // it's not 200, then throw an exception (something went wrong). + // For more information about the possible HTTP status codes, see + // this Wikipedia article: http://tinyurl.com/8yqvhwf + long http_response_code; + constexpr long HTTP_OK = 200; + curl_easy_getinfo(fCurl, CURLINFO_RESPONSE_CODE, &http_response_code); + if (http_response_code != HTTP_OK) { + throw std::runtime_error("HTTP error (code " + + std::to_string(http_response_code) + ") encountered while querying" + " the IF beam database"); + } + + return code; +} + +// Here's some documentation for some of the parameters stored in the beam +// database. It's taken from the MicroBooNE operations wiki: +// http://tinyurl.com/z3c4mxs +// +// The status page shows the present reading of beamline instrumentation. All +// of this data is being stored to IF beam Database. The "IF Beam DB +// dashboard":http://dbweb4.fnal.gov:8080/ifbeam/app/BNBDash/index provides +// another view of beam data. Some of it is redundant to the status page, but +// it verifies that the data is being stored in the database. At present the +// page shows following devices: +// * TOR860, TOR875 - two toroids in BNB measuring beam intensity. TOR860 is +// at the beginning of the beamline, and TOR875 is at the end. +// * THCURR - horn current +// * HWTOUT - horn water temperature coming out of the horn. +// * BTJT2 - target temperature +// * HP875, VP875 - beam horizontal and vertical positions at the 875 +// location, about 4.5 m upstream of the target center. +// * HPTG1, VPTG1 - beam horizontal and vertical positions immediately +// (about 2.5 m) upstream of the target center. +// * HPTG2, VPTG2 - beam horizontal and vertical positions more immediately +// (about 1.5 m) upstream of the target center. +// * Because there are no optics between H/VP875 and H/VPTG2, the movements +// on these monitors should scale with the difference in distances. +// * BTJT2 - target air cooling temperature. Four RTD measure the return +// temperature of the cooling air. This is the one closest to the target. +// * BTH2T2 - target air cooling temperature. This is the temperature of the +// air going into the horn. + +//////////////////////////////////////////////////////////////////////////////// +std::map > +IFBeamDBInterfaceV2::ParseDBResponseSingleSpan(const std::string& response) const +{ + // Create an empty map to store the parsed data. + std::map > retMap; + + // Use a stringstream to parse the data + std::istringstream response_stream(response); + + // Temporary storage for the comma-separated fields in the database response + // string + std::string line, junk, data_type, time_string, unit, val_string; + uint64_t timestamp; + + // Holder for the earliest TS in a chunk + // We will roll this forward when a TS 60 ms later comes in + // (the max rate of $1D is 15 Hz or 66 ms) + uint64_t earlyTS = 0; + + // Skip the first line (which gives textual column headers) + std::getline(response_stream, line, '\n'); + + while (std::getline(response_stream, line, '\n')) { + std::stringstream ss(line); + + std::getline(ss, junk, ','); + std::getline(ss, data_type, ','); + std::getline(ss, time_string, ','); + std::getline(ss, unit, ','); + std::getline(ss, val_string); + + timestamp = std::stoull(time_string); + if (timestamp - earlyTS > 60) earlyTS = timestamp; + + retMap[earlyTS][data_type] = BeamDataPoint(std::stod(val_string), + unit, + timestamp); + } + + return retMap; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > +IFBeamDBInterfaceV2::ParseDBResponseBundleSpan(const std::string& response) const +{ + // Create an empty map to store the parsed data. + std::map > retMap; + + // Use a stringstream to parse the data + std::istringstream response_stream(response); + + // Temporary storage for the comma-separated fields in the database response + // string + std::string line, junk, data_type, time_string, unit, val_string; + uint64_t timestamp; + + // Holder for the earliest TS in a chunk + // We will roll this forward when a TS 60 ms later comes in + // (the max rate of $1D is 15 Hz or 66 ms) + uint64_t earlyTS = 0; + + + // Skip the first line (which gives textual column headers) + std::getline(response_stream, line, '\n'); + + while (std::getline(response_stream, line, '\n')) { + std::stringstream ss(line); + + std::getline(ss, time_string, ','); + std::getline(ss, data_type, ','); + std::getline(ss, unit, ','); + std::getline(ss, val_string); + + timestamp = std::stoull(time_string); + if (timestamp - earlyTS > 60) earlyTS = timestamp; + + retMap[earlyTS][data_type] = BeamDataPoint(std::stod(val_string), + unit, + timestamp); + } + + return retMap; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > +IFBeamDBInterfaceV2::ParseDBResponseSingle(const std::string& response) const +{ + std::map > retMap; + + // Use a stringstream to parse the data + std::istringstream response_stream(response); + + // Temporary storage for the comma-separated fields in the database response + // string + std::string line, junk, data_type, time_string, unit, val_string; + uint64_t timestamp; + + // This is a bit less necessary here, + // but it keeps all the points in the same timestamp map element + // Holder for the earliest TS in a chunk + // We will roll this forward when a TS 60 ms later comes in + // (the max rate of $1D is 15 Hz or 66 ms) + uint64_t earlyTS = 0; + + // Skip the first line (which gives textual column headers) + std::getline(response_stream, line, '\n'); + + // The second line has all the info, but also a load of crap + std::getline(response_stream, line, '\n'); + std::stringstream ss(line); + std::getline(ss, junk, '"'); + std::getline(ss, data_type, '"'); + std::getline(ss, junk, '"'); std::getline(ss, junk, '"'); std::getline(ss, junk, '"'); + std::getline(ss, unit, '"'); + std::getline(ss, junk, '"'); std::getline(ss, junk, '"'); std::getline(ss, junk, '"'); + std::getline(ss, time_string, '"'); + std::getline(ss, junk, '>'); + std::getline(ss, val_string, '\n'); + // we can ignore the remaining lines and finish up + + timestamp = std::stoull(time_string); + if (timestamp - earlyTS > 60) earlyTS = timestamp; + + retMap[earlyTS][data_type] = BeamDataPoint(std::stod(val_string), + unit, + timestamp); + + return retMap; +} + +//////////////////////////////////////////////////////////////////////////////// +std::map > +IFBeamDBInterfaceV2::ParseDBResponseBundle(const std::string& response) const +{ + std::map > retMap; + + // Use a stringstream to parse the data + std::istringstream response_stream(response); + + // Temporary storage for the comma-separated fields in the database response + // string + std::string line, junk, data_type, time_string, unit, val_string; + uint64_t timestamp; + + // This is a bit less necessary here, + // but it keeps all the points in the same timestamp map element + // Holder for the earliest TS in a chunk + // We will roll this forward when a TS 60 ms later comes in + // (the max rate of $1D is 15 Hz or 66 ms) + uint64_t earlyTS = 0; + + // Skip the first line (which gives textual column headers) + std::getline(response_stream, line, '\n'); + + while (std::getline(response_stream, line, '\n')) { + std::stringstream ss(line); + + std::getline(ss, data_type, ','); + std::getline(ss, junk, ','); + std::getline(ss, time_string, ','); + std::getline(ss, unit, ','); + std::getline(ss, val_string); + + timestamp = std::stoull(time_string); + if (timestamp - earlyTS > 60) earlyTS = timestamp; + + retMap[earlyTS][data_type] = BeamDataPoint(std::stod(val_string), + unit, + timestamp); + } + + return retMap; +} + diff --git a/UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.h b/UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.h new file mode 100644 index 000000000..7ba3c6434 --- /dev/null +++ b/UserTools/BeamFetcherV2/IFBeamDBInterfaceV2.h @@ -0,0 +1,90 @@ +#pragma once +// Singleton class used by the BeamFetcherV2 tool to communicate with the +// Fermilab Intensity Frontier beam database +// Modified from the original version in the BeamFetcher tool +// (see http://ifb-data.fnal.gov:8100/ifbeam/data) +// +// Steven Gardiner (sjgardiner@ucdavis.edu) +// Andrew Sutton (asutton@fnal.gov) + +// standard library includes +#include +#include + +// libcurl includes +#include + +// ToolAnalysis includes +#include "BeamDataPoint.h" +#include "BeamStatus.h" +/// @brief Singleton used to interact with the Intensity Frontier beam database +/// at Fermilab +class IFBeamDBInterfaceV2 { + + public: + + /// @brief Clean up libcurl stuff as the IFBeamDBInterfaceV2 object is + /// destroyed + ~IFBeamDBInterfaceV2(); + + /// @brief Deleted copy constructor + IFBeamDBInterfaceV2(const IFBeamDBInterfaceV2&) = delete; + + /// @brief Deleted move constructor + IFBeamDBInterfaceV2(IFBeamDBInterfaceV2&&) = delete; + + /// @brief Deleted copy assignment operator + IFBeamDBInterfaceV2& operator=(const IFBeamDBInterfaceV2&) = delete; + + /// @brief Deleted move assignment operator + IFBeamDBInterfaceV2& operator=(IFBeamDBInterfaceV2&&) = delete; + + /// @brief Get a const reference to the singleton instance of the + /// IFBeamDBInterfaceV2 + static const IFBeamDBInterfaceV2& Instance(); + + /// @brief Get information about the Booster Neutrino Beam (BNB) state from + /// the database for the time interval [t0, t1] + /// @param t0 Starting timestamp (milliseconds since the Unix epoch) + /// @param t1 Starting timestamp (milliseconds since the Unix epoch) + /// @return A nested map containing the parsed data. Keys of the outer map + /// are device names, values are inner maps. Keys of the inner map are + /// timestamps (milliseconds since the Unix epoch), values are + /// BeamDataPoint structs that hold a numerical value and a unit string. + /// @note An easy way to get the current milliseconds since the Unix epoch + /// is to use the terminal utility date like this: @verbatim date +%s%3N + /// @endverbatim + /// I found this handy trick here: http://unix.stackexchange.com/a/123764 + std::map > + QueryBeamDBSingleSpan(std::string device, uint64_t t0, uint64_t t1) const; + + std::map > + QueryBeamDBBundleSpan(std::string bundle, uint64_t t0, uint64_t t1) const; + + std::map > + QueryBeamDBSingle(std::string device, uint64_t time) const; + + std::map > + QueryBeamDBBundle(std::string bundle, uint64_t time) const; + + int RunQuery(const std::stringstream &url_stream, std::string &response_string) const; + + protected: + /// @brief Create the singleton IFBeamDBInterfaceV2 object + IFBeamDBInterfaceV2(); + + std::map > + ParseDBResponseSingleSpan(const std::string& response) const; + + std::map > + ParseDBResponseBundleSpan(const std::string& response) const; + + std::map > + ParseDBResponseSingle(const std::string& response) const; + + std::map > + ParseDBResponseBundle(const std::string& response) const; + + /// @brief Pointer used to interact with libcurl + CURL* fCurl = nullptr; +}; diff --git a/UserTools/BeamFetcherV2/README.md b/UserTools/BeamFetcherV2/README.md new file mode 100644 index 000000000..04df17154 --- /dev/null +++ b/UserTools/BeamFetcherV2/README.md @@ -0,0 +1,48 @@ +# BeamFetcherV2 + +The `BeamFetcherV2` tool obtains information about the status of the BNB from the IF database. It has two distinct modes of operation FetchFromTimes of FetchFromTrigger controlled by the boolean config flag `FetchFromTimes`. In FromTimes mode you will pass in start and stop times and a new file will be created with a BoostStore. In FromTrigger mode you first must run the TriggerDataDecoder then BeamFetcher will grab the trigger timestamp and find the nearest matching time for the beam device. FromTrigger mode will save the info into the CStore for access later on. The `IFBeamDBInterface` class is a helper class that handles the details of the communication with the IF database. + +## Data + +FetchFromTimes: The following objects will be saved in the BeamStatus BoostStore +* "BeamDBIndex" (Header) `map` + * Designates the time interval that is stored in the given BoostStore entry +* "StartMillisecondsSinceEpoch" (Header) `uint64_t` + * Designates the overall start time of database entries stored in the BoostStore +* "EndMillisecondsSinceEpoch" (Header) `uint64_t` + * Designates the overall end time of database entries stored in the BoostStore +* "BeamDB" `map>` + * Actual beam status information, keys are the device names (e.g. E:TOR875) + +FetchFromTrigger: The following objects will be put into the CStore +* "BeamData" `map< uint_64, map >` + * The info from the DB where the key is the associated trigger timestamp to the nearest milliseconds and the internal map is from device name (e.g. E:TOR875) to a BeamDataPoint object containing the readback value, units, and actual timestamp. + +## Configuration + +The main configuration variable for the `BeamFetcher` tool is `FetchFromTimes`, which determines whether to use the tigger timestamps or user input timestamps. The `DevicesFile`, `IsBundle`, and `TimeChunkStepInMilliseconds` variables are required regardless of the fetch mode. You can also set the `SaveROOT` bool in order to save out a TTree with the timestamp and device values as the leaves. + +If `FetchFromTimes == 1` then you will also need the additional config variables. The preferred timestamp format is chosen with the `TimestampMode` variable (LOCALDATE/MSEC/DB). For LOCALDATE mode you use Start/EndDate files with string formatted times (like 2023-04-11 23:03:19.163505). For MSEC mode you use the Start/EndMillisecondsSinceEpoch variables. For DB mode you must first run `LoadRunInfo` and the run timestamps will be pulled from the CStore. + +``` +# BeamFetcher config file +verbose 5 +# +# These three are always needed +# +DevicesFile ./configfiles/BeamFetcher/devices.txt # File containing one device per line or a bundle +IsBundle 0 # bool stating whether DevicesFile contains bundles or individual devices +FetchFromTimes 0 # bool defining how to grab the data (from input times (1) or trigger(0)) +TimeChunkStepInMilliseconds 3600000 # one hour +SaveROOT 0 # bool, do you want to write a ROOT file with the timestamps and devices? +# +# These parameters are only needed if FetchFromTimes == 1 +# +OutputFile ./1604_beamdb +TimestampMode LOCALDATE +DaylightSavings 0 # Do we need to account for DST? +StartDate ./configfiles/BeamFetcher/my_start_date.txt #String form of start date stored in a file +EndDate ./configfiles/BeamFetcher/my_end_date.txt #String form of end date stored in a file +#StartMillisecondsSinceEpoch 1491132659000 # 6:30:49 AM 2 April 2017 (FNAL time) #msec format of start time +#EndMillisecondsSinceEpoch 1491164001000 # 3:13:21 PM 2 April 2017 (FNAL time) #msec format of end time +``` diff --git a/UserTools/Factory/Factory.cpp b/UserTools/Factory/Factory.cpp index 706d3e4f1..59dc6005f 100644 --- a/UserTools/Factory/Factory.cpp +++ b/UserTools/Factory/Factory.cpp @@ -158,5 +158,6 @@ if (tool=="ReweightEventsGenie") ret=new ReweightEventsGenie; if (tool=="FilterLAPPDEvents") ret=new FilterLAPPDEvents; if (tool=="FilterEvents") ret=new FilterEvents; if (tool=="Stage1DataBuilder") ret=new Stage1DataBuilder; +if (tool=="BeamFetcherV2") ret=new BeamFetcherV2; return ret; } diff --git a/UserTools/Unity.h b/UserTools/Unity.h index 7fab6b155..e77bfa810 100644 --- a/UserTools/Unity.h +++ b/UserTools/Unity.h @@ -166,3 +166,4 @@ #include "FilterLAPPDEvents.h" #include "FilterEvents.h" #include "Stage1DataBuilder.h" +#include "BeamFetcherV2.h" From 0ba4a6ad1c1f7051579b1dea638f7e6fe8a58a30 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Tue, 25 Jul 2023 22:12:45 +0100 Subject: [PATCH 07/31] bugfix to LoadWCSim MCTriggernum in CStore was being set to the number of subtriggers when splitSubTriggers was false (default). I can't see any code which uses this, and the usual meaning of MCTriggernum is the current subtrigger being processed, with Tools checking (MCTriggernum==0) to identify the next WCSim entry. If a Tool requires it, the number of triggers in the event is avilable under NumTriggersThisEvent in the ANNIEEvent store. --- UserTools/LoadWCSim/LoadWCSim.cpp | 392 +++++++++++++++--------------- 1 file changed, 197 insertions(+), 195 deletions(-) diff --git a/UserTools/LoadWCSim/LoadWCSim.cpp b/UserTools/LoadWCSim/LoadWCSim.cpp index dcbe685f9..854212030 100644 --- a/UserTools/LoadWCSim/LoadWCSim.cpp +++ b/UserTools/LoadWCSim/LoadWCSim.cpp @@ -69,7 +69,7 @@ bool LoadWCSim::Initialise(std::string configfile, DataModel &data){ Log("LoadWCSim Tool: No Triggertype specified. Assuming TriggerType = Beam",v_warning,verbosity); Triggertype = "Beam"; //other options: Cosmic / No Loopback } - + get_ok = m_variables.Get("TriggerWord",TriggerWord); if (not get_ok){ Log("LoadWCSim Tool: No Triggerword specified. Assuming TriggerWord = 5 (Beam)",v_warning,verbosity); @@ -90,7 +90,7 @@ bool LoadWCSim::Initialise(std::string configfile, DataModel &data){ channelkey_to_pmtid.emplace(chankey,pmtid); pmtid_to_channelkey.emplace(pmtid,chankey); } - + file_pmtid.close(); m_data->CStore.Set("pmt_tubeid_to_channelkey_data",pmtid_to_channelkey); m_data->CStore.Set("channelkey_to_pmtid_data",channelkey_to_pmtid); @@ -99,50 +99,50 @@ bool LoadWCSim::Initialise(std::string configfile, DataModel &data){ return false; } path_mrd_chankeymap = "./configfiles/LoadWCSim/MRD_Chankey_WCSimID.dat"; - get_ok = m_variables.Get("ChankeyToMRDIDMap",path_mrd_chankeymap); - ifstream file_mrdid(path_mrd_chankeymap.c_str()); - if (file_mrdid.is_open()){ - // watch out: comment or empty lines not supported here - while (!file_mrdid.eof()){ - unsigned long chankey; - int mrdid; - file_mrdid >> chankey >> mrdid; - mrdid_to_channelkey.emplace(mrdid,chankey); - } - file_mrdid.close(); - } else { - Log("LoadWCSim Tool: MRD ID Configuration file "+path_mrd_chankeymap+" could not be opened! Is the path valid? Abort",v_warning,verbosity); - return false; - } + get_ok = m_variables.Get("ChankeyToMRDIDMap",path_mrd_chankeymap); + ifstream file_mrdid(path_mrd_chankeymap.c_str()); + if (file_mrdid.is_open()){ + // watch out: comment or empty lines not supported here + while (!file_mrdid.eof()){ + unsigned long chankey; + int mrdid; + file_mrdid >> chankey >> mrdid; + mrdid_to_channelkey.emplace(mrdid,chankey); + } + file_mrdid.close(); + } else { + Log("LoadWCSim Tool: MRD ID Configuration file "+path_mrd_chankeymap+" could not be opened! Is the path valid? Abort",v_warning,verbosity); + return false; + } path_fmv_chankeymap = "./configfiles/LoadWCSim/FMV_Chankey_WCSimID.dat"; - get_ok = m_variables.Get("ChankeyToFMVIDMap",path_fmv_chankeymap); - ifstream file_fmvid(path_fmv_chankeymap.c_str()); - if (file_fmvid.is_open()){ - // watch out: comment or empty lines not supported here - while (!file_fmvid.eof()){ - unsigned long chankey; - int fmvid; - file_fmvid >> chankey >> fmvid; - fmvid_to_channelkey.emplace(fmvid,chankey); - } - file_fmvid.close(); - } else { - Log("LoadWCSim Tool: FMV ID Configuration file "+path_fmv_chankeymap+" could not be opened! Is the path valid? Abort",v_warning,verbosity); - return false; - } - get_ok = m_variables.Get("RunType",RunType); - if (not get_ok){ - Log("LoadWCSim Tool: No RunType specified. Assuming RunType = 3 (Beam)",v_warning,verbosity); - RunType = 3; - } - + get_ok = m_variables.Get("ChankeyToFMVIDMap",path_fmv_chankeymap); + ifstream file_fmvid(path_fmv_chankeymap.c_str()); + if (file_fmvid.is_open()){ + // watch out: comment or empty lines not supported here + while (!file_fmvid.eof()){ + unsigned long chankey; + int fmvid; + file_fmvid >> chankey >> fmvid; + fmvid_to_channelkey.emplace(fmvid,chankey); + } + file_fmvid.close(); + } else { + Log("LoadWCSim Tool: FMV ID Configuration file "+path_fmv_chankeymap+" could not be opened! Is the path valid? Abort",v_warning,verbosity); + return false; + } + get_ok = m_variables.Get("RunType",RunType); + if (not get_ok){ + Log("LoadWCSim Tool: No RunType specified. Assuming RunType = 3 (Beam)",v_warning,verbosity); + RunType = 3; + } + get_ok = m_variables.Get("PMTMask",PMTMask); if (not get_ok){ Log("LoadWCSim Tool: Assuming to use no PMTMask",v_warning,verbosity); PMTMask = "None"; } - - MCEventNum=0; + + MCEventNum=0; get_ok = m_variables.Get("FileStartOffset",MCEventNum); // put version in the CStore for downstream tools @@ -269,7 +269,7 @@ bool LoadWCSim::Initialise(std::string configfile, DataModel &data){ if (PMTMask != "None"){ masked_ids = this->LoadPMTMask(PMTMask); } - + // use nominal beam values TODO double beaminten=4.777e+12; double beampow=3.2545e+16; @@ -279,7 +279,7 @@ bool LoadWCSim::Initialise(std::string configfile, DataModel &data){ beamstat.set_pot(beampow); BeamCondition bc = BeamCondition::Ok; beamstat.set_condition(bc); - + // Construct the other objects we'll be setting at event level, // pass managed pointers to the ANNIEEvent Store MCParticles = new std::vector; @@ -363,21 +363,23 @@ bool LoadWCSim::Execute(){ } MCFile = WCSimEntry->GetCurrentFile()->GetName(); - MCHits->clear(); TDCData->clear(); MCNeutCap.clear(); MCNeutCapGammas.clear(); mrd_firstlayer=false; - mrd_lastlayer=false; - + mrd_lastlayer=false; + triggers_event = WCSimEntry->wcsimrootevent->GetNumberOfEvents(); - if (!splitSubtriggers) MCTriggernum = 0; - int MaxEventNr = (splitSubtriggers)? (MCTriggernum + 1) : (WCSimEntry->wcsimrootevent->GetNumberOfEvents()); - + int MaxEventNr = MCTriggernum+1; + if (!splitSubtriggers){ + // we'll merge all subtriggers, so loop from 0 to triggers_event; + MCTriggernum = 0; + MaxEventNr = WCSimEntry->wcsimrootevent->GetNumberOfEvents(); + } // else if we're splitting subtriggers, loop from [current MCTriggernum] to [current MCTriggernum+1] + while (MCTriggernum < MaxEventNr){ - //for(MCTriggernum=0; MCTriggernumwcsimrootevent->GetNumberOfEvents(); MCTriggernum++){ if(verbosity>1) cout<<"getting triggers"<wcsimrootevent->GetTrigger(0); @@ -450,10 +452,10 @@ bool LoadWCSim::Execute(){ if (splitSubtriggers){ //MC particle times now stored relative to the trigger time starttime = (static_cast(nextrack->GetTime()-EventTimeNs)); - stoptime = (static_cast(nextrack->GetStopTime()-EventTimeNs)); + stoptime = (static_cast(nextrack->GetStopTime()-EventTimeNs)); } else { starttime = (static_cast(nextrack->GetTime())); - stoptime = (static_cast(nextrack->GetStopTime())); + stoptime = (static_cast(nextrack->GetStopTime())); } MCParticle neutrino( nextrack->GetIpnu(), nextrack->GetE(), nextrack->GetEndE(), @@ -474,7 +476,7 @@ bool LoadWCSim::Execute(){ nextrack->GetParenttype(), nextrack->GetFlag(), trigi); - + //Set the neutrino as its own particle m_data->Stores["ANNIEEvent"]->Set("NeutrinoParticle",neutrino); @@ -485,10 +487,10 @@ bool LoadWCSim::Execute(){ if (splitSubtriggers){ //MC particle times now stored relative to the trigger time starttime = (static_cast(nextrack->GetTime()-EventTimeNs)); - stoptime = (static_cast(nextrack->GetStopTime()-EventTimeNs)); + stoptime = (static_cast(nextrack->GetStopTime()-EventTimeNs)); } else { starttime = (static_cast(nextrack->GetTime())); - stoptime = (static_cast(nextrack->GetStopTime())); + stoptime = (static_cast(nextrack->GetStopTime())); } MCParticle thisparticle( nextrack->GetIpnu(), nextrack->GetE(), nextrack->GetEndE(), @@ -512,8 +514,8 @@ bool LoadWCSim::Execute(){ // not currently in constructor call, but we now have it in latest WCSim files // XXX this will fall over with older WCSim files, whose WCSimLib doesn't have this method! thisparticle.SetTankExitPoint(Position(nextrack->GetTankExitPoint(0)/ 100., - nextrack->GetTankExitPoint(1)/ 100., - nextrack->GetTankExitPoint(2)/ 100.)); + nextrack->GetTankExitPoint(1)/ 100., + nextrack->GetTankExitPoint(2)/ 100.)); if( (nextrack->GetIpnu()==13) && (nextrack->GetParenttype()==0) && (nextrack->GetFlag()==0) && @@ -651,7 +653,7 @@ bool LoadWCSim::Execute(){ if (!splitSubtriggers) digittime += EventTimeNs; //std::cout <<"digittime after adding event time: "<count(key)==0) MCHits->emplace(key, std::vector{nexthit}); else MCHits->at(key).push_back(nexthit); @@ -698,8 +700,8 @@ bool LoadWCSim::Execute(){ if(verbosity>2) cout<<"digit Q is "< parents = GetHitParentIds(digihit, firsttrigm); - if (!splitSubtriggers) digittime += EventTimeNs; - + if (!splitSubtriggers) digittime += EventTimeNs; + MCHit nexthit(key, digittime, digiq, parents); if(TDCData->count(key)==0) {TDCData->emplace(key, std::vector{nexthit}); if (Mrd_Chankey_Layer.at(key)==0) mrd_firstlayer=true; if (Mrd_Chankey_Layer.at(key)==10) mrd_lastlayer=true;} else TDCData->at(key).push_back(nexthit); @@ -746,8 +748,8 @@ bool LoadWCSim::Execute(){ if(verbosity>2) cout<<"digit Q is "< parents = GetHitParentIds(digihit, firsttrigv); - digittime += EventTimeNs; - + digittime += EventTimeNs; + MCHit nexthit(key, digittime, digiq, parents); if(TDCData->count(key)==0) TDCData->emplace(key, std::vector{nexthit}); else TDCData->at(key).push_back(nexthit); @@ -760,12 +762,11 @@ bool LoadWCSim::Execute(){ //Load neutron capture information int numcaptures = atrigt ? atrigt->GetNcaptures() : 0; - if(verbosity>1) cout<<"LoadWCSim tool: looping over "<2) cout<<"getting capture # "<GetCaptures()->At(capi); - + if(verbosity>1) cout<<"LoadWCSim tool: looping over "<2) cout<<"getting capture # "<GetCaptures()->At(capi); + int capt_parent = capt->GetCaptureParent(); double capt_vtxx = capt->GetCaptureVtx(0); double capt_vtxy = capt->GetCaptureVtx(1); @@ -804,9 +805,7 @@ bool LoadWCSim::Execute(){ MCNeutCapGammas.at("CaptGammas").push_back(gamma_energies); } } - - - + // update the information about tracks and which tank/mrd/veto PMTs they hit // this needs updating with each MC trigger, as digits are grouped into MC trigger // so these maps will then only contain the digits respective particles create @@ -841,7 +840,7 @@ bool LoadWCSim::Execute(){ if(verbosity>1) cout<<"setting the store variables"<Stores.at("ANNIEEvent")->Set("RunNumber",RunNumber); m_data->Stores.at("ANNIEEvent")->Set("SubrunNumber",SubrunNumber); - m_data->Stores.at("ANNIEEvent")->Set("RunType",RunType); + m_data->Stores.at("ANNIEEvent")->Set("RunType",RunType); m_data->Stores.at("ANNIEEvent")->Set("EventNumber",EventNumber); if(verbosity>2) cout<<"particles"<Stores.at("ANNIEEvent")->Set("MCParticles",MCParticles,true); @@ -869,9 +868,12 @@ bool LoadWCSim::Execute(){ m_data->Stores.at("ANNIEEvent")->Set("EventTimeMRD",RunStartTime); m_data->Stores.at("ANNIEEvent")->Set("EventTime",EventTime,true); m_data->Stores.at("ANNIEEvent")->Set("MCEventNum",MCEventNum); - m_data->Stores.at("ANNIEEvent")->Set("MCTriggernum",MCTriggernum-1); + // if we merged the subtriggers, report an MCTriggernum of 0 + // so downstream tools know it's a new event + int reported_triggernum = splitSubtriggers ? MCTriggernum-1 : 0; + m_data->Stores.at("ANNIEEvent")->Set("MCTriggernum",reported_triggernum); m_data->Stores.at("ANNIEEvent")->Set("MCFile",MCFile); - m_data->Stores.at("ANNIEEvent")->Set("MCFlag",true); // constant + m_data->Stores.at("ANNIEEvent")->Set("MCFlag",true); //m_data->Stores.at("ANNIEEvent")->Set("BeamStatus",BeamStatus,true); m_data->Stores.at("ANNIEEvent")->Set("BeamStatus",beamstat); m_data->Stores.at("ANNIEEvent")->Set("MCNeutCap",MCNeutCap); @@ -890,17 +892,17 @@ bool LoadWCSim::Execute(){ m_data->Stores.at("ANNIEEvent")->Set("MRDTriggerType",Triggertype); m_data->Stores.at("ANNIEEvent")->Set("PrimaryMuonIndex",primarymuonindex); m_data->Stores.at("ANNIEEvent")->Set("TriggerWord",TriggerWord); - + std::map DataStreams; DataStreams.emplace(std::make_pair("Tank",true)); DataStreams.emplace(std::make_pair("MRD",true)); DataStreams.emplace(std::make_pair("Trigger",true)); DataStreams.emplace(std::make_pair("LAPPD",true)); m_data->Stores.at("ANNIEEvent")->Set("DataStreams",DataStreams); - + int TriggerExtended = 1; //1: We have an extended readout for all MC events m_data->Stores.at("ANNIEEvent")->Set("TriggerExtended",TriggerExtended); - + //Things that need to be set by later tools: //RawADCData //CalibratedADCData @@ -914,7 +916,7 @@ bool LoadWCSim::Execute(){ bool newentry=false; if(MCTriggernum==WCSimEntry->wcsimrootevent->GetNumberOfEvents()){ MCTriggernum=0; - MCEventNum++; + MCEventNum++; newentry=true; if(verbosity>2) cout<<"this is the last trigger in the event: next loop will process a new event"<1){ cout<<"constructed anniegeom at "<=CAEN_HV_CARDS_PER_CRATE) { CAEN_HV_Card_Num=0; CAEN_HV_Crate_Num++; } Channel pmtchannel( uniquechannelkey, - Position(0,0,0.), - 0, // stripside - 0, // stripnum - ADC_Crate_Num, - ADC_Card_Num, - ADC_Chan_Num, - MT_Crate_Num, - MT_Card_Num, - MT_Chan_Num, - CAEN_HV_Crate_Num, - CAEN_HV_Card_Num, - CAEN_HV_Chan_Num, - channelstatus::ON); + Position(0,0,0.), + 0, // stripside + 0, // stripnum + ADC_Crate_Num, + ADC_Card_Num, + ADC_Chan_Num, + MT_Crate_Num, + MT_Card_Num, + MT_Chan_Num, + CAEN_HV_Crate_Num, + CAEN_HV_Card_Num, + CAEN_HV_Chan_Num, + channelstatus::ON); // Add this channel to the geometry if(verbosity>4) cout<<"Adding channel "<ConsumeNextFreeChannelKey(); @@ -1164,19 +1166,19 @@ Geometry* LoadWCSim::ConstructToolChainGeometry(){ if(LeCroy_HV_Card_Num>=LECROY_HV_CARDS_PER_CRATE) { LeCroy_HV_Card_Num=0; LeCroy_HV_Crate_Num++; } Channel pmtchannel( uniquechannelkey, - Position(0,0,0.), - 0, // stripside - 0, // stripnum - TDC_Crate_Num, - TDC_Card_Num, - TDC_Chan_Num, - -1, // TDC has no level 2 signal handling - -1, - -1, - LeCroy_HV_Crate_Num, - LeCroy_HV_Card_Num, - LeCroy_HV_Chan_Num, - channelstatus::ON); + Position(0,0,0.), + 0, // stripside + 0, // stripnum + TDC_Crate_Num, + TDC_Card_Num, + TDC_Chan_Num, + -1, // TDC has no level 2 signal handling + -1, + -1, + LeCroy_HV_Crate_Num, + LeCroy_HV_Card_Num, + LeCroy_HV_Chan_Num, + channelstatus::ON); // Add this channel to the geometry if(verbosity>4) cout<<"Adding channel "<{MRDSpecs::paddle_extentsx.at(mrdpmti).first/1000., - MRDSpecs::paddle_extentsx.at(mrdpmti).second/1000.}, - std::pair{MRDSpecs::paddle_extentsy.at(mrdpmti).first/1000., - MRDSpecs::paddle_extentsy.at(mrdpmti).second/1000.}, - std::pair{MRDSpecs::paddle_extentsz.at(mrdpmti).first/1000., - MRDSpecs::paddle_extentsz.at(mrdpmti).second/1000.}); + MRD_x, + MRD_y, + MRD_z, + orientation, + Position( MRDSpecs::paddle_originx.at(mrdpmti)/1000., + MRDSpecs::paddle_originy.at(mrdpmti)/1000., + MRDSpecs::paddle_originz.at(mrdpmti)/1000.), + std::pair{MRDSpecs::paddle_extentsx.at(mrdpmti).first/1000., + MRDSpecs::paddle_extentsx.at(mrdpmti).second/1000.}, + std::pair{MRDSpecs::paddle_extentsy.at(mrdpmti).first/1000., + MRDSpecs::paddle_extentsy.at(mrdpmti).second/1000.}, + std::pair{MRDSpecs::paddle_extentsz.at(mrdpmti).first/1000., + MRDSpecs::paddle_extentsz.at(mrdpmti).second/1000.}); if(verbosity>4) cout<<"Setting paddle for detector "<SetDetectorPaddle(uniquedetectorkey,apaddle); @@ -1243,18 +1245,18 @@ Geometry* LoadWCSim::ConstructToolChainGeometry(){ case 5: CylLocString = "Veto"; break; // TODO set layer? default: CylLocString = "NA"; break; // unknown } - Detector adet(uniquedetectorkey, - "Veto", - CylLocString, - Position( apmt.GetPosition(0)/100., - apmt.GetPosition(1)/100., - apmt.GetPosition(2)/100.), - Direction(apmt.GetOrientation(0), - apmt.GetOrientation(1), - apmt.GetOrientation(2)), - apmt.GetName(), - detectorstatus::ON, - 0.); + Detector adet( uniquedetectorkey, + "Veto", + CylLocString, + Position( apmt.GetPosition(0)/100., + apmt.GetPosition(1)/100., + apmt.GetPosition(2)/100.), + Direction(apmt.GetOrientation(0), + apmt.GetOrientation(1), + apmt.GetOrientation(2)), + apmt.GetName(), + detectorstatus::ON, + 0.); if (verbosity > 3) std::cout <<"LoadWCSim tool: FACC tube channelkey: "<ConsumeNextFreeChannelKey(); @@ -1272,19 +1274,19 @@ Geometry* LoadWCSim::ConstructToolChainGeometry(){ if(LeCroy_HV_Card_Num>=LECROY_HV_CARDS_PER_CRATE) { LeCroy_HV_Card_Num=0; LeCroy_HV_Crate_Num++; } Channel pmtchannel( uniquechannelkey, - Position(0,0,0.), - 0, // stripside - 0, // stripnum - TDC_Crate_Num, - TDC_Card_Num, - TDC_Chan_Num, - -1, // TDC has no level 2 signal handling - -1, - -1, - LeCroy_HV_Crate_Num, - LeCroy_HV_Card_Num, - LeCroy_HV_Chan_Num, - channelstatus::ON); + Position(0,0,0.), + 0, // stripside + 0, // stripnum + TDC_Crate_Num, + TDC_Card_Num, + TDC_Chan_Num, + -1, // TDC has no level 2 signal handling + -1, + -1, + LeCroy_HV_Crate_Num, + LeCroy_HV_Card_Num, + LeCroy_HV_Chan_Num, + channelstatus::ON); // Add this channel to the geometry if(verbosity>4) cout<<"Adding channel "<4) cout<<"printing geometry"<4) anniegeom->PrintChannels(); } - + // lappds // lappds moved to end such that all the other channels are assigned first for(int lappdi=0; lappdi=LAPPD_HV_CHANNELS_PER_CARD) { LAPPD_HV_Chan_Num=0; LAPPD_HV_Card_Num++; } if(LAPPD_HV_Card_Num>=LAPPD_HV_CARDS_PER_CRATE) { LAPPD_HV_Card_Num=0; LAPPD_HV_Crate_Num++; } - Channel lappdchannel(uniquechannelkey, - Position(xpos,ypos,0.), - stripside, - stripnum, - ACDC_Crate_Num, - ACDC_Card_Num, - ACDC_Chan_Num, - ACC_Crate_Num, - ACC_Card_Num, - ACC_Chan_Num, - LAPPD_HV_Crate_Num, - LAPPD_HV_Card_Num, - LAPPD_HV_Chan_Num, - channelstatus::ON); + Channel lappdchannel( uniquechannelkey, + Position(xpos,ypos,0.), + stripside, + stripnum, + ACDC_Crate_Num, + ACDC_Card_Num, + ACDC_Chan_Num, + ACC_Crate_Num, + ACC_Card_Num, + ACC_Chan_Num, + LAPPD_HV_Crate_Num, + LAPPD_HV_Card_Num, + LAPPD_HV_Chan_Num, + channelstatus::ON); // Add this channel to the geometry if(verbosity>4) cout<<"Adding channel "< LoadWCSim::LoadPMTMask(std::string path_to_pmtmask){ - + std::vector mask_vector; int temp_id; ifstream maskfile(path_to_pmtmask.c_str()); @@ -1554,6 +1556,6 @@ std::vector LoadWCSim::LoadPMTMask(std::string path_to_pmtmask){ mask_vector.push_back(temp_id); if (maskfile.eof()) break; } - + return mask_vector; } From c29b41a228885b378f52f9e29a726e6916a586d1 Mon Sep 17 00:00:00 2001 From: jminock Date: Mon, 25 Sep 2023 14:45:16 -0400 Subject: [PATCH 08/31] Bug fixes and additional Genie info (#243) * Add dependencies for GENIE REWEIGHT * Added GENIE REWEIGHT and LHAPDF LHAPDF and its PDF's are necessary for the function of GENIE REWEIGHT and cross analysis studies with MicroBooNE * Added paths for GENIE REWEIGHT and LHAPDF * Added paths for GENIE REWEIGHT and LHAPDF * Separate LHAPDF from GENIE and save space by deleting unnecessary files from root6 * Typo GENIE directory * Typo GENIE directory * Delete GENIE src directory after install Free up some space * Re-include source, needed * Change GENIE path * include CLHEP * Fix Log4cpp include path * Updated Dockerfile.base and copied xml files to correct GENIE directory * Include GENIE make install Fix GENIE Reweight error * Add ReweightEventsGenie Tool * Update tempbuild.yml source setup file for building * Updated and includes LoadGenieEvent Tool * Fixed errors of update * Fix LoadGenie Direction error * Fixed Direction class Unit error * Adding extra MC Xsec info to PhaseIITreeMaker and fix typo * Fixed event matching problem in LoadGenieEvent. Made GenieEntry savable to CStore in LoadWCSim * Fixed event matching problem in LoadGenieEvent. Made GenieEntry savable to CStore in LoadWCSim * Fixed string error * convert GENIE energy to MeV and make sure WCTrigger number is accounted for in PhaseIITreeMaker * convert GENIE energy to MeV * Bug fixes and additional Genie info for LoadGenieEvent and PhaseIITreeMaker * Fix FSL PDG typing --------- Co-authored-by: James Minock Co-authored-by: marc1uk --- UserTools/LoadGenieEvent/LoadGenieEvent.cpp | 93 +++++----- UserTools/LoadGenieEvent/LoadGenieEvent.h | 3 +- UserTools/LoadGenieEvent/README.md | 21 ++- UserTools/LoadWCSim/LoadWCSim.cpp | 2 +- .../PhaseIITreeMaker/PhaseIITreeMaker.cpp | 165 ++++++++++++++---- UserTools/PhaseIITreeMaker/PhaseIITreeMaker.h | 26 +++ .../LoadGenieEvents/LoadGenieEventConfig | 4 +- .../ReweightEventsGenie/LoadGenieEventConfig | 4 +- 8 files changed, 234 insertions(+), 84 deletions(-) diff --git a/UserTools/LoadGenieEvent/LoadGenieEvent.cpp b/UserTools/LoadGenieEvent/LoadGenieEvent.cpp index c09dd6a63..0bc5fe1fc 100644 --- a/UserTools/LoadGenieEvent/LoadGenieEvent.cpp +++ b/UserTools/LoadGenieEvent/LoadGenieEvent.cpp @@ -105,7 +105,7 @@ bool LoadGenieEvent::Initialise(std::string configfile, DataModel &data){ std::string wcsimfile; m_data->Stores.at("ANNIEEvent")->Get("MCFile",wcsimfile); //Strip WCSim file name of its prefix path - std::string wcsim_prefix = "wcsim_"; + std::string wcsim_prefix = "wcsim_0."; wcsimfile.erase(0,wcsimfile.find(wcsim_prefix)+wcsim_prefix.length()); wcsimfile.erase(wcsimfile.find(".root"),wcsimfile.find(".root")+5); std::string wcsimev = wcsimfile; @@ -145,19 +145,18 @@ bool LoadGenieEvent::Execute(){ inputfiles = filedir+"/"+inputfiles; if(verbosity) std::cout << "Tool LoadGenieEvent: Loading Genie file: " << inputfiles << std::endl; } - m_data->CStore.Get("GenieEntry",tchainentrynum); + get_ok = m_data->CStore.Get("GenieEntry",tchainentrynum); if(!get_ok){ - if(verbosity) std::cout << "Tool LoadGenieEvent: Failed to find GenieEntry in CStore" << std::endl; + Log("Tool LoadGenieEvent: Failed to find GenieEntry in CStore",v_error,verbosity); return false; } - std::string curfname = ((curf) ? curf->GetName() : ""); // check if this is a new file if(inputfiles!=curfname){ // we need to load the new file if(flux) flux->ResetBranchAddresses(); if(curf) curf->Close(); - if(verbosity) std::cout <<"Tool LoadGenieEvent: Loading new file "<Get("gtree"); SetBranchAddresses(); @@ -184,13 +183,12 @@ bool LoadGenieEvent::Execute(){ uint16_t MCTriggernum; m_data->Stores["ANNIEEvent"]->Get("MCTriggernum",MCTriggernum); if (MCTriggernum != 0){ - m_data->CStore.Set("NewGENIEEntry",false); + m_data->CStore.Set("NewGENIEEntry",false); return true; //Don't evaluate new GENIE event for dealyed WCSim triggers } else { m_data->CStore.Set("NewGENIEEntry",true); } } - tchainentrynum++; // Expand out the neutrino event info // ======================================================= @@ -304,10 +302,11 @@ bool LoadGenieEvent::Execute(){ interactiontypestring=thegenieinfo.interactiontypestring; neutcode=thegenieinfo.neutinteractioncode; // currently disabled to prevent excessive verbosity - eventq2=thegenieinfo.Q2; - eventEnu=thegenieinfo.probeenergy; + eventq2=thegenieinfo.Q2; //MeV + eventEnu=thegenieinfo.probeenergy; //MeV + eventPnu=thegenieinfo.probethreemomentum; //MeV neutrinopdg=thegenieinfo.probepdg; - muonenergy=thegenieinfo.fsleptonenergy; + muonenergy=thegenieinfo.fsleptonenergy; //MeV muonangle=thegenieinfo.fslangle; nuIntxVtx_X=thegenieinfo.Intx_x; // cm @@ -330,11 +329,11 @@ bool LoadGenieEvent::Execute(){ } else { isinfiducialvol = false; } fsleptonname = std::string(thegenieinfo.fsleptonname); - fsleptonenergy = thegenieinfo.fsleptonenergy; + fsleptonenergy = thegenieinfo.fsleptonenergy; //MeV fsleptonpdg = thegenieinfo.fsleptonpdg; - fsleptonm = thegenieinfo.fsleptonm; - fsleptonmomentum = thegenieinfo.fsleptonmomentum; - fsleptonmomentumdir = thegenieinfo.fsleptonmomentumdir; + fsleptonm = thegenieinfo.fsleptonm; //MeV + fsleptonmomentum = thegenieinfo.fsleptonmomentum; //MeV +// fsleptonmomentumdir = thegenieinfo.fsleptonmomentumdir; fsleptonvtx = thegenieinfo.fsleptonvtx; // cm fsleptont = thegenieinfo.fsleptont; // ns @@ -423,6 +422,7 @@ bool LoadGenieEvent::Execute(){ geniestore->Set("NuVtxInFidVol",isinfiducialvol); geniestore->Set("EventQ2",eventq2); geniestore->Set("NeutrinoEnergy",eventEnu); + geniestore->Set("NeutrinoMomentum",eventPnu); geniestore->Set("NeutrinoPDG",neutrinopdg); geniestore->Set("MuonEnergy",muonenergy); geniestore->Set("MuonAngle",muonangle); @@ -431,7 +431,7 @@ bool LoadGenieEvent::Execute(){ geniestore->Set("FSLeptonMass",fsleptonm); geniestore->Set("FSLeptonEnergy",fsleptonenergy); geniestore->Set("FSLeptonMomentum",fsleptonmomentum); - geniestore->Set("FSLeptonMomentumDir",fsleptonmomentumdir); +// geniestore->Set("FSLeptonMomentumDir",fsleptonmomentumdir); geniestore->Set("FSLeptonVertex",fsleptonvtx); geniestore->Set("FSLeptonTime",fsleptont); geniestore->Set("NumFSProtons",numfsprotons); @@ -449,6 +449,7 @@ bool LoadGenieEvent::Execute(){ //geniestore->Set("TheGenieInfoPtr",&thegenieinfo,false); //intptr_t thegenieinfoptr = reinterpret_cast(&thegenieinfo); //m_data->CStore.Set("TheGenieInfoPtr2",thegenieinfoptr); + tchainentrynum++; Log("Tool LoadGenieEvent: Clearing genieintx",v_debug,verbosity); genieintx->Clear(); // REQUIRED TO PREVENT MEMORY LEAK @@ -522,20 +523,23 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter /*Double_t*/ thegenieinfo.Intx_x = IntxVtx->X() * 100.; // same info as nuvtx in g4dirt file /*Double_t*/ thegenieinfo.Intx_y = IntxVtx->Y() * 100.; // GENIE uses meters /*Double_t*/ thegenieinfo.Intx_z = IntxVtx->Z() * 100.; // GENIE uses meters - /*Double_t*/ thegenieinfo.Intx_t = IntxVtx->T() * 1000000000; // GENIE uses seconds + /*Double_t*/ thegenieinfo.Intx_t = IntxVtx->T() * 1000000000.; // GENIE uses seconds // neutrino information: - /*Double_t*/ thegenieinfo.probeenergy = genieint->InitState().ProbeE(genie::kRfLab); // GeV + /*Double_t*/ thegenieinfo.probeenergy = genieint->InitState().ProbeE(genie::kRfLab)*1000.; //GeV->MeV /*Int_t*/ thegenieinfo.probepdg = genieint->InitState().Probe()->PdgCode(); /*TString*/ thegenieinfo.probepartname = genieint->InitState().Probe()->GetName(); - TLorentzVector* probemomentum = gevtRec->Probe()->P4(); + TLorentzVector* probemomentum = new TLorentzVector(gevtRec->Probe()->P4()->Px()*1000., + gevtRec->Probe()->P4()->Py()*1000., + gevtRec->Probe()->P4()->Pz()*1000., + gevtRec->Probe()->P4()->E()*1000.); //GeV->MeV if(probemomentum->E()!=thegenieinfo.probeenergy){ logmessage = "LoadGenieEvent Tool: WARNING, Probe energy from probemomentum.E and ProbeE differ!"; logmessage+= "ProbeE = "+to_string(thegenieinfo.probeenergy); logmessage+= ", ProbeMomentum[0] = "+to_string(probemomentum->E()); Log(logmessage,v_warning,verbosity); } - /*TVector3*/ thegenieinfo.probethreemomentum = TVector3ToDirection(probemomentum->Vect()); + /*Direction*/ thegenieinfo.probethreemomentum = TVector3ToDirection(probemomentum->Vect()); /*TVector3*/ thegenieinfo.probemomentumdir = thegenieinfo.probethreemomentum.Unit(); /*Double_t*/ thegenieinfo.probeanglex = TMath::ATan(thegenieinfo.probethreemomentum.X()/thegenieinfo.probethreemomentum.Z()); @@ -557,9 +561,12 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter /*TVector3*/ thegenieinfo.targetnucleonthreemomentum=Direction(0.,0.,0.); /*Double_t*/ thegenieinfo.targetnucleonenergy=0.; if(targetnucleon){ - TLorentzVector* targetnucleonmomentum = targetnucleon->P4(); + TLorentzVector* targetnucleonmomentum = new TLorentzVector(targetnucleon->P4()->Px()*1000., + targetnucleon->P4()->Py()*1000., + targetnucleon->P4()->Pz()*1000., + targetnucleon->P4()->E()*1000.); //GeV->MeV thegenieinfo.targetnucleonthreemomentum = TVector3ToDirection(targetnucleonmomentum->Vect()); - thegenieinfo.targetnucleonenergy = targetnucleonmomentum->Energy(); //GeV + thegenieinfo.targetnucleonenergy = targetnucleonmomentum->Energy(); } // target nucleus: @@ -577,7 +584,7 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter /*Double_t*/ thegenieinfo.remnantnucleusenergy=-1.; if(remnucpos>-1){ thegenieinfo.remnantnucleusname = gevtRec->Particle(remnucpos)->Name(); - thegenieinfo.remnantnucleusenergy = gevtRec->Particle(remnucpos)->Energy(); //GeV + thegenieinfo.remnantnucleusenergy = gevtRec->Particle(remnucpos)->Energy()*1000.; //GeV->MeV } // final state lepton: @@ -592,17 +599,19 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter /*TVector3*/ thegenieinfo.fsleptonvtx=Position(0.,0.,0.); if(fsleppos>-1){ thegenieinfo.fsleptonname = gevtRec->Particle(fsleppos)->Name(); - thegenieinfo.fsleptonenergy = gevtRec->Particle(fsleppos)->Energy(); + thegenieinfo.fsleptonenergy = gevtRec->Particle(fsleppos)->Energy()*1000.; //GeV->MeV thegenieinfo.fsleptonpdg = gevtRec->Particle(fsleppos)->Pdg(); - thegenieinfo.fsleptonm = gevtRec->Particle(fsleppos)->Mass(); - thegenieinfo.fsleptonmomentum = Direction(gevtRec->Particle(fsleppos)->Px(), - gevtRec->Particle(fsleppos)->Py(), - gevtRec->Particle(fsleppos)->Pz()); + thegenieinfo.fsleptonm = gevtRec->Particle(fsleppos)->Mass()*1000.; //GeV->MeV + TLorentzVector* fsleptonmom = new TLorentzVector(gevtRec->Particle(fsleppos)->Px()*1000., + gevtRec->Particle(fsleppos)->Py()*1000., + gevtRec->Particle(fsleppos)->Pz()*1000., + gevtRec->Particle(fsleppos)->E()*1000.); //GeV->MeV + thegenieinfo.fsleptonmomentum = TVector3ToDirection(fsleptonmom->Vect()); thegenieinfo.fsleptonmomentumdir = thegenieinfo.fsleptonmomentum.Unit(); - thegenieinfo.fsleptonvtx = Position(gevtRec->Particle(fsleppos)->Vx()*100, - gevtRec->Particle(fsleppos)->Vy()*100, - gevtRec->Particle(fsleppos)->Vz()*100); //meters -> cm - thegenieinfo.fsleptont = gevtRec->Particle(fsleppos)->Vt()*1000000000; //sec -> ns + thegenieinfo.fsleptonvtx = Position(gevtRec->Particle(fsleppos)->Vx()*100., + gevtRec->Particle(fsleppos)->Vy()*100., + gevtRec->Particle(fsleppos)->Vz()*100.); //meters -> cm + thegenieinfo.fsleptont = gevtRec->Particle(fsleppos)->Vt()*1000000000.; //sec -> ns } // other remnants: TEMP FIX: this information is NOT being correctly read in @@ -635,7 +644,7 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter int pdgc = p->Pdg(); int status = p->Status(); - double wclimit = 0.160; //water Cherenkov momentum threshold + double wclimit = 0.160; //water Cherenkov momentum threshold GeV if (status != genie::kIStStableFinalState) continue; @@ -673,11 +682,17 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter } // kinematic information - Double_t NucleonM = genie::constants::kNucleonMass; + Double_t NucleonM = genie::constants::kNucleonMass*1000.; //GeV->MeV // Calculate kinematic variables "as an experimentalist would measure them; // neglecting fermi momentum and off-shellness of bound nucleons" - TLorentzVector* k1 = gevtRec->Probe()->P4(); - TLorentzVector* k2 = gevtRec->FinalStatePrimaryLepton()->P4(); + TLorentzVector* k1 = new TLorentzVector(gevtRec->Probe()->P4()->Px()*1000., + gevtRec->Probe()->P4()->Py()*1000., + gevtRec->Probe()->P4()->Pz()*1000., + gevtRec->Probe()->P4()->E()*1000.); //GeV->MeV + TLorentzVector* k2 = new TLorentzVector(gevtRec->FinalStatePrimaryLepton()->P4()->Px()*1000., + gevtRec->FinalStatePrimaryLepton()->P4()->Py()*1000., + gevtRec->FinalStatePrimaryLepton()->P4()->Pz()*1000., + gevtRec->FinalStatePrimaryLepton()->P4()->E()*1000.); //GeV->MeV /*Double_t*/ thegenieinfo.costhfsl = TMath::Cos( k2->Vect().Angle(k1->Vect()) ); /*Double_t*/ thegenieinfo.fslangle = k2->Vect().Angle(k1->Vect()); // q=k1-k2, 4-p transfer @@ -700,7 +715,7 @@ void LoadGenieEvent::GetGenieEntryInfo(genie::EventRecord* gevtRec, genie::Inter if(printneutrinoevent){ cout<<"This was a "<< thegenieinfo.procinfostring <<" (neut code "<-1){ - cout<<"producing a "<-1){ - cout<<" and a "<GetHeader()->GetGenieEntryNum(); /*if(verbosity>3)*/ cout<<"Genie file is "<CStore.Set("GenieFile",geniefilename); - m_data->CStore.Set("GenieEntry",genieentry); + m_data->CStore.Set("GenieEntry",std::to_string(genieentry)); for(int trigi=0; trigiwcsimrootevent->GetNumberOfEvents(); trigi++){ diff --git a/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp b/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp index a35c9b49a..348025216 100644 --- a/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp +++ b/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp @@ -305,6 +305,23 @@ bool PhaseIITreeMaker::Initialise(std::string configfile, DataModel &data){ fPhaseIITrigTree->Branch("trueNeutCapE",&fTrueNeutCapE); fPhaseIITrigTree->Branch("trueNeutCapGammaE",&fTrueNeutCapGammaE); fPhaseIITrigTree->Branch("trueNeutrinoEnergy",&fTrueNeutrinoEnergy,"trueNeutrinoEnergy/D"); + fPhaseIITrigTree->Branch("trueNeutrinoMomentum_X",&fTrueNeutrinoMomentum_X,"trueNeutrinoMomentum_X/D"); + fPhaseIITrigTree->Branch("trueNeutrinoMomentum_Y",&fTrueNeutrinoMomentum_Y,"trueNeutrinoMomentum_Y/D"); + fPhaseIITrigTree->Branch("trueNeutrinoMomentum_Z",&fTrueNeutrinoMomentum_Z,"trueNeutrinoMomentum_Z/D"); + fPhaseIITrigTree->Branch("trueNuIntxVtx_X",&fTrueNuIntxVtx_X,"trueNuIntxVtx_X/D"); + fPhaseIITrigTree->Branch("trueNuIntxVtx_Y",&fTrueNuIntxVtx_Y,"trueNuIntxVtx_Y/D"); + fPhaseIITrigTree->Branch("trueNuIntxVtx_Z",&fTrueNuIntxVtx_Z,"trueNuIntxVtx_Z/D"); + fPhaseIITrigTree->Branch("trueNuIntxVtx_T",&fTrueNuIntxVtx_T,"trueNuIntxVtx_T/D"); + fPhaseIITrigTree->Branch("trueFSLVtx_X",&fTrueFSLVtx_X,"trueFSLVtx_X/D"); + fPhaseIITrigTree->Branch("trueFSLVtx_Y",&fTrueFSLVtx_Y,"trueFSLVtx_Y/D"); + fPhaseIITrigTree->Branch("trueFSLVtx_Z",&fTrueFSLVtx_Z,"trueFSLVtx_Z/D"); + fPhaseIITrigTree->Branch("trueFSLMomentum_X",&fTrueFSLMomentum_X,"trueFSLMomentum_X/D"); + fPhaseIITrigTree->Branch("trueFSLMomentum_Y",&fTrueFSLMomentum_Y,"trueFSLMomentum_Y/D"); + fPhaseIITrigTree->Branch("trueFSLMomentum_Z",&fTrueFSLMomentum_Z,"trueFSLMomentum_Z/D"); + fPhaseIITrigTree->Branch("trueFSLTime",&fTrueFSLTime,"trueFSLTime/D"); + fPhaseIITrigTree->Branch("trueFSLMass",&fTrueFSLMass,"trueFSLMass/D"); + fPhaseIITrigTree->Branch("trueFSLPdg",&fTrueFSLPdg,"trueFSLPdg/I"); + fPhaseIITrigTree->Branch("trueFSLEnergy",&fTrueFSLEnergy,"trueFSLEnergy/D"); fPhaseIITrigTree->Branch("trueQ2",&fTrueQ2,"trueQ2/D"); fPhaseIITrigTree->Branch("trueCC",&fTrueCC,"trueCC/I"); fPhaseIITrigTree->Branch("trueQEL",&fTrueQEL,"trueQEL/I"); @@ -314,6 +331,15 @@ bool PhaseIITreeMaker::Initialise(std::string configfile, DataModel &data){ fPhaseIITrigTree->Branch("trueMEC",&fTrueMEC,"trueMEC/I"); fPhaseIITrigTree->Branch("trueNeutrons",&fTrueNeutrons,"trueNeutrons/I"); fPhaseIITrigTree->Branch("trueProtons",&fTrueProtons,"trueProtons/I"); + fPhaseIITrigTree->Branch("truePi0",&fTruePi0,"truePi0/I"); + fPhaseIITrigTree->Branch("truePiPlus",&fTruePiPlus,"truePiPlus/I"); + fPhaseIITrigTree->Branch("truePiPlusCher",&fTruePiPlusCher,"truePiPlusCher/I"); + fPhaseIITrigTree->Branch("truePiMinus",&fTruePiMinus,"truePiMinus/I"); + fPhaseIITrigTree->Branch("truePiMinusCher",&fTruePiMinusCher,"truePiMinusCher/I"); + fPhaseIITrigTree->Branch("trueKPlus",&fTrueKPlus,"trueKPlus/I"); + fPhaseIITrigTree->Branch("trueKPlusCher",&fTrueKPlusCher,"trueKPlusCher/I"); + fPhaseIITrigTree->Branch("trueKMinus",&fTrueKMinus,"trueKMinus/I"); + fPhaseIITrigTree->Branch("trueKMinusCher",&fTrueKMinusCher,"trueKMinusCher/I"); } // Reconstructed variables from each step in Muon Reco Analysis @@ -854,6 +880,23 @@ void PhaseIITreeMaker::ResetVariables() { fTrueNeutCapE->clear(); fTrueNeutCapGammaE->clear(); fTrueNeutrinoEnergy = -9999; + fTrueNeutrinoMomentum_X = -9999; + fTrueNeutrinoMomentum_Y = -9999; + fTrueNeutrinoMomentum_Z = -9999; + fTrueNuIntxVtx_X = -9999; + fTrueNuIntxVtx_Y = -9999; + fTrueNuIntxVtx_Z = -9999; + fTrueNuIntxVtx_T = -9999; + fTrueFSLVtx_X = -9999; + fTrueFSLVtx_Y = -9999; + fTrueFSLVtx_Z = -9999; + fTrueFSLMomentum_X = -9999; + fTrueFSLMomentum_Y = -9999; + fTrueFSLMomentum_Z = -9999; + fTrueFSLTime = -9999; + fTrueFSLMass = -9999; + fTrueFSLPdg = -9999; + fTrueFSLEnergy = -9999; fTrueQ2 = -9999; fTrueCC = -9999; fTrueQEL = -9999; @@ -863,6 +906,15 @@ void PhaseIITreeMaker::ResetVariables() { fTrueMEC = -9999; fTrueProtons = -9999; fTrueNeutrons = -9999; + fTruePi0 = -9999; + fTruePiPlus = -9999; + fTruePiPlusCher = -9999; + fTruePiMinus = -9999; + fTruePiMinusCher = -9999; + fTrueKPlus = -9999; + fTrueKPlusCher = -9999; + fTrueKMinus = -9999; + fTrueKMinusCher = -9999; } if (RecoDebug_fill){ @@ -1615,35 +1667,89 @@ bool PhaseIITreeMaker::FillMCTruthInfo() { //Load genie information if (hasGenie){ - double TrueNeutrinoEnergy, TrueQ2; - bool TrueCC, TrueQEL, TrueDIS, TrueCOH, TrueMEC, TrueRES; - int fsNeutrons, fsProtons; - bool get_neutrino_energy = m_data->Stores["GenieInfo"]->Get("NeutrinoEnergy",TrueNeutrinoEnergy); - bool get_q2 = m_data->Stores["GenieInfo"]->Get("EventQ2",TrueQ2); - bool get_cc = m_data->Stores["GenieInfo"]->Get("IsWeakCC",TrueCC); - bool get_qel = m_data->Stores["GenieInfo"]->Get("IsQuasiElastic",TrueQEL); - bool get_res = m_data->Stores["GenieInfo"]->Get("IsResonant",TrueRES); - bool get_dis = m_data->Stores["GenieInfo"]->Get("IsDeepInelastic",TrueDIS); - bool get_coh = m_data->Stores["GenieInfo"]->Get("IsCoherent",TrueCOH); - bool get_mec = m_data->Stores["GenieInfo"]->Get("IsMEC",TrueMEC); - bool get_n = m_data->Stores["GenieInfo"]->Get("NumFSNeutrons",fsNeutrons); - bool get_p = m_data->Stores["GenieInfo"]->Get("NumFSProtons",fsProtons); - std::cout <<"get_neutrino: "<Stores["GenieInfo"]->Get("NeutrinoEnergy",TrueNeutrinoEnergy); + bool get_neutrino_mom = m_data->Stores["GenieInfo"]->Get("NeutrinoMomentum",TrueNeutrinoMomentum); + bool get_neutrino_vtxx = m_data->Stores["GenieInfo"]->Get("NuIntxVtx_X",TrueNuIntxVtx_X); + bool get_neutrino_vtxy = m_data->Stores["GenieInfo"]->Get("NuIntxVtx_Y",TrueNuIntxVtx_Y); + bool get_neutrino_vtxz = m_data->Stores["GenieInfo"]->Get("NuIntxVtx_Z",TrueNuIntxVtx_Z); + bool get_neutrino_vtxt = m_data->Stores["GenieInfo"]->Get("NuIntxVtx_T",TrueNuIntxVtx_T); + bool get_q2 = m_data->Stores["GenieInfo"]->Get("EventQ2",TrueQ2); + bool get_cc = m_data->Stores["GenieInfo"]->Get("IsWeakCC",TrueCC); + bool get_qel = m_data->Stores["GenieInfo"]->Get("IsQuasiElastic",TrueQEL); + bool get_res = m_data->Stores["GenieInfo"]->Get("IsResonant",TrueRES); + bool get_dis = m_data->Stores["GenieInfo"]->Get("IsDeepInelastic",TrueDIS); + bool get_coh = m_data->Stores["GenieInfo"]->Get("IsCoherent",TrueCOH); + bool get_mec = m_data->Stores["GenieInfo"]->Get("IsMEC",TrueMEC); + bool get_n = m_data->Stores["GenieInfo"]->Get("NumFSNeutrons",fsNeutrons); + bool get_p = m_data->Stores["GenieInfo"]->Get("NumFSProtons",fsProtons); + bool get_pi0 = m_data->Stores["GenieInfo"]->Get("NumFSPi0",fsPi0); + bool get_piplus = m_data->Stores["GenieInfo"]->Get("NumFSPiPlus",fsPiPlus); + bool get_pipluscher = m_data->Stores["GenieInfo"]->Get("NumFSPiPlusCher",fsPiPlusCher); + bool get_piminus = m_data->Stores["GenieInfo"]->Get("NumFSPiMinus",fsPiMinus); + bool get_piminuscher = m_data->Stores["GenieInfo"]->Get("NumFSPiMinusCher",fsPiMinusCher); + bool get_kplus = m_data->Stores["GenieInfo"]->Get("NumFSKPlus",fsKPlus); + bool get_kpluscher = m_data->Stores["GenieInfo"]->Get("NumFSKPlusCher",fsKPlusCher); + bool get_kminus = m_data->Stores["GenieInfo"]->Get("NumFSKMinus",fsKMinus); + bool get_kminuscher = m_data->Stores["GenieInfo"]->Get("NumFSKMinusCher",fsKMinusCher); + bool get_fsl_vtx = m_data->Stores["GenieInfo"]->Get("FSLeptonVertex",TrueFSLeptonVtx); + bool get_fsl_momentum = m_data->Stores["GenieInfo"]->Get("FSLeptonMomentum",TrueFSLeptonMomentum); + bool get_fsl_time = m_data->Stores["GenieInfo"]->Get("FSLeptonTime",TrueFSLeptonTime); + bool get_fsl_mass = m_data->Stores["GenieInfo"]->Get("FSLeptonMass",TrueFSLeptonMass); + bool get_fsl_pdg = m_data->Stores["GenieInfo"]->Get("FSLeptonPdg",TrueFSLeptonPdg); + bool get_fsl_energy = m_data->Stores["GenieInfo"]->Get("FSLeptonEnergy",TrueFSLeptonEnergy); + std::cout <<"get_neutrino_energy: "< Date: Mon, 25 Sep 2023 21:01:13 +0200 Subject: [PATCH 09/31] Added the final version of the SaveConfigInfo UserTool to the current ToolAnalysis Application branch (#244) Authored-by: Johann Martyn --- Makefile | 4 +- .../ANNIEEventBuilder/ANNIEEventBuilder.cpp | 4 + UserTools/Factory/Factory.cpp | 2 + UserTools/ReadConfigInfo/README.md | 21 ++ UserTools/ReadConfigInfo/ReadConfigInfo.cpp | 86 +++++++++ UserTools/ReadConfigInfo/ReadConfigInfo.h | 48 +++++ UserTools/SaveConfigInfo/README.md | 23 +++ UserTools/SaveConfigInfo/SaveConfigInfo.cpp | 180 ++++++++++++++++++ UserTools/SaveConfigInfo/SaveConfigInfo.h | 52 +++++ UserTools/Unity.h | 2 + .../ANNIEEventBuilderConfig | 20 ++ .../DataDecoderwConfigInfo/BeamDecoderConfig | 17 ++ .../DefaultTriggerMask.txt | 7 + .../DataDecoderwConfigInfo/LoadGeometryConfig | 8 + .../DataDecoderwConfigInfo/LoadRawDataConfig | 9 + .../MRDDataDecoderConfig | 2 + .../PMTDataDecoderConfig | 5 + .../PhaseIIADCCalibratorConfig | 15 ++ .../PhaseIIADCHitFinderConfig | 10 + .../SaveConfigInfoConfig | 3 + .../Stage1DataBuilderConfig | 2 + .../DataDecoderwConfigInfo/ToolChainConfig | 23 +++ .../DataDecoderwConfigInfo/ToolsConfig | 11 ++ .../TriggerDataDecoderConfig | 4 + .../DataDecoderwConfigInfo/my_files.txt | 3 + configfiles/ReadConfigInfo/DummyToolConfig | 3 + .../ReadConfigInfo/LoadANNIEEventConfig | 4 + configfiles/ReadConfigInfo/README.md | 25 +++ .../ReadConfigInfo/ReadConfigInfoConfig | 2 + configfiles/ReadConfigInfo/ToolChainConfig | 26 +++ configfiles/ReadConfigInfo/ToolsConfig | 2 + configfiles/ReadConfigInfo/my_inputs.txt | 1 + 32 files changed, 623 insertions(+), 1 deletion(-) create mode 100644 UserTools/ReadConfigInfo/README.md create mode 100644 UserTools/ReadConfigInfo/ReadConfigInfo.cpp create mode 100644 UserTools/ReadConfigInfo/ReadConfigInfo.h create mode 100644 UserTools/SaveConfigInfo/README.md create mode 100644 UserTools/SaveConfigInfo/SaveConfigInfo.cpp create mode 100644 UserTools/SaveConfigInfo/SaveConfigInfo.h create mode 100644 configfiles/DataDecoderwConfigInfo/ANNIEEventBuilderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/BeamDecoderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/DefaultTriggerMask.txt create mode 100644 configfiles/DataDecoderwConfigInfo/LoadGeometryConfig create mode 100644 configfiles/DataDecoderwConfigInfo/LoadRawDataConfig create mode 100644 configfiles/DataDecoderwConfigInfo/MRDDataDecoderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/PMTDataDecoderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/PhaseIIADCCalibratorConfig create mode 100644 configfiles/DataDecoderwConfigInfo/PhaseIIADCHitFinderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/SaveConfigInfoConfig create mode 100644 configfiles/DataDecoderwConfigInfo/Stage1DataBuilderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/ToolChainConfig create mode 100644 configfiles/DataDecoderwConfigInfo/ToolsConfig create mode 100644 configfiles/DataDecoderwConfigInfo/TriggerDataDecoderConfig create mode 100644 configfiles/DataDecoderwConfigInfo/my_files.txt create mode 100644 configfiles/ReadConfigInfo/DummyToolConfig create mode 100644 configfiles/ReadConfigInfo/LoadANNIEEventConfig create mode 100644 configfiles/ReadConfigInfo/README.md create mode 100644 configfiles/ReadConfigInfo/ReadConfigInfoConfig create mode 100644 configfiles/ReadConfigInfo/ToolChainConfig create mode 100644 configfiles/ReadConfigInfo/ToolsConfig create mode 100644 configfiles/ReadConfigInfo/my_inputs.txt diff --git a/Makefile b/Makefile index a3add16b9..f5694a95e 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,8 @@ ToolDAQPath=${PWD}/ToolDAQ -CPPFLAGS= -Wno-reorder -Wno-sign-compare -Wno-unused-variable -Wno-unused-but-set-variable -Werror=return-type -Wl,--no-as-needed +GIT_VERSION := "$(shell git describe --dirty --always)" + +CPPFLAGS= -DVERSION=\"$(GIT_VERSION)\" -Wno-reorder -Wno-sign-compare -Wno-unused-variable -Wno-unused-but-set-variable -Werror=return-type -Wl,--no-as-needed CC=g++ -std=c++1y -g -fPIC -shared $(CPPFLAGS) CCC= g++ -std=c++1y -g -fPIC $(CPPFLAGS) diff --git a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp index ecfadcd1a..5c1d6271a 100644 --- a/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp +++ b/UserTools/ANNIEEventBuilder/ANNIEEventBuilder.cpp @@ -2516,6 +2516,10 @@ void ANNIEEventBuilder::SaveEntryToFile(int RunNum, int SubRunNum, int PartNum) /*if(verbosity>4)*/ std::cout << "ANNIEEvent: Saving ANNIEEvent entry"+to_string(ANNIEEventNum) << std::endl; std::string Filename = SavePath + ProcessedFilesBasename + "_"+BuildType+"_R" + to_string(RunNum) + "S" + to_string(SubRunNum) + "p" + to_string(PartNum); + std::string config_info; //Save the ConfigInfo if it exists + if( m_data->CStore.Get("ConfigInfo",config_info) ){ + ANNIEEvent->Header->Set("ConfigInfo",config_info); + } if (SaveSeparatePartfiles) ANNIEEvent->Save(Filename); std::cout<<"ANNIEEvent: "<Print(false); diff --git a/UserTools/Factory/Factory.cpp b/UserTools/Factory/Factory.cpp index 59dc6005f..2215596e1 100644 --- a/UserTools/Factory/Factory.cpp +++ b/UserTools/Factory/Factory.cpp @@ -159,5 +159,7 @@ if (tool=="FilterLAPPDEvents") ret=new FilterLAPPDEvents; if (tool=="FilterEvents") ret=new FilterEvents; if (tool=="Stage1DataBuilder") ret=new Stage1DataBuilder; if (tool=="BeamFetcherV2") ret=new BeamFetcherV2; +if (tool=="SaveConfigInfo") ret=new SaveConfigInfo; +if (tool=="ReadConfigInfo") ret=new ReadConfigInfo; return ret; } diff --git a/UserTools/ReadConfigInfo/README.md b/UserTools/ReadConfigInfo/README.md new file mode 100644 index 000000000..47104723d --- /dev/null +++ b/UserTools/ReadConfigInfo/README.md @@ -0,0 +1,21 @@ +# ReadConfigInfo + +ReadConfigInfo + +## Data + +Reads the ANNIEEvent Header `ANNIEEvent->Header->Get("ConfigInfo",config_info)` +and saves the content of the config_info string into an outputfile. +The ANNIEEvent BoostStore is provided by the LoadANNIEEvent Tool. +It can produce a single outputfile, or an individual outputfile for each Processed ANNIEEvent file given to the LoadANNIEEvent Tool. + +## Configuration + +Describe any configuration variables for ReadConfigInfo. + +``` +verbosity 3 +#If there is no FileName variable the filenames will be produced automatically as ConfigInfo_R*S*p*.txt. +#Otherwise only a single file will be produced with the name given with FileName +#FileName ReadConfigInfoTest.txt +``` diff --git a/UserTools/ReadConfigInfo/ReadConfigInfo.cpp b/UserTools/ReadConfigInfo/ReadConfigInfo.cpp new file mode 100644 index 000000000..c251f4a5b --- /dev/null +++ b/UserTools/ReadConfigInfo/ReadConfigInfo.cpp @@ -0,0 +1,86 @@ +#include "ReadConfigInfo.h" + +ReadConfigInfo::ReadConfigInfo():Tool(){} + + +bool ReadConfigInfo::Initialise(std::string configfile, DataModel &data){ + + verbosity = 0; + old_run_number = 0; + old_subrun_number = 0; + old_part_number = 0; + filename = ""; + write_seperate_files = false; + + /////////////////// Useful header /////////////////////// + if(configfile!="") m_variables.Initialise(configfile); // loading config file + //m_variables.Print(); + + m_data= &data; //assigning transient data pointer + ///////////////////////////////////////////////////////////////// + + m_variables.Get("verbosity", verbosity); + m_variables.Get("FileName", filename); + + if(filename == ""){ + write_seperate_files = true; + } + + Log("write_seperate_files: "+std::to_string(write_seperate_files), v_message, verbosity); + + return true; +} + + +bool ReadConfigInfo::Execute(){ + if(write_seperate_files){ //Write a txt file with the correspondinf ConfigInfo for each part file + int current_run_number; + int current_subrun_number; + int current_part_number; + + m_data->Stores["ANNIEEvent"]->Get("RunNumber", current_run_number); + m_data->Stores["ANNIEEvent"]->Get("SubrunNumber", current_subrun_number); + m_data->Stores["ANNIEEvent"]->Get("PartNumber", current_part_number); + + if(current_run_number != old_run_number || current_subrun_number != old_subrun_number || current_part_number != old_part_number){ + std::string config_info = "ConfigInfo does not exits in ANNIEEvent Header for R"+to_string(current_run_number)+"S"+to_string(current_subrun_number)+"p"+to_string(current_part_number) ; + if(m_data->Stores["ANNIEEvent"]->Header->Get("ConfigInfo",config_info)){ + filename = "ConfigInfo_R" + std::to_string(current_run_number) + "S" + std::to_string(current_subrun_number) + "p" + std::to_string(current_part_number) + ".txt"; + outfile.open (filename.c_str()); + outfile << config_info; + outfile.close(); + Log(filename, v_message, verbosity); + Log(config_info, v_message, verbosity); + } + else{ //If ConfigInfo does not exists throw an error message + Log(config_info, v_error, verbosity); + } + + old_run_number = current_run_number; + old_subrun_number = current_subrun_number; + old_part_number = current_part_number; + } + } + else{//Stop the loop if only a single file should be written + m_data->vars.Set("StopLoop",1); + } + return true; +} + + +bool ReadConfigInfo::Finalise(){ + if(write_seperate_files == 0){ //Write a single file + std::string config_info = "ConfigInfo does not exits in ANNIEEvent Header for filename: "+filename; + if(m_data->Stores["ANNIEEvent"]->Header->Get("ConfigInfo",config_info)){ + outfile.open (filename.c_str()); + outfile << config_info; + outfile.close(); + Log(filename, v_message, verbosity); + Log(config_info, v_message, verbosity); + } + else{ //If ConfigInfo does not exists throw an error message + Log(config_info, v_error, verbosity); + } + } + return true; +} diff --git a/UserTools/ReadConfigInfo/ReadConfigInfo.h b/UserTools/ReadConfigInfo/ReadConfigInfo.h new file mode 100644 index 000000000..ca151b67b --- /dev/null +++ b/UserTools/ReadConfigInfo/ReadConfigInfo.h @@ -0,0 +1,48 @@ +#ifndef ReadConfigInfo_H +#define ReadConfigInfo_H + +#include +#include +#include + +#include "Tool.h" + + +/** +* \class ReadConfigInfo +* +* ReadConfigInfo reads the ConfigInfo at the ANNIEEvent->Header and saves it in a single text file or multiple files, one for each entry in my_inputs.txt of the LoadANNIEEvent Tool +* +* $Author: Johann Martyn $ +* $Date: 2023/06/20 +* Contact: jomartyn@uni-mainz.de +*/ +class ReadConfigInfo: public Tool { + + + public: + + ReadConfigInfo(); ///< Simple constructor + bool Initialise(std::string configfile,DataModel &data); ///< Initialise Function for setting up Tool resources. @param configfile The path and name of the dynamic configuration file to read in. @param data A reference to the transient data class used to pass information between Tools. + bool Execute(); ///< Execute function used to perform Tool purpose. + bool Finalise(); ///< Finalise function used to clean up resources. + + + private: + std::string filename; + int verbosity; + int old_run_number; + int old_subrun_number; + int old_part_number; + ofstream outfile; + bool write_seperate_files; + const int v_error=0; + const int v_warning=1; + const int v_message=2; + const int v_debug=3; + + +}; + + +#endif diff --git a/UserTools/SaveConfigInfo/README.md b/UserTools/SaveConfigInfo/README.md new file mode 100644 index 000000000..a54231395 --- /dev/null +++ b/UserTools/SaveConfigInfo/README.md @@ -0,0 +1,23 @@ +# SaveConfigInfo + +SaveConfigInfo + +## Data + +Collects the git commit hash of the current folder and the content of a dynamic number of files into the +`std::string config_info` variable. +This string is then forwarded to the ANNIEEventBuilder Tool via `m_data->CStore.Set("ConfigInfo",config_info)`. +In ANNIEEventBuilder.cpp it is then saved in the ANNIEEvent Header `ANNIEEvent->Header->Set("ConfigInfo",config_info)` +This is done for each part of file of the respective run. + +The SaveConfigInfo Tool is currently used in the `configfiles/DataDecoderwConfigInfo` ToolChain. + +## Configuration + + +``` +verbosity 0 +OutFileName config_info.txt #Save the config_info string additionally as a text file, external to the ANNIEEvent BoostStore file +ToolChainConfigFile ./configfiles/DataDecoderwConfigInfo/ToolChainConfig #The path and filename of the ToolChainConfig file, from which all other files are read +FullDepth 1 # some config files link to other *.txt or *.csv files and such. For "FullDepth 1" these are also saved, for 0 they are not saved. +``` \ No newline at end of file diff --git a/UserTools/SaveConfigInfo/SaveConfigInfo.cpp b/UserTools/SaveConfigInfo/SaveConfigInfo.cpp new file mode 100644 index 000000000..31fbceedb --- /dev/null +++ b/UserTools/SaveConfigInfo/SaveConfigInfo.cpp @@ -0,0 +1,180 @@ +#include "SaveConfigInfo.h" + +SaveConfigInfo::SaveConfigInfo():Tool(){} + + +bool SaveConfigInfo::Initialise(std::string configfile, DataModel &data){ + + verbosity = 0; + outfilename = "configInfo.txt"; + config_info = "THIS IS NOT WORKING"; + full_depth = false; + /////////////////// Useful header /////////////////////// + if(configfile!="") m_variables.Initialise(configfile); // loading config file + //m_variables.Print(); + + m_data= &data; //assigning transient data pointer + ///////////////////////////////////////////////////////////////// + + m_variables.Get("verbosity",verbosity); + m_variables.Get("OutFileName",outfilename); + m_variables.Get("FullDepth",full_depth); + // Include the output filename in vec_configfiles to avoid a double entry + vec_configfiles.push_back(outfilename); + + // First we read the git commit hash from the Makefile + buffer << "git commit hash saved in Makefile during compile time\n"; + buffer << VERSION; + if( strstr(VERSION,"-dirty") ){ + buffer << "\ndirty: The working tree has local modification. This must not necessarliy impact the ToolChain which has been run just now.\n"; + } + buffer << "\n------------------------------------------------\n\n"; + + // First we look for the name of the Tools_File, which includes all other UserTool Config file names + // This is saved in the vars Store + std::string line; + m_data->vars.Get("Tools_File", line); + vec_configfiles.push_back(line); + + // Next we look through the Tools_File and save the names of all ConfigFiles + buffer << vec_configfiles[1] << "\n"; + if( std::ifstream(vec_configfiles[1].c_str()) ){ + buffer << std::ifstream(vec_configfiles[1].c_str()).rdbuf(); + infile.open(vec_configfiles[1].c_str()); + std::string uniquename, toolname, configfile; + while(getline(infile, line)){ + std::stringstream ss(line); + ss >> uniquename >> toolname >> configfile; + if(uniquename[0] != '#') vec_configfiles.push_back(configfile); + } + infile.close(); + } + else{ + Log(vec_configfiles[1] + " does not exist!", v_error,verbosity); + buffer << " - does not exist!"; + } + buffer << "\n------------------------------------------------\n\n"; + + // Last come the files defined in vec_configfiles[0] + if(full_depth == false){ + for(int i=2; i vec_depth(vec_configfiles.size()); + for(int i=0; i vec_local_files; + ifstream local_infile; + while( getline(infile,line) ){ + + // Skip lines, which are commented out + if(line.empty()) continue; + char firstchar = '0'; + for(char& achar : line){ + if(std::isspace(achar)) continue; + firstchar = achar; + break; + } + if(firstchar == '#') continue; + + // Now read te line and check if it contains another textfile that can be openend + std::stringstream ss(line); + while( !ss.eof() ){ + ss >> token; + //Avoid reading in the RawData binaries + if(token.find("RAWData") != std::string::npos) continue; + //Avoid reading in ROOT files + if(token.find(".root") != std::string::npos) continue; + + local_infile.open( token.c_str() ); + if( local_infile.is_open() ){ + // We need to avoid double entries and endless loops + bool double_entry = false; + for(int k=0; k= v_debug){ + std::cout << "Number of local files to open from " << vec_configfiles[i] << ": " << vec_local_files.size() << std::endl; + for(int j=0; jCStore.Get("ConfigInfo",config_info) == 0){ + m_data->CStore.Set("ConfigInfo",buffer.str()); + } + return true; +} + + +bool SaveConfigInfo::Finalise(){ + + if(m_data->CStore.Get("ConfigInfo",config_info)){ + Log("SaveConfigInfo: ConfigInfo" + config_info, v_debug,verbosity); + } + else{ + Log("SaveConfigInfo: ConfigInfo is missing! This is unexpected!", v_warning,verbosity); + } + return true; +} \ No newline at end of file diff --git a/UserTools/SaveConfigInfo/SaveConfigInfo.h b/UserTools/SaveConfigInfo/SaveConfigInfo.h new file mode 100644 index 000000000..00524a89a --- /dev/null +++ b/UserTools/SaveConfigInfo/SaveConfigInfo.h @@ -0,0 +1,52 @@ +#ifndef SaveConfigInfo_H +#define SaveConfigInfo_H + +#include +#include +#include +#include + +#include "Tool.h" + +#include + + +/** +* \class SaveConfigInfo +* +* SaveConfigInfo reads a list of textfiles and the git commit hash and saves them to the CStore with std::string config_info +* +* $Author: Johann Martyn $ +* $Date: 2023/06/20 +* Contact: jomartyn@uni-mainz.de +*/ +class SaveConfigInfo: public Tool { + + + public: + SaveConfigInfo(); ///< Simple constructor + bool Initialise(std::string configfile,DataModel &data); ///< Initialise Function for setting up Tool resources. @param configfile The path and name of the dynamic configuration file to read in. @param data A reference to the transient data class used to pass information between Tools. + bool Execute(); ///< Execute function used to perform Tool purpose. + bool Finalise(); ///< Finalise function used to clean up resources. + + + private: + std::vector vec_configfiles; + std::stringstream buffer; + std::string outfilename; + std::string config_info; + std::ofstream outfile; + std::ifstream infile; + bool full_depth; + + /// \brief verbosity levels: if 'verbosity' < this level, the message type will be logged. + int verbosity=0; + const int v_error=0; + const int v_warning=1; + const int v_message=2; + const int v_debug=3; + +}; + + +#endif diff --git a/UserTools/Unity.h b/UserTools/Unity.h index e77bfa810..db441a61d 100644 --- a/UserTools/Unity.h +++ b/UserTools/Unity.h @@ -167,3 +167,5 @@ #include "FilterEvents.h" #include "Stage1DataBuilder.h" #include "BeamFetcherV2.h" +#include "SaveConfigInfo.h" +#include "ReadConfigInfo.h" diff --git a/configfiles/DataDecoderwConfigInfo/ANNIEEventBuilderConfig b/configfiles/DataDecoderwConfigInfo/ANNIEEventBuilderConfig new file mode 100644 index 000000000..3586ccf3f --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/ANNIEEventBuilderConfig @@ -0,0 +1,20 @@ +verbosity 0 + +BuildType TankAndMRDAndCTC +ProcessedFilesBasename ProcessedRawData +NumEventsPerPairing 200 +SavePath ./ + +MinNumWavesInSet 134 // 1=Just throw any waveforms into ANNIE events if you got em + +ExecutesPerBuild 10 +OrphanOldTankTimestamps 1 +OldTimestampThreshold 1000 +OrphanFileBase OrphanStore +MaxStreamMatchingTimeSeparation 60 // seconds. If one stream is ahead of the others, pause reading + +SaveRawData 0 +StoreBeamStatus 1 + +BuildStage1Data 0 +SaveSeparatePartfiles 1 diff --git a/configfiles/DataDecoderwConfigInfo/BeamDecoderConfig b/configfiles/DataDecoderwConfigInfo/BeamDecoderConfig new file mode 100644 index 000000000..3866c2b30 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/BeamDecoderConfig @@ -0,0 +1,17 @@ +# BeamDecoder config file +verbosity 0 +# Names of devices needed for beam quality cuts +HornCurrentDevice E:THCURR +# The "first" toroid is the one farther upstream from the target +FirstToroid E:TOR860 +SecondToroid E:TOR875 +# POT window +CutPOTMin 5e11 +CutPOTMax 8e12 +# Peak horn current window (in kA) +CutPeakHornCurrentMin 172 +CutPeakHornCurrentMax 176 +# Toroid agreement tolerance (fractional error) +CutToroidAgreement 0.05 +# DB vs DAQ timestamp agreement tolerance (ms) +CutTimestampAgreement 100 diff --git a/configfiles/DataDecoderwConfigInfo/DefaultTriggerMask.txt b/configfiles/DataDecoderwConfigInfo/DefaultTriggerMask.txt new file mode 100644 index 000000000..8a2967429 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/DefaultTriggerMask.txt @@ -0,0 +1,7 @@ +#Triggers are given by Jonathan; place one number per line. Values are index + 1 +#4+1: Delayed beam. 32+1: LED trigger. 34+1: AmBe and Cosmic trigger. 35+1: MRD_CR_Trigger. 30+1: LED_Start +5 +36 +31 +33 +35 diff --git a/configfiles/DataDecoderwConfigInfo/LoadGeometryConfig b/configfiles/DataDecoderwConfigInfo/LoadGeometryConfig new file mode 100644 index 000000000..894092ba3 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/LoadGeometryConfig @@ -0,0 +1,8 @@ +verbosity 0 +LAPPDChannelCount 60 +FACCMRDGeoFile ./configfiles/LoadGeometry/FullMRDGeometry.csv +DetectorGeoFile ./configfiles/LoadGeometry/DetectorGeometrySpecs.csv +LAPPDGeoFile ./configfiles/LoadGeometry/LAPPDGeometry.csv +TankPMTGeoFile ./configfiles/LoadGeometry/FullTankPMTGeometry.csv +TankPMTGainFile ./configfiles/LoadGeometry/ChannelSPEGains_BeamRun20192020.csv +AuxiliaryChannelFile ./configfiles/LoadGeometry/AuxChannels.csv diff --git a/configfiles/DataDecoderwConfigInfo/LoadRawDataConfig b/configfiles/DataDecoderwConfigInfo/LoadRawDataConfig new file mode 100644 index 000000000..f439188a8 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/LoadRawDataConfig @@ -0,0 +1,9 @@ +verbosity 11 +BuildType TankAndMRDAndCTC +#BuildType CTC +Mode FileList +InputFile ./configfiles/DataDecoderwConfigInfo/my_files.txt +DummyRunInfo 1 +StoreTrigOverlap 0 +ReadTrigOverlap 1 +StoreRawData 0 diff --git a/configfiles/DataDecoderwConfigInfo/MRDDataDecoderConfig b/configfiles/DataDecoderwConfigInfo/MRDDataDecoderConfig new file mode 100644 index 000000000..8168ccdb7 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/MRDDataDecoderConfig @@ -0,0 +1,2 @@ +verbosity 2 +DaylightSavingsSpring 0 diff --git a/configfiles/DataDecoderwConfigInfo/PMTDataDecoderConfig b/configfiles/DataDecoderwConfigInfo/PMTDataDecoderConfig new file mode 100644 index 000000000..19e946601 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/PMTDataDecoderConfig @@ -0,0 +1,5 @@ +verbosity 0 +ADCCountsToBuildWaves 0 +Mode Offline +OffsetVME03 0 +OffsetVME01 0 diff --git a/configfiles/DataDecoderwConfigInfo/PhaseIIADCCalibratorConfig b/configfiles/DataDecoderwConfigInfo/PhaseIIADCCalibratorConfig new file mode 100644 index 000000000..158dc6ed1 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/PhaseIIADCCalibratorConfig @@ -0,0 +1,15 @@ +# PhaseIIADCCalibrator config file + +verbosity 0 + +BaselineEstimationType ze3ra_multi +NumBaselineSamples 15 +NumSubWaveforms 10 + +SamplesPerBaselineEstimate 2000 +BaselineUncertaintyTolerance 2 +PCritical 0.01 +MakeCalLEDWaveforms 0 + +EventBuilding 1 +ExecutesPerBuild 10 diff --git a/configfiles/DataDecoderwConfigInfo/PhaseIIADCHitFinderConfig b/configfiles/DataDecoderwConfigInfo/PhaseIIADCHitFinderConfig new file mode 100644 index 000000000..d183b7b27 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/PhaseIIADCHitFinderConfig @@ -0,0 +1,10 @@ +verbosity 0 + +UseLEDWaveforms 0 + +PulseFindingApproach threshold +PulseWindowType dynamic +DefaultADCThreshold 7 +DefaultThresholdType relative + +EventBuilding 1 diff --git a/configfiles/DataDecoderwConfigInfo/SaveConfigInfoConfig b/configfiles/DataDecoderwConfigInfo/SaveConfigInfoConfig new file mode 100644 index 000000000..a65d2aab4 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/SaveConfigInfoConfig @@ -0,0 +1,3 @@ +verbosity 5 +OutFileName config_info.txt +FullDepth 1 diff --git a/configfiles/DataDecoderwConfigInfo/Stage1DataBuilderConfig b/configfiles/DataDecoderwConfigInfo/Stage1DataBuilderConfig new file mode 100644 index 000000000..1bd00896b --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/Stage1DataBuilderConfig @@ -0,0 +1,2 @@ +Verbosity 0 +Basename Stage1Data diff --git a/configfiles/DataDecoderwConfigInfo/ToolChainConfig b/configfiles/DataDecoderwConfigInfo/ToolChainConfig new file mode 100644 index 000000000..2f9fee04a --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/ToolChainConfig @@ -0,0 +1,23 @@ +#ToolChain dynamic setup file + +##### Runtime Paramiters ##### +verbose 1 +error_level 0 # 0= do not exit, 1= exit on unhandeled errors only, 2= exit on unhandeled errors and handeled errors +attempt_recover 1 + +###### Logging ##### +log_mode Interactive # Interactive=cout , Remote= remote logging system "serservice_name Remote_Logging" , Local = local file log; +log_local_path ./log +log_service LogStore + +###### Service discovery ##### +service_publish_sec -1 +service_kick_sec -1 + +##### Tools To Add ##### +Tools_File ./configfiles/DataDecoderwConfigInfo/ToolsConfig + +##### Run Type ##### +Inline -1 +Interactive 0 + diff --git a/configfiles/DataDecoderwConfigInfo/ToolsConfig b/configfiles/DataDecoderwConfigInfo/ToolsConfig new file mode 100644 index 000000000..079762d1f --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/ToolsConfig @@ -0,0 +1,11 @@ +LoadGeometry LoadGeometry ./configfiles/LoadGeometry/LoadGeometryConfig +LoadRawData LoadRawData ./configfiles/DataDecoderwConfigInfo/LoadRawDataConfig +PMTDataDecoder PMTDataDecoder ./configfiles/DataDecoderwConfigInfo/PMTDataDecoderConfig +MRDDataDecoder MRDDataDecoder ./configfiles/DataDecoderwConfigInfo/MRDDataDecoderConfig +TriggerDataDecoder TriggerDataDecoder ./configfiles/DataDecoderwConfigInfo/TriggerDataDecoderConfig +BeamDecoder BeamDecoder ./configfiles/DataDecoderwConfigInfo/BeamDecoderConfig +PhaseIIADCCalibrator PhaseIIADCCalibrator ./configfiles/DataDecoderwConfigInfo/PhaseIIADCCalibratorConfig +PhaseIIADCHitFinder PhaseIIADCHitFinder ./configfiles/DataDecoderwConfigInfo/PhaseIIADCHitFinderConfig +SaveConfigInfo SaveConfigInfo ./configfiles/DataDecoderwConfigInfo/SaveConfigInfoConfig +ANNIEEventBuilder ANNIEEventBuilder ./configfiles/DataDecoderwConfigInfo/ANNIEEventBuilderConfig +Stage1DataBuilder Stage1DataBuilder ./configfiles/DataDecoderwConfigInfo/Stage1DataBuilderConfig diff --git a/configfiles/DataDecoderwConfigInfo/TriggerDataDecoderConfig b/configfiles/DataDecoderwConfigInfo/TriggerDataDecoderConfig new file mode 100644 index 000000000..c444157a6 --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/TriggerDataDecoderConfig @@ -0,0 +1,4 @@ +verbosity 0 +TriggerMaskFile ./configfiles/DataDecoderwConfigInfo/DefaultTriggerMask.txt +StoreTrigOverlap 0 +ReadTrigOverlap 0 diff --git a/configfiles/DataDecoderwConfigInfo/my_files.txt b/configfiles/DataDecoderwConfigInfo/my_files.txt new file mode 100644 index 000000000..31eed704b --- /dev/null +++ b/configfiles/DataDecoderwConfigInfo/my_files.txt @@ -0,0 +1,3 @@ +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p0 +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p1 +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p2 diff --git a/configfiles/ReadConfigInfo/DummyToolConfig b/configfiles/ReadConfigInfo/DummyToolConfig new file mode 100644 index 000000000..95cad88d2 --- /dev/null +++ b/configfiles/ReadConfigInfo/DummyToolConfig @@ -0,0 +1,3 @@ +# Dummy config file + +verbose 2 \ No newline at end of file diff --git a/configfiles/ReadConfigInfo/LoadANNIEEventConfig b/configfiles/ReadConfigInfo/LoadANNIEEventConfig new file mode 100644 index 000000000..a99fecd0d --- /dev/null +++ b/configfiles/ReadConfigInfo/LoadANNIEEventConfig @@ -0,0 +1,4 @@ +verbose 0 +FileForListOfInputs ./configfiles/ReadConfigInfo/my_inputs.txt +EventOffset 0 +GlobalEvNr 1 diff --git a/configfiles/ReadConfigInfo/README.md b/configfiles/ReadConfigInfo/README.md new file mode 100644 index 000000000..78d3e2015 --- /dev/null +++ b/configfiles/ReadConfigInfo/README.md @@ -0,0 +1,25 @@ +# Configure files + +*********************** +#Description +********************** + +Configure files are simple text files for passing variables to the Tools. + +Text files are read by the Store class (src/Store) and automatically assigned to an internal map for the relevant Tool to use. + + +************************ +#Usage +************************ + +Any line starting with a "#" will be ignored by the Store, as will blank lines. + +Variables should be stored one per line as follows: + + +Name Value #Comments + + +Note: Only one value is permitted per name and they are stored in a string stream and template cast back to the type given. + diff --git a/configfiles/ReadConfigInfo/ReadConfigInfoConfig b/configfiles/ReadConfigInfo/ReadConfigInfoConfig new file mode 100644 index 000000000..66cbf67c5 --- /dev/null +++ b/configfiles/ReadConfigInfo/ReadConfigInfoConfig @@ -0,0 +1,2 @@ +verbosity 10 +FileName ReadConfigInfoTest.txt diff --git a/configfiles/ReadConfigInfo/ToolChainConfig b/configfiles/ReadConfigInfo/ToolChainConfig new file mode 100644 index 000000000..b88414020 --- /dev/null +++ b/configfiles/ReadConfigInfo/ToolChainConfig @@ -0,0 +1,26 @@ +#ToolChain dynamic setup file + +##### Runtime Parameters ##### +verbose 1 ## Verbosity level of ToolChain +error_level 0 # 0= do not exit, 1= exit on unhandled errors only, 2= exit on unhandled errors and handled errors +attempt_recover 1 ## 1= will attempt to finalise if an execute fails +remote_port 24002 +IO_Threads 1 ## Number of threads for network traffic (~ 1/Gbps) + +###### Logging ##### +log_mode Interactive # Interactive=cout , Remote= remote logging system "serservice_name Remote_Logging" , Local = local file log; +log_local_path ./log +log_service LogStore + + +###### Service discovery ##### Ignore these settings for local analysis +service_publish_sec -1 +service_kick_sec -1 + +##### Tools To Add ##### +Tools_File ./configfiles/ReadConfigInfo/ToolsConfig ## list of tools to run and their config files + +##### Run Type ##### +Inline -1 ## number of Execute steps in program, -1 infinite loop that is ended by user +Interactive 0 ## set to 1 if you want to run the code interactively + diff --git a/configfiles/ReadConfigInfo/ToolsConfig b/configfiles/ReadConfigInfo/ToolsConfig new file mode 100644 index 000000000..bff55a409 --- /dev/null +++ b/configfiles/ReadConfigInfo/ToolsConfig @@ -0,0 +1,2 @@ +myLoadANNIEEvent LoadANNIEEvent ./configfiles/ReadConfigInfo/LoadANNIEEventConfig +myReadConfigInfo ReadConfigInfo ./configfiles/ReadConfigInfo/ReadConfigInfoConfig diff --git a/configfiles/ReadConfigInfo/my_inputs.txt b/configfiles/ReadConfigInfo/my_inputs.txt new file mode 100644 index 000000000..d02d47b86 --- /dev/null +++ b/configfiles/ReadConfigInfo/my_inputs.txt @@ -0,0 +1 @@ +ProcessedRawData_TankAndMRDAndCTC_R4314S0p0 From 31c442b59b29dbefaf96d84c1cccc9a30794c8b2 Mon Sep 17 00:00:00 2001 From: Steven Doran <78985334+S81D@users.noreply.github.com> Date: Tue, 26 Sep 2023 06:03:13 -0500 Subject: [PATCH 10/31] Added Neutral Current flag for GENIE events to PhaseIITreeMaker tool (#250) * Added whether an event is NC to PhaseIITreeMaker --- UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp | 8 ++++++-- UserTools/PhaseIITreeMaker/PhaseIITreeMaker.h | 1 + 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp b/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp index 348025216..8022719e9 100644 --- a/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp +++ b/UserTools/PhaseIITreeMaker/PhaseIITreeMaker.cpp @@ -324,6 +324,7 @@ bool PhaseIITreeMaker::Initialise(std::string configfile, DataModel &data){ fPhaseIITrigTree->Branch("trueFSLEnergy",&fTrueFSLEnergy,"trueFSLEnergy/D"); fPhaseIITrigTree->Branch("trueQ2",&fTrueQ2,"trueQ2/D"); fPhaseIITrigTree->Branch("trueCC",&fTrueCC,"trueCC/I"); + fPhaseIITrigTree->Branch("trueNC",&fTrueNC,"trueNC/I"); fPhaseIITrigTree->Branch("trueQEL",&fTrueQEL,"trueQEL/I"); fPhaseIITrigTree->Branch("trueRES",&fTrueRES,"trueRES/I"); fPhaseIITrigTree->Branch("trueDIS",&fTrueDIS,"trueDIS/I"); @@ -899,6 +900,7 @@ void PhaseIITreeMaker::ResetVariables() { fTrueFSLEnergy = -9999; fTrueQ2 = -9999; fTrueCC = -9999; + fTrueNC = -9999; fTrueQEL = -9999; fTrueRES = -9999; fTrueDIS = -9999; @@ -1669,7 +1671,7 @@ bool PhaseIITreeMaker::FillMCTruthInfo() { if (hasGenie){ double TrueNeutrinoEnergy, TrueQ2, TrueNuIntxVtx_X, TrueNuIntxVtx_Y, TrueNuIntxVtx_Z, TrueNuIntxVtx_T; double TrueFSLeptonMass, TrueFSLeptonEnergy, TrueFSLeptonTime; - bool TrueCC, TrueQEL, TrueDIS, TrueCOH, TrueMEC, TrueRES; + bool TrueCC, TrueNC, TrueQEL, TrueDIS, TrueCOH, TrueMEC, TrueRES; int fsNeutrons, fsProtons, fsPi0, fsPiPlus, fsPiPlusCher, fsPiMinus, fsPiMinusCher; int fsKPlus, fsKPlusCher, fsKMinus, fsKMinusCher, TrueNuPDG, TrueFSLeptonPdg; Position TrueFSLeptonVtx; @@ -1683,6 +1685,7 @@ bool PhaseIITreeMaker::FillMCTruthInfo() { bool get_neutrino_vtxt = m_data->Stores["GenieInfo"]->Get("NuIntxVtx_T",TrueNuIntxVtx_T); bool get_q2 = m_data->Stores["GenieInfo"]->Get("EventQ2",TrueQ2); bool get_cc = m_data->Stores["GenieInfo"]->Get("IsWeakCC",TrueCC); + bool get_nc = m_data->Stores["GenieInfo"]->Get("IsWeakNC",TrueNC); bool get_qel = m_data->Stores["GenieInfo"]->Get("IsQuasiElastic",TrueQEL); bool get_res = m_data->Stores["GenieInfo"]->Get("IsResonant",TrueRES); bool get_dis = m_data->Stores["GenieInfo"]->Get("IsDeepInelastic",TrueDIS); @@ -1709,7 +1712,7 @@ bool PhaseIITreeMaker::FillMCTruthInfo() { std::cout <<"get_q2: "< Date: Tue, 26 Sep 2023 16:54:27 +0300 Subject: [PATCH 11/31] Fixes to wcsimrootgeom (#251) change line 985 from `wcsimrootgeom->GetWCCylLength() / 100` to `wcsimrootgeom->GetWCCylLength() / 200` as this is height not half-height. Add comments to be more specific about the dimensions specified. --- UserTools/LoadWCSim/LoadWCSim.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/UserTools/LoadWCSim/LoadWCSim.cpp b/UserTools/LoadWCSim/LoadWCSim.cpp index 23b56abff..8935e3b47 100644 --- a/UserTools/LoadWCSim/LoadWCSim.cpp +++ b/UserTools/LoadWCSim/LoadWCSim.cpp @@ -978,8 +978,8 @@ Geometry* LoadWCSim::ConstructToolChainGeometry(){ double tank_ycentre = (wcsimrootgeom->GetWCOffset(1)) / 100.; double tank_zcentre = (wcsimrootgeom->GetWCOffset(2)) / 100.; Position tank_centre(tank_xcentre, tank_ycentre, tank_zcentre); - double tank_radius = (wcsimrootgeom->GetWCCylRadius()) / 100.; - double tank_halfheight = (wcsimrootgeom->GetWCCylLength()) / 100.; + double tank_radius = (wcsimrootgeom->GetWCCylRadius()) / 100.; //GetWCCylRadius() returns the black sheet radius not the tank radius + double tank_halfheight = (wcsimrootgeom->GetWCCylLength()) / 200.; //GetWCCylLength() returns the main annulus height not the tank height //Currently hard-coded; estimated with a tape measure on the ANNIE frame :) double pmt_enclosed_radius = 1.0; double pmt_enclosed_halfheight = 1.45; From 6d5927be25db6a8e4952186d58186b645c23abde Mon Sep 17 00:00:00 2001 From: Michael Nieslony <41126346+mnieslony@users.noreply.github.com> Date: Wed, 27 Sep 2023 16:46:04 +0200 Subject: [PATCH 12/31] MRD paddle efficiency TGraph Update (#247) * last MRD/FMV efficiency changes that were not pushed yet * removed unnecessary comments which cluttered the code * removed unused configuration options * modified mrd eff config files * revert ClusterFinder changes * Update TimeClustering.cpp * add comment on time shifts * Update LoadANNIEEvent.cpp * remove duplicate line * Move temp_exp/obs_layer inside of if-condition --- UserTools/FMVEfficiency/FMVEfficiency.cpp | 119 +++++--- UserTools/FindMrdTracks/FindMrdTracks.cpp | 15 +- UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp | 16 +- .../MrdPaddleEfficiencyCalc.cpp | 92 ++++--- .../MrdPaddleEfficiencyCalc.h | 6 +- .../MrdPaddleEfficiencyPreparer.cpp | 72 ++++- .../MrdPaddleEfficiencyPreparer.h | 8 + UserTools/TimeClustering/TimeClustering.cpp | 3 + configfiles/FMVEfficiency/ClusterFinderConfig | 2 +- configfiles/FMVEfficiency/FMVEfficiencyConfig | 3 +- configfiles/FMVEfficiency/FindMrdTracksConfig | 2 +- .../FMVEfficiency/LoadANNIEEventConfig | 2 +- .../FMVEfficiency/TimeClusteringConfig | 5 +- configfiles/FMVEfficiency/ToolsConfig | 2 - .../FMVEfficiency/calculate_fmv_efficiency.C | 191 ++++--------- configfiles/FMVEfficiency/my_inputs.txt | 2 +- .../Data/FindMrdTracksConfig | 6 +- .../Data/LoadANNIEEventConfig | 3 +- .../Data/MrdPaddleEfficiencyPreparerConfig | 2 +- .../Data/MrdPaddlePlotConfig | 2 +- .../Data/TimeClusteringConfig | 5 +- .../MrdPaddleEfficiency/Data/ToolsConfig | 2 +- .../MrdPaddleEfficiency/Data/my_inputs.txt | 2 +- .../MRDCorrectionFactors.dat | 254 ++++++++++++++++++ .../MrdPaddleEfficiencyCalcConfig | 5 +- 25 files changed, 582 insertions(+), 239 deletions(-) create mode 100644 configfiles/MrdPaddleEfficiencyCalc/MRDCorrectionFactors.dat diff --git a/UserTools/FMVEfficiency/FMVEfficiency.cpp b/UserTools/FMVEfficiency/FMVEfficiency.cpp index 5a35a682b..c3b488751 100644 --- a/UserTools/FMVEfficiency/FMVEfficiency.cpp +++ b/UserTools/FMVEfficiency/FMVEfficiency.cpp @@ -217,8 +217,14 @@ bool FMVEfficiency::Execute(){ if (not get_ok) { Log("EventDisplay Tool: Error retrieving MrdDigitChankeys, did you run TimeClustering beforehand",v_error,verbosity); return false;} } - if (isData) m_data->Stores["ANNIEEvent"]->Get("TDCData",TDCData); - else m_data->Stores["ANNIEEvent"]->Get("TDCData",TDCData_MC); + bool get_tdc; + if (isData) get_tdc = m_data->Stores["ANNIEEvent"]->Get("TDCData",TDCData); + else get_tdc = m_data->Stores["ANNIEEvent"]->Get("TDCData",TDCData_MC); + + if (!get_tdc){ + if (verbosity > 0) std::cout <<"FMVEfficiency tool: No TDCData available! Abort"< hit_fmv_detkeys_first, hit_fmv_detkeys_second; - std::vector vector_fmv_times_first, vector_fmv_times_second; + std::vector> vector_fmv_times_first, vector_fmv_times_second; if (isData){ if(TDCData){ @@ -315,27 +321,33 @@ bool FMVEfficiency::Execute(){ hit_fmv_detkeys_first.push_back(detkey); double fmv_time=0; int nhits_fmv=0; + std::vector single_fmv_times; for(auto&& hitsonthismrdpmt : anmrdpmt.second){ fmv_time+=hitsonthismrdpmt.GetTime(); nhits_fmv++; + single_fmv_times.push_back(hitsonthismrdpmt.GetTime()); } if (nhits_fmv!=0) fmv_time/=nhits_fmv; - vector_fmv_times_first.push_back(fmv_time); + vector_fmv_times_first.push_back(single_fmv_times); } else { - /*if (detkey == 14 || detkey == 18 || detkey == 19) continue; + //The following code with channelkey changes was necessary during a period where channels were re-mapped + /*if (detkey == 14 || detkey == 18 || detkey == 19) continue; if (detkey == 23) detkey = 14; else if (detkey == 24) detkey = 18; else if (detkey == 25) detkey = 19;*/ + hit_fmv_detkeys_second.push_back(detkey); + std::vector single_fmv_times; double fmv_time = 0; int nhits_fmv = 0; for(auto&&hitsonthismrdpmt : anmrdpmt.second){ fmv_time+=hitsonthismrdpmt.GetTime(); nhits_fmv++; + single_fmv_times.push_back(hitsonthismrdpmt.GetTime()); } if (nhits_fmv!=0) fmv_time/=nhits_fmv; - vector_fmv_times_second.push_back(fmv_time); + vector_fmv_times_second.push_back(single_fmv_times); } } } @@ -359,23 +371,27 @@ bool FMVEfficiency::Execute(){ hit_fmv_detkeys_first.push_back(detkey); double fmv_time=0; int nhits_fmv=0; + std::vector single_fmv_times; for(auto&& hitsonthismrdpmt : anmrdpmt.second){ fmv_time+=hitsonthismrdpmt.GetTime(); nhits_fmv++; + single_fmv_times.push_back(hitsonthismrdpmt.GetTime()); } if (nhits_fmv!=0) fmv_time/=nhits_fmv; - vector_fmv_times_first.push_back(fmv_time); + vector_fmv_times_first.push_back(single_fmv_times); } else { hit_fmv_detkeys_second.push_back(detkey); double fmv_time = 0; int nhits_fmv = 0; + std::vector single_fmv_times; for(auto&&hitsonthismrdpmt : anmrdpmt.second){ fmv_time+=hitsonthismrdpmt.GetTime(); nhits_fmv++; + single_fmv_times.push_back(hitsonthismrdpmt.GetTime()); } if (nhits_fmv!=0) fmv_time/=nhits_fmv; - vector_fmv_times_second.push_back(fmv_time); + vector_fmv_times_second.push_back(single_fmv_times); } } } @@ -402,11 +418,12 @@ bool FMVEfficiency::Execute(){ if (pmt_cluster){ if (npaddles_Layer1 == 1){ for (unsigned int i_fmv = 0; i_fmv < hit_fmv_detkeys_first.size(); i_fmv++){ - time_diff_tank_Layer1->Fill(vector_fmv_times_first.at(i_fmv)-cluster_time); + for (int i_t = 0; i_t < vector_fmv_times_first.size(); i_t++){ + time_diff_tank_Layer1->Fill(vector_fmv_times_first.at(i_fmv).at(i_t)-cluster_time); if (isData){ - if ((vector_fmv_times_first.at(i_fmv)-cluster_time)<740 || (vector_fmv_times_first.at(i_fmv)-cluster_time)>840) continue; + if ((vector_fmv_times_first.at(i_fmv).at(i_t)-cluster_time)<740 || (vector_fmv_times_first.at(i_fmv).at(i_t)-cluster_time)>840) continue; } else { - if ((vector_fmv_times_first.at(i_fmv)-cluster_time)<-100 || (vector_fmv_times_first.at(i_fmv)-cluster_time)>100) continue; + if ((vector_fmv_times_first.at(i_fmv).at(i_t)-cluster_time)<-100 || (vector_fmv_times_first.at(i_fmv).at(i_t)-cluster_time)>100) continue; } unsigned long detkey_first = hit_fmv_detkeys_first.at(i_fmv); fmv_tank_secondlayer_expected.at(detkey_first)++; @@ -414,15 +431,17 @@ bool FMVEfficiency::Execute(){ fmv_tank_secondlayer_observed.at(detkey_first)++; } } + } } if (npaddles_Layer2 == 1){ for (unsigned int i_fmv = 0; i_fmv < hit_fmv_detkeys_second.size(); i_fmv++){ - time_diff_tank_Layer2->Fill(vector_fmv_times_second.at(i_fmv)-cluster_time); + for (int i_t=0; i_t < vector_fmv_times_second.at(i_fmv).size(); i_t++){ + time_diff_tank_Layer2->Fill(vector_fmv_times_second.at(i_fmv).at(i_t)-cluster_time); if (isData){ - if ((vector_fmv_times_second.at(i_fmv)-cluster_time)<740 || (vector_fmv_times_second.at(i_fmv)-cluster_time)>840) continue; + if ((vector_fmv_times_second.at(i_fmv).at(i_t)-cluster_time)<740 || (vector_fmv_times_second.at(i_fmv).at(i_t)-cluster_time)>840) continue; } else { - if ((vector_fmv_times_second.at(i_fmv)-cluster_time)<-100 || (vector_fmv_times_second.at(i_fmv)-cluster_time)>100) continue; + if ((vector_fmv_times_second.at(i_fmv).at(i_t)-cluster_time)<-100 || (vector_fmv_times_second.at(i_fmv).at(i_t)-cluster_time)>100) continue; } unsigned long detkey_second = hit_fmv_detkeys_second.at(i_fmv); unsigned long detkey_first = detkey_second - n_veto_pmts/2; @@ -431,6 +450,7 @@ bool FMVEfficiency::Execute(){ fmv_tank_firstlayer_observed.at(detkey_first)++; } } + } } } } @@ -438,14 +458,31 @@ bool FMVEfficiency::Execute(){ // -------------------------------- //----Evaluate MRD coincidences----- // -------------------------------- - - //Only use events with one track in the MRD - if (MrdTimeClusters.size()!=1) return true; + //Change: Actually select on one fitted track instead of one subevent (cluster) + + //Get fitted MRD track + int numsubevs, numtracksinev; + m_data->Stores["MRDTracks"]->Get("NumMrdSubEvents",numsubevs); + m_data->Stores["MRDTracks"]->Get("NumMrdTracks",numtracksinev); + m_data->Stores["MRDTracks"]->Get("MRDTracks",theMrdTracks); + if (numsubevs==0) { + if (verbosity > 2) std::cout <<"No subevents! Abort execution of tool"< 2) std::cout <<"Event does not have 1 track. Abort FMVEfficiency tool (Event has "< trackssubev; + m_data->CStore.Get("TracksSubEvs",trackssubev); + + if (verbosity > 2) std::cout <<"trackssubev.size(): "< single_mrdcluster = MrdTimeClusters.at(thiscluster); int numdigits = single_mrdcluster.size(); if (numdigits >=50) return true; //reject noise events @@ -463,11 +500,6 @@ bool FMVEfficiency::Execute(){ } if (n_pmts!=0) mrd_time/=n_pmts; - //Get fitted MRD track - int numsubevs, numtracksinev; - m_data->Stores["MRDTracks"]->Get("NumMrdSubEvents",numsubevs); - m_data->Stores["MRDTracks"]->Get("NumMrdTracks",numtracksinev); - m_data->Stores["MRDTracks"]->Get("MRDTracks",theMrdTracks); BoostStore* thisTrackAsBoostStore = &(theMrdTracks->at(0)); std::vector PMTsHit; @@ -502,15 +534,20 @@ bool FMVEfficiency::Execute(){ //if (npaddles_Layer1 == 1){ if (npaddles_Layer1 >= 1 && npaddles_Layer1 <= padPerLayer){ for (unsigned int i_fmv = 0; i_fmv < hit_fmv_detkeys_first.size(); i_fmv++){ - - time_diff_paddle->Fill(hit_fmv_detkeys_first.at(i_fmv),vector_fmv_times_first.at(i_fmv)-mrd_time); + bool found_coinc = false; + for (int i_t = 0; i_t < vector_fmv_times_first.at(i_fmv).size(); i_t++){ + if (found_coinc) continue; + time_diff_paddle->Fill(hit_fmv_detkeys_first.at(i_fmv),vector_fmv_times_first.at(i_fmv).at(i_t)-mrd_time-100); //Check whether MRD & FMV Layer 1 fired in coincidence (time cut) + if (verbosity > 3) std::cout <<"FMV time: "<Fill(hit_fmv_detkeys_first.at(i_fmv)); - time_diff_Layer1->Fill(vector_fmv_times_first.at(i_fmv)-mrd_time); - if (fabs(vector_fmv_times_first.at(i_fmv)-mrd_time)>100.) continue; + time_diff_Layer1->Fill(vector_fmv_times_first.at(i_fmv).at(i_t)-mrd_time); + if (fabs(vector_fmv_times_first.at(i_fmv).at(i_t)-mrd_time-100)>70.) continue; + found_coinc = true; //Get properties of coincident MRD/FMV Layer 1 hit unsigned long detkey_first = hit_fmv_detkeys_first.at(i_fmv); + if (verbosity > 3) std::cout <<"detkey: "<Fill(x_layer1-fmv_x); track_diff_y_Layer1->Fill(y_layer1-fmv_firstlayer_y.at(detkey_first)); track_diff_xy_Layer1->Fill(x_layer1-fmv_x,y_layer1-fmv_firstlayer_y.at(detkey_first)); @@ -540,31 +577,40 @@ bool FMVEfficiency::Execute(){ vector_observed_loose_layer2.at(detkey_first)->Fill(x_layer1); std::vector::iterator it = std::find(hit_fmv_detkeys_second.begin(),hit_fmv_detkeys_second.end(),detkey_first+n_veto_pmts/2); int index = std::distance(hit_fmv_detkeys_second.begin(),it); - time_diff_paddle_coinc->Fill(detkey_first+n_veto_pmts/2,vector_fmv_times_second.at(index)-vector_fmv_times_first.at(i_fmv)); + for (int i_t2=0; i_t2 < vector_fmv_times_second.at(index).size(); i_t2++){ + time_diff_paddle_coinc->Fill(detkey_first+n_veto_pmts/2,vector_fmv_times_second.at(index).at(i_t2)-vector_fmv_times_first.at(i_fmv).at(i_t)); + } } fmv_secondlayer_observed.at(detkey_first)++; std::vector::iterator it = std::find(hit_fmv_detkeys_second.begin(),hit_fmv_detkeys_second.end(),detkey_first+n_veto_pmts/2); int index = std::distance(hit_fmv_detkeys_second.begin(),it); - time_diff_paddle_simplecoinc->Fill(detkey_first+n_veto_pmts/2,vector_fmv_times_second.at(index)-vector_fmv_times_first.at(i_fmv)); + for (int i_t2=0; i_t2 < vector_fmv_times_second.at(index).size(); i_t2++){ + time_diff_paddle_simplecoinc->Fill(detkey_first+n_veto_pmts/2,vector_fmv_times_second.at(index).at(i_t2)-vector_fmv_times_first.at(i_fmv).at(i_t)); + } if (hit_chankey_layer1 == detkey_first){ vector_observed_strict_layer2.at(detkey_first)->Fill(x_layer1); fmv_secondlayer_observed_track_strict.at(detkey_first)++; } } + } } } //if (npaddles_Layer2 == 1){ if (npaddles_Layer2 >= 1 && npaddles_Layer2 <=padPerLayer){ for (unsigned int i_fmv = 0; i_fmv < hit_fmv_detkeys_second.size(); i_fmv++){ - - time_diff_paddle->Fill(hit_fmv_detkeys_second.at(i_fmv),vector_fmv_times_second.at(i_fmv)-mrd_time-20); + bool found_coinc = false; + for (int i_t=0; i_t < vector_fmv_times_second.at(i_fmv).size(); i_t++){ + if (found_coinc) continue; + time_diff_paddle->Fill(hit_fmv_detkeys_second.at(i_fmv),vector_fmv_times_second.at(i_fmv).at(i_t)-mrd_time-100); //Check whether MRD & FMV Layer 2 fired in coincidence (time cut) - time_diff_Layer2->Fill(vector_fmv_times_second.at(i_fmv)-mrd_time); + time_diff_Layer2->Fill(vector_fmv_times_second.at(i_fmv).at(i_t)-mrd_time); fmv_layer2->Fill(hit_fmv_detkeys_second.at(i_fmv)); - if (fabs(vector_fmv_times_second.at(i_fmv)-mrd_time-20.)>100.) continue; + if (fabs(vector_fmv_times_second.at(i_fmv).at(i_t)-mrd_time-100.)>70.) continue; + found_coinc = true; + //Get properties of coincident MRD/FMV Layer 2 hit unsigned long detkey_second = hit_fmv_detkeys_second.at(i_fmv); unsigned long detkey_first = detkey_second - n_veto_pmts/2; @@ -594,11 +640,15 @@ bool FMVEfficiency::Execute(){ vector_observed_loose_layer1.at(detkey_first)->Fill(x_layer2); std::vector::iterator it = std::find(hit_fmv_detkeys_first.begin(),hit_fmv_detkeys_first.end(),detkey_first); int index = std::distance(hit_fmv_detkeys_first.begin(),it); - time_diff_paddle_coinc->Fill(detkey_first,vector_fmv_times_first.at(index)-vector_fmv_times_second.at(i_fmv)); + for (int i_t2=0; i_t2 < vector_fmv_times_first.at(index).size(); i_t2++){ + time_diff_paddle_coinc->Fill(detkey_first,vector_fmv_times_first.at(index).at(i_t2)-vector_fmv_times_second.at(i_fmv).at(i_t)); + } } std::vector::iterator it = std::find(hit_fmv_detkeys_first.begin(),hit_fmv_detkeys_first.end(),detkey_first); int index = std::distance(hit_fmv_detkeys_first.begin(),it); - time_diff_paddle_simplecoinc->Fill(detkey_first,vector_fmv_times_first.at(index)-vector_fmv_times_second.at(i_fmv)); + for (int i_t2 = 0; i_t2 < vector_fmv_times_first.at(index).size(); i_t2++){ + time_diff_paddle_simplecoinc->Fill(detkey_first,vector_fmv_times_first.at(index).at(i_t2)-vector_fmv_times_second.at(i_fmv).at(i_t)); + } for (int i_first=0; i_first < (int) hit_fmv_detkeys_first.size(); i_first++){ fmv_layer1_layer2->Fill(hit_fmv_detkeys_first.at(i_first),detkey_second); } @@ -608,6 +658,7 @@ bool FMVEfficiency::Execute(){ fmv_firstlayer_observed_track_strict.at(detkey_first)++; } } + } } } diff --git a/UserTools/FindMrdTracks/FindMrdTracks.cpp b/UserTools/FindMrdTracks/FindMrdTracks.cpp index 0c5922926..bf344cafe 100755 --- a/UserTools/FindMrdTracks/FindMrdTracks.cpp +++ b/UserTools/FindMrdTracks/FindMrdTracks.cpp @@ -94,9 +94,18 @@ bool FindMrdTracks::Execute(){ m_data->Stores["ANNIEEvent"]->Get("TriggerNumber",MCTriggernum); m_data->Stores["ANNIEEvent"]->Get("MCEventNum",MCEventNum); if (!isData) m_data->Stores["ANNIEEvent"]->Get("MCParticles",MCParticles); - get_ok = m_data->Stores.at("ANNIEEvent")->Get("MRDTriggerType",MRDTriggertype); - if (not get_ok){ - Log("FindMrdTracks: Did not find MRDTriggerType in ANNIEEvent. Please check the settings in MRDDataDecoder+BuildANNIEEvent/LoadWCSim?",v_error,verbosity); + uint32_t TriggerWord; + get_ok = m_data->Stores["ANNIEEvent"]->Get("TriggerWord",TriggerWord); + if (get_ok){ + if (TriggerWord == 5) MRDTriggertype = "Beam"; + else if (TriggerWord == 36) MRDTriggertype = "Cosmic"; + } else { + Log("FindMrdTracks tool: Triggerword not available! Extract MRD trigger type from loopback",v_warning,verbosity); + get_ok = m_data->Stores.at("ANNIEEvent")->Get("MRDTriggerType",MRDTriggertype); + if (not get_ok){ + Log("FindMrdTracks: Did not find MRDTriggerType in ANNIEEvent. Please check the settings in MRDDataDecoder+BuildANNIEEvent/LoadWCSim?",v_error,verbosity); + m_data->vars.Set("StopLoop",1); + } } Log("FindMrdTracks tool: MRDTriggertype is "+MRDTriggertype+" (from ANNIEEvent store)",v_debug,verbosity); diff --git a/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp b/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp index c0185d63d..eca215941 100644 --- a/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp +++ b/UserTools/LoadANNIEEvent/LoadANNIEEvent.cpp @@ -130,7 +130,13 @@ bool LoadANNIEEvent::Execute() { // Load the contents from the new input file into it std::string input_filename = input_filenames_.at(current_file_); std::cout <<"Reading in current file "<Initialise(input_filename); + bool filename_valid = false; + filename_valid = ProcessedFileStore->Initialise(input_filename); + if (!filename_valid){ + Log("LoadANNIEEvent: Filename "+input_filename+" not found! Proceed to next file",v_error,verbosity_); + current_file_++; + return true; + } m_data->Stores["ProcessedFileStore"]=ProcessedFileStore; // create an ANNIEEvent BoostStore and an OrphanStore BoostStore to load from it @@ -168,7 +174,13 @@ bool LoadANNIEEvent::Execute() { BoostStore *theANNIEEvent = new BoostStore(false, BOOST_STORE_MULTIEVENT_FORMAT); std::string input_filename = input_filenames_.at(current_file_); - theANNIEEvent->Initialise(input_filename); + bool filename_valid = false; + filename_valid = theANNIEEvent->Initialise(input_filename); + if (!filename_valid){ + Log("LoadANNIEEvent: Filename "+input_filename+" not found! Proceed to next file",v_error,verbosity_); + current_file_++; + return true; + } m_data->Stores["ANNIEEvent"] = theANNIEEvent; m_data->Stores.at("ANNIEEvent")->Header->Get("TotalEntries",total_entries_in_file_); if (current_file_==0) { diff --git a/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.cpp b/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.cpp index acae70ca3..37a1bc2e2 100644 --- a/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.cpp +++ b/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.cpp @@ -17,6 +17,7 @@ bool MrdPaddleEfficiencyCalc::Initialise(std::string configfile, DataModel &data str_inactive = "./configfiles/MrdPaddleEfficiencyCalc/inactive_channels.dat"; mc_chankey_path = "./configfiles/MrdPaddleEfficiencyCalc/MRD_Chankeys_Data_MC.dat"; layer_plots = false; + correction_file = "./configfiles/MrdPaddleEfficiencyCalc/MRDCorrectionFactors.dat"; m_variables.Get("verbosity",verbosity); m_variables.Get("InputFile",str_input); @@ -25,6 +26,7 @@ bool MrdPaddleEfficiencyCalc::Initialise(std::string configfile, DataModel &data m_variables.Get("IsData",isData); m_variables.Get("MCChankeyFile",mc_chankey_path); m_variables.Get("LayerPlots",layer_plots); + m_variables.Get("CorrectionFile",correction_file); int chankey_mc, chankey_data, wcsimid; @@ -45,7 +47,8 @@ bool MrdPaddleEfficiencyCalc::Initialise(std::string configfile, DataModel &data outputfile = new TFile(str_output.c_str(),"RECREATE"); //Define histograms & canvases - eff_chankey = new TH1D("eff_chankey","Efficiency vs. channelkey",310,26,336); + eff_chankey = new TEfficiency("eff_chankey","Efficiency vs. channelkey; chankey;efficiency #varepsilon",310,26,336); + eff_chankey_corrected = new TEfficiency("eff_chankey_corrected","Efficiency vs. channelkey; chankey;efficiency #varepsilon",310,26,336); eff_top = new TH2Poly("eff_top","Efficiency - Top View",1.6,3.,-2,2.); eff_side = new TH2Poly("eff_side","Efficiency - Side View",1.6,3.,-2.,2.); eff_top_side = new TH2Poly("eff_top_side","Efficiency - Side/Top View",1.6,3.,-2.,2.); @@ -55,22 +58,19 @@ bool MrdPaddleEfficiencyCalc::Initialise(std::string configfile, DataModel &data gROOT->cd(); //Label axes of histograms - eff_chankey->GetXaxis()->SetTitle("chankey"); - eff_chankey->GetYaxis()->SetTitle("efficiency #epsilon"); - eff_chankey->SetStats(0); eff_top->GetXaxis()->SetTitle("z [m]"); eff_top->GetYaxis()->SetTitle("x [m]"); eff_side->GetXaxis()->SetTitle("z [m]"); eff_side->GetYaxis()->SetTitle("y [m]"); - eff_top->GetZaxis()->SetTitle("#epsilon"); - eff_side->GetZaxis()->SetTitle("#epsilon"); + eff_top->GetZaxis()->SetTitle("#varepsilon"); + eff_side->GetZaxis()->SetTitle("#varepsilon"); eff_top->SetStats(0); eff_side->SetStats(0); eff_top->GetZaxis()->SetRangeUser(0.000,1); eff_side->GetZaxis()->SetRangeUser(0.000,1); eff_top_side->GetXaxis()->SetTitle("z [m]"); eff_top_side->GetYaxis()->SetTitle("x/y [m]"); - eff_top_side->GetZaxis()->SetTitle("#epsilon"); + eff_top_side->GetZaxis()->SetTitle("#varepsilon"); eff_top_side->SetStats(0); eff_top_side->GetZaxis()->SetRangeUser(0.000,1); eff_crate1->SetStats(0); @@ -201,6 +201,16 @@ bool MrdPaddleEfficiencyCalc::Initialise(std::string configfile, DataModel &data } inactive_file.close(); + unsigned long temp_chkey; + double temp_eff, temp_corr; + ifstream f_correction(correction_file.c_str()); + while (!f_correction.eof()){ + f_correction >> temp_chkey >> temp_eff >> temp_corr; + map_correction.emplace(temp_chkey,temp_corr); + if (f_correction.eof()) break; + } + f_correction.close(); + //Set up color palette Bird_Idx = TColor::CreateGradientColorTable(9, stops, red, green, blue, 255, alpha); std::cout <<"Bird_Idx: "<GetXaxis()->SetTitle("x [m]"); layer_hist2_layer->GetXaxis()->SetTitle("x [m]"); } - layer_hist1->GetYaxis()->SetTitle("Efficiency #epsilon"); - layer_hist2->GetYaxis()->SetTitle("Efficiency #epsilon"); - layer_hist1_layer->GetYaxis()->SetTitle("Efficiency #epsilon"); - layer_hist2_layer->GetYaxis()->SetTitle("Efficiency #epsilon"); + layer_hist1->GetYaxis()->SetTitle("Efficiency #varepsilon"); + layer_hist2->GetYaxis()->SetTitle("Efficiency #varepsilon"); + layer_hist1_layer->GetYaxis()->SetTitle("Efficiency #varepsilon"); + layer_hist2_layer->GetYaxis()->SetTitle("Efficiency #varepsilon"); layer_hist1->SetStats(0); layer_hist2->SetStats(0); layer_hist1_layer->SetStats(0); @@ -320,7 +330,7 @@ bool MrdPaddleEfficiencyCalc::Execute(){ //Get observed/expected histograms TH1D *temp_exp = (TH1D*) inputfile->Get(name_exp_hist.str().c_str()); TH1D *temp_obs = (TH1D*) inputfile->Get(name_obs_hist.str().c_str()); - TH1D *temp_exp_layer=nullptr, *temp_obs_layer=nullptr; + TH1D *temp_exp_layer, *temp_obs_layer; if (layer_plots){ temp_exp_layer = (TH1D*) inputfile->Get(name_exp_hist_layer.str().c_str()); temp_obs_layer = (TH1D*) inputfile->Get(name_obs_hist_layer.str().c_str()); @@ -335,7 +345,12 @@ bool MrdPaddleEfficiencyCalc::Execute(){ TH1D *efficiency_hist = (TH1D*) temp_obs->Clone(name_eff_hist.str().c_str()); efficiency_hist->SetStats(0); efficiency_hist->SetTitle(title_eff_hist.str().c_str()); - TH1D *efficiency_hist_layer; + + //Note that for efficiency_hist_layer, the colors might not be displayed correctly in newer versions of root + //See https://root-forum.cern.ch/t/error-using-tcolor/39149/10 for more details on how to fix it when drawing the canvas from the output file + + TH1D *efficiency_hist_layer, *efficiency_hist_layer_copy; + TEfficiency *temp_teff; if (layer_plots){ efficiency_hist_layer = (TH1D*) temp_obs_layer->Clone(name_eff_hist_layer.str().c_str()); efficiency_hist_layer->SetStats(0); @@ -344,19 +359,27 @@ bool MrdPaddleEfficiencyCalc::Execute(){ if (i_layer%2==0) efficiency_hist->GetXaxis()->SetTitle("y [m]"); else efficiency_hist->GetXaxis()->SetTitle("x [m]"); - efficiency_hist->GetYaxis()->SetTitle("efficiency #epsilon"); + efficiency_hist->GetYaxis()->SetTitle("efficiency #varepsilon"); efficiency_hist->Divide(temp_exp); if (layer_plots){ if (i_layer%2==0) efficiency_hist_layer->GetXaxis()->SetTitle("y [m]"); else efficiency_hist_layer->GetXaxis()->SetTitle("x [m]"); - efficiency_hist_layer->GetYaxis()->SetTitle("efficiency #epsilon"); + efficiency_hist_layer->GetYaxis()->SetTitle("efficiency #varepsilon"); efficiency_hist_layer->Divide(temp_exp_layer); + + temp_teff = new TEfficiency(*temp_obs_layer,*temp_exp_layer); + for (int i_bin=0; i_bin < temp_exp_layer->GetNbinsX(); i_bin++){ + double temp_error = temp_teff->GetEfficiencyErrorUp(i_bin+1); + if (temp_teff->GetEfficiency(i_bin+1) > 0.) efficiency_hist_layer->SetBinError(i_bin+1,temp_error); + else efficiency_hist_layer->SetBinError(i_bin+1,0); + } + + efficiency_hist_layer_copy = (TH1D*) efficiency_hist_layer->Clone(); + efficiency_hist_layer_copy->SetName(name_eff_hist_Layer.str().c_str()); + } + - TH1F *efficiency_hist_layer_copy = (TH1F*) efficiency_hist_layer->Clone(); - efficiency_hist_layer_copy->SetName(name_eff_hist_Layer.str().c_str()); - //if (i_ch < channels_per_layer[i_layer]/2) efficiency_hist_layer_copy->SetLineColor(Bird_palette[int(254*(i_ch/double(channels_per_layer[i_layer]/2)))]); - //else efficiency_hist_layer_copy->SetLineColor(Bird_palette[int(254*((i_ch-channels_per_layer[i_layer]/2)/double(channels_per_layer[i_layer]/2)))]); //Scale down from 10 bins to 1 temp_exp->Rebin(10); @@ -370,10 +393,15 @@ bool MrdPaddleEfficiencyCalc::Execute(){ double efficiency = efficiency_hist_avg->GetBinContent(1); double exp = temp_exp->GetBinContent(1); - double obs = temp_exp->GetBinContent(1); + double obs = temp_obs->GetBinContent(1); double err_eff = 1./exp * sqrt(obs + obs*obs/exp); - eff_chankey->SetBinContent(bins_start[i_layer]+i_ch,efficiency); - eff_chankey->SetBinError(bins_start[i_layer]+i_ch,err_eff); + eff_chankey->SetTotalEvents(bins_start[i_layer]+i_ch,int(exp)); + eff_chankey->SetPassedEvents(bins_start[i_layer]+i_ch,int(obs)); + eff_chankey_corrected->SetTotalEvents(bins_start[i_layer]+i_ch,int(exp)); + double obs_corrected = obs*map_correction[input_chankey]; + if (obs_corrected > exp) obs_corrected = exp; + eff_chankey_corrected->SetPassedEvents(bins_start[i_layer]+i_ch,int(obs_corrected)); + if (i_ch < channels_per_layer[i_layer]/2){ layer_hist1->SetBinContent(i_ch+1,efficiency); @@ -384,17 +412,19 @@ bool MrdPaddleEfficiencyCalc::Execute(){ } canvas_layer1->cd(); efficiency_hist_layer->SetLineColor(Bird_palette[int(254*(i_ch/double(channels_per_layer[i_layer]/2)))]); + efficiency_hist_layer->SetFillColorAlpha(Bird_palette[int(254*(i_ch/double(channels_per_layer[i_layer]/2)))],0.30); + if (i_ch == 0) { efficiency_hist_layer->SetTitle(title_canvas_hist1.str().c_str()); efficiency_hist_layer->GetYaxis()->SetRangeUser(0.000,1); - efficiency_hist_layer->Draw(); + efficiency_hist_layer->Draw("e2"); c_eff_layers->cd(j_layer); - efficiency_hist_layer->Draw(); + efficiency_hist_layer->Draw("e2"); } else { - efficiency_hist_layer->Draw("same"); + efficiency_hist_layer->Draw("e2same"); c_eff_layers->cd(j_layer); - efficiency_hist_layer->Draw("same"); + efficiency_hist_layer->Draw("e2same"); } } } else { @@ -406,17 +436,18 @@ bool MrdPaddleEfficiencyCalc::Execute(){ } canvas_layer2->cd(); efficiency_hist_layer->SetLineColor(Bird_palette[int(254*((i_ch-channels_per_layer[i_layer]/2)/double(channels_per_layer[i_layer]/2)))]); + efficiency_hist_layer->SetFillColor(Bird_palette[int(254*((i_ch-channels_per_layer[i_layer]/2)/double(channels_per_layer[i_layer]/2)))]); if (i_ch == channels_per_layer[i_layer]/2) { efficiency_hist_layer->SetTitle(title_canvas_hist2.str().c_str()); efficiency_hist_layer->GetYaxis()->SetRangeUser(0.000,1); - efficiency_hist_layer->Draw(); + efficiency_hist_layer->Draw("e2"); c_eff_layers->cd(j_layer+1); - efficiency_hist_layer->Draw(); + efficiency_hist_layer->Draw("e2"); } else { - efficiency_hist_layer->Draw("same"); + efficiency_hist_layer->Draw("e2same"); c_eff_layers->cd(j_layer+1); - efficiency_hist_layer->Draw("same"); + efficiency_hist_layer->Draw("e2same"); } } } @@ -461,6 +492,7 @@ bool MrdPaddleEfficiencyCalc::Execute(){ outputfile->cd(); eff_chankey->Write(); + eff_chankey_corrected->Write(); eff_top->Write(); eff_side->Write(); eff_top_side->Write(); diff --git a/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.h b/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.h index 2765e5bdc..17fbe829b 100644 --- a/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.h +++ b/UserTools/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalc.h @@ -8,6 +8,7 @@ #include "TH1D.h" #include "TH2D.h" #include "TH2Poly.h" +#include "TEfficiency.h" #include "TCanvas.h" #include "TBox.h" #include "TROOT.h" @@ -48,13 +49,15 @@ class MrdPaddleEfficiencyCalc: public Tool { std::string mc_chankey_path; std::map chankeymap_MC_data; std::map chankeymap_data_MC; + std::string correction_file; //TFile variables TFile *inputfile = nullptr; TFile *outputfile = nullptr; //Histograms + canvas - TH1D *eff_chankey = nullptr; + TEfficiency *eff_chankey = nullptr; + TEfficiency *eff_chankey_corrected = nullptr; TH2Poly *eff_top = nullptr; TH2Poly *eff_side = nullptr; TH2Poly *eff_top_side = nullptr; @@ -72,6 +75,7 @@ class MrdPaddleEfficiencyCalc: public Tool { int active_channel[2][24]={{0}}; std::map> MRDChannelNumToCrateSpaceMap; Geometry *geom = nullptr; + std::map map_correction; //Layer-by-layer information int channels_per_layer[11] = {26,30,26,34,26,26,26,30,26,30,26}; diff --git a/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.cpp b/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.cpp index 810f05c6a..1b2a81678 100644 --- a/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.cpp +++ b/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.cpp @@ -149,12 +149,17 @@ bool MrdPaddleEfficiencyPreparer::Initialise(std::string configfile, DataModel & } hist_chankey = new TH1F("hist_chankey","MRD Chankeys - Efficiency",340,0,340); + hist_nlayers = new TH1F("hist_nlayers","Number of hit MRD layers",11,0,11); + MissingChannel = new std::vector; + ExpectedChannel = new std::vector; + MissingLayer = new std::vector; //hist_timediff = new TH1F("hist_timediff","Timediff first & last layer",2000,-2000,2000); tree_trackfit = new TTree("tree_trackfit","tree_trackfit"); - tree_trackfit->Branch("EvNum",&EventNumber); - tree_trackfit->Branch("MRDTriggerType",&MRDTriggertype); + tree_trackfit->Branch("RunNum",&RunNumber); + tree_trackfit->Branch("EvNum",&EventNumber); + tree_trackfit->Branch("MRDTriggerType",&MRDTriggertype); tree_trackfit->Branch("NumMrdTracks",&numtracksinev); - tree_trackfit->Branch("MrdTrackID",&MrdTrackID); + tree_trackfit->Branch("MrdTrackID",&MrdTrackID); tree_trackfit->Branch("NPMTsHit",&NPMTsHit); tree_trackfit->Branch("NLayersHit",&NLayersHit); tree_trackfit->Branch("StartVertexX",&StartVertexX); @@ -163,11 +168,17 @@ bool MrdPaddleEfficiencyPreparer::Initialise(std::string configfile, DataModel & tree_trackfit->Branch("StopVertexX",&StopVertexX); tree_trackfit->Branch("StopVertexY",&StopVertexY); tree_trackfit->Branch("StopVertexZ",&StopVertexZ); + tree_trackfit->Branch("IsThrough",&IsThrough); + tree_trackfit->Branch("MissingChannel",&MissingChannel); + tree_trackfit->Branch("ExpectedChannel",&ExpectedChannel); + tree_trackfit->Branch("NumMissingChannel",&NumMissingChannel); + tree_trackfit->Branch("MissingLayer",&MissingLayer); + tree_trackfit->Branch("NumMissingLayer",&NumMissingLayer); m_data->CStore.Get("channelkey_to_mrdpmtid",channelkey_to_mrdpmtid); m_data->CStore.Get("mrd_tubeid_to_channelkey",mrdpmtid_to_channelkey); - numtracksinev = 0; + numtracksinev = 0; return true; @@ -177,12 +188,13 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ // Get all relevant data from ANNIEEvent BoostStore + m_data->Stores["ANNIEEvent"]->Get("RunNumber",RunNumber); m_data->Stores["ANNIEEvent"]->Get("EventNumber",EventNumber); m_data->Stores["ANNIEEvent"]->Get("MRDTriggerType",MRDTriggertype); // In case of a cosmic event, use the fitted track for an efficiency calculation - if (MRDTriggertype == "Cosmic"){ + if (true){ //previously condition for cosmic event, now removed to also investigate beam events // Get MRD track information from MRDTracks BoostStore @@ -193,7 +205,22 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ // Only look at events with a single track (cut may be relaxed in the future) -// if (numtracksinev >= 1) { + MrdTrackID=-1; + NPMTsHit=-1; + NLayersHit=-1; + StartVertexX=-999; + StartVertexY=-999; + StartVertexZ=-999; + StopVertexX=-999; + StopVertexY=-999; + StopVertexZ=-999; + IsThrough=-1; + MissingChannel->clear(); + ExpectedChannel->clear(); + NumMissingChannel=-1; + MissingLayer->clear(); + NumMissingLayer=-1; + if (numtracksinev == 1) { // Get reconstructed tracks @@ -210,11 +237,14 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ //get track properties that are needed for the efficiency analysis + int IsMrdPenetrating; + thisTrackAsBoostStore->Get("StartVertex",StartVertex); thisTrackAsBoostStore->Get("StopVertex",StopVertex); thisTrackAsBoostStore->Get("PMTsHit",PMTsHit); thisTrackAsBoostStore->Get("LayersHit",LayersHit); thisTrackAsBoostStore->Get("MrdTrackID",MrdTrackID); + thisTrackAsBoostStore->Get("IsMrdPenetrating",IsMrdPenetrating); StartVertexX = StartVertex.X(); StartVertexY = StartVertex.Y(); @@ -224,7 +254,14 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ StopVertexZ = StopVertex.Z(); NPMTsHit = (int) PMTsHit.size(); NLayersHit = (int) LayersHit.size(); - tree_trackfit->Fill(); + NumMissingChannel = 0; + MissingChannel->clear(); + + bool long_track = false; + if (StartVertexZ < 3.45 && StopVertexZ > 4.5) long_track = true; + IsThrough = long_track; + + hist_nlayers->Fill(NLayersHit); if (usetruetrack){ std::vector> truetrackvertices; @@ -250,7 +287,7 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ // Minor selection cuts to only select well fit tracks - if (PMTsHit.size() < 50 ){ + if (PMTsHit.size() < 50 && long_track){ for (int i_pmt=0; i_pmt < (int) PMTsHit.size(); i_pmt++){ int mrdid = PMTsHit.at(i_pmt); @@ -265,7 +302,7 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ } }*/ } - + for (int i_layer = 0; i_layer < (int) zLayers.size(); i_layer++){ // Exclude first and layer from efficiency determination @@ -285,6 +322,7 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ if (orientationLayers.at(i_layer) == 0) { expected_MRDHits.at(i_layer).at(hit_chankey)->Fill(y_layer); expected_MRDHits_layer.at(i_layer).at(hit_chankey)->Fill(y_layer); + ExpectedChannel->push_back(hit_chankey); int half_expected_ch = map_chkey_half[hit_chankey]; int mrdid; if (isData) mrdid = channelkey_to_mrdpmtid[hit_chankey]; @@ -293,6 +331,9 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ observed_MRDHits.at(i_layer).at(hit_chankey)->Fill(y_layer); observed_MRDHits_layer.at(i_layer).at(hit_chankey)->Fill(y_layer); + } else { + MissingChannel->push_back(hit_chankey); + MissingLayer->push_back(i_layer+1); } for (unsigned long i = channels_start[i_layer]; i < channels_start[i_layer+1]; i++){ int half_channel = map_chkey_half[i]; @@ -311,6 +352,7 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ else { expected_MRDHits.at(i_layer).at(hit_chankey)->Fill(x_layer); expected_MRDHits_layer.at(i_layer).at(hit_chankey)->Fill(x_layer); + ExpectedChannel->push_back(hit_chankey); int half_expected_ch = map_chkey_half[hit_chankey]; int mrdid; if (isData) mrdid = channelkey_to_mrdpmtid[hit_chankey]; @@ -318,7 +360,11 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ if (std::find(PMTsHit.begin(),PMTsHit.end(),mrdid)!=PMTsHit.end()){ observed_MRDHits.at(i_layer).at(hit_chankey)->Fill(x_layer); observed_MRDHits_layer.at(i_layer).at(hit_chankey)->Fill(x_layer); - } + } else { + MissingChannel->push_back(hit_chankey); + MissingLayer->push_back(i_layer+1); + + } for (unsigned long i = channels_start[i_layer]; i < channels_start[i_layer+1]; i++){ int half_channel = map_chkey_half[i]; if (i==hit_chankey) continue; @@ -337,8 +383,11 @@ bool MrdPaddleEfficiencyPreparer::Execute(){ } } } - } else { + NumMissingChannel = (int) MissingChannel->size(); + NumMissingLayer = (int) MissingLayer->size(); tree_trackfit->Fill(); + } else { + //tree_trackfit->Fill(); } } @@ -351,6 +400,7 @@ bool MrdPaddleEfficiencyPreparer::Finalise(){ hist_file->cd(); hist_chankey->Write(); + hist_nlayers->Write(); tree_trackfit->Write(); for (unsigned int i_layer = 0; i_layer < zLayers.size(); i_layer++){ for (unsigned int i_ch = 0; i_ch < channelsLayers.at(i_layer).size(); i_ch++){ diff --git a/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.h b/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.h index 12ab171a8..332e4c512 100644 --- a/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.h +++ b/UserTools/MrdPaddleEfficiencyPreparer/MrdPaddleEfficiencyPreparer.h @@ -57,6 +57,7 @@ class MrdPaddleEfficiencyPreparer: public Tool { int numsubevs; int numtracksinev; int EventNumber; + int RunNumber; Position StartVertex; Position StopVertex; std::vector PMTsHit; @@ -75,9 +76,16 @@ class MrdPaddleEfficiencyPreparer: public Tool { double StopVertexX = 0.; double StopVertexY = 0.; double StopVertexZ = 0.; + int IsThrough = 0; + std::vector *MissingChannel = nullptr; + std::vector *ExpectedChannel = nullptr; + int NumMissingChannel = 0; + std::vector *MissingLayer = nullptr; + int NumMissingLayer = 0; TFile *hist_file = nullptr; TH1F *hist_chankey = nullptr; + TH1F *hist_nlayers = nullptr; TTree *tree_trackfit = nullptr; std::map> observed_MRDHits; diff --git a/UserTools/TimeClustering/TimeClustering.cpp b/UserTools/TimeClustering/TimeClustering.cpp index 0cb21e8f2..fdb960e6c 100644 --- a/UserTools/TimeClustering/TimeClustering.cpp +++ b/UserTools/TimeClustering/TimeClustering.cpp @@ -32,6 +32,9 @@ bool TimeClustering::Initialise(std::string configfile, DataModel &data){ MakeSingleEventPlots = false; //very verbose, mostly for debugging ModifiedTDCData = false; //Set default values for time-shifted TDC channels + //TDCs in one of the two crates are shifted in time with respect to the channels in the other crate + //--> correct this systematic time offset for cluster finding process + // https://github.com/ANNIEsoft/ToolAnalysis/pull/247 TimeShiftChannels = ""; shifted_channels = {std::make_pair(0,51),std::make_pair(82,107),std::make_pair(142,167),std::make_pair(194,219),std::make_pair(250,275),std::make_pair(306,332)}; diff --git a/configfiles/FMVEfficiency/ClusterFinderConfig b/configfiles/FMVEfficiency/ClusterFinderConfig index 8950a4909..24886023e 100644 --- a/configfiles/FMVEfficiency/ClusterFinderConfig +++ b/configfiles/FMVEfficiency/ClusterFinderConfig @@ -1,7 +1,7 @@ # ClusterFinder Config File HitStore Hits #Either MCHits or Hits (accessed in ANNIEEvent store) -OutputFile R1623S0p3_Clusters +OutputFile R3347_Clusters ClusterFindingWindow 100 # in ns, size of the window used to "clusterize" AcqTimeWindow 70000 # in ns, size of the acquisition window ClusterIntegrationWindow 100 # in ns, all hits with +/- 1/2 of this window are considered in the cluster diff --git a/configfiles/FMVEfficiency/FMVEfficiencyConfig b/configfiles/FMVEfficiency/FMVEfficiencyConfig index 549b02f4c..5df377ad0 100644 --- a/configfiles/FMVEfficiency/FMVEfficiencyConfig +++ b/configfiles/FMVEfficiency/FMVEfficiencyConfig @@ -1,6 +1,7 @@ # FMVEfficiency config file SinglePEGains ./configfiles/FMVEfficiency/ChannelSPEGains_BeamRun20192020.csv verbosity 0 -OutputFile FMVEfficiency_R1623_PMTMRD_p3 +OutputFile FMVEfficiency_R3347 UseTank 1 IsData 1 +PadPerLayer 3 diff --git a/configfiles/FMVEfficiency/FindMrdTracksConfig b/configfiles/FMVEfficiency/FindMrdTracksConfig index 5a54df4c1..5bc9985e7 100644 --- a/configfiles/FMVEfficiency/FindMrdTracksConfig +++ b/configfiles/FMVEfficiency/FindMrdTracksConfig @@ -1,7 +1,7 @@ # FindMrdTracks Config File # all variables retrieved with m_variables.Get() must be defined here! -verbosity 5 +verbosity 0 IsData 1 OutputDirectory . OutputFile MRDTracks_RAWDataR1624S0p99R0S0 diff --git a/configfiles/FMVEfficiency/LoadANNIEEventConfig b/configfiles/FMVEfficiency/LoadANNIEEventConfig index b18e388d4..d19b1c700 100644 --- a/configfiles/FMVEfficiency/LoadANNIEEventConfig +++ b/configfiles/FMVEfficiency/LoadANNIEEventConfig @@ -1,3 +1,3 @@ -verbose 4 +verbose 0 EventOffset 0 FileForListOfInputs ./configfiles/FMVEfficiency/my_inputs.txt diff --git a/configfiles/FMVEfficiency/TimeClusteringConfig b/configfiles/FMVEfficiency/TimeClusteringConfig index 1871df543..3856ddf58 100644 --- a/configfiles/FMVEfficiency/TimeClusteringConfig +++ b/configfiles/FMVEfficiency/TimeClusteringConfig @@ -1,13 +1,12 @@ #TimeClustering config file -verbosity 2 +verbosity 0 MinDigitsForTrack 3 MaxMrdSubEventDuration 30 MinSubeventTimeSep 30 MakeMrdDigitTimePlot 1 LaunchTApplication 0 IsData 1 -#OutputROOTFile TimeClustering_MRDTest28_cluster30ns -OutputROOTFile test +OutputROOTFile TimeClustering_R3347 MapChankey_WCSimID ./configfiles/FindMrdTracks/MRD_Chankey_WCSimID.dat TimeShiftChannels ./configfiles/FMVEfficiency/TimeShiftChannels.txt diff --git a/configfiles/FMVEfficiency/ToolsConfig b/configfiles/FMVEfficiency/ToolsConfig index 7a976c8c8..6c5df31a5 100644 --- a/configfiles/FMVEfficiency/ToolsConfig +++ b/configfiles/FMVEfficiency/ToolsConfig @@ -1,7 +1,5 @@ myLoadGeometry LoadGeometry configfiles/LoadGeometry/LoadGeometryConfig myLoadANNIEEvent LoadANNIEEvent configfiles/FMVEfficiency/LoadANNIEEventConfig -myPhaseIIADCCalibrator PhaseIIADCCalibrator configfiles/FMVEfficiency/PhaseIIADCCalibratorConfig -myPhaseIIADCHitFinder PhaseIIADCHitFinder configfiles/FMVEfficiency/PhaseIIADCHitFinderConfig myClusterFinder ClusterFinder configfiles/FMVEfficiency/ClusterFinderConfig myTimeClustering TimeClustering configfiles/FMVEfficiency/TimeClusteringConfig myFindMrdTracks FindMrdTracks configfiles/FMVEfficiency/FindMrdTracksConfig diff --git a/configfiles/FMVEfficiency/calculate_fmv_efficiency.C b/configfiles/FMVEfficiency/calculate_fmv_efficiency.C index 7d34076fb..d8f2253da 100644 --- a/configfiles/FMVEfficiency/calculate_fmv_efficiency.C +++ b/configfiles/FMVEfficiency/calculate_fmv_efficiency.C @@ -3,76 +3,24 @@ void calculate_fmv_efficiency(std::string inputfile, std::string outputfile, boo TFile *f_out = new TFile(outputfile.c_str(),"RECREATE"); //Define output histograms - TH1D *fmv_eff_layer1 = new TH1D("fmv_eff_layer1","FMV Efficiencies Layer 1",13,0,13); - TH1D *fmv_eff_strict_layer1 = new TH1D("fmv_eff_strict_layer1","FMV Efficiencies Layer 1 (Strict MRD Track)",13,0,13); - TH1D *fmv_eff_strict_avg_layer1 = new TH1D("fmv_eff_strict_avg_layer1","FMV Average Efficiencies Layer 1 (Strict MRD Track)",13,0,13); - TH1D *fmv_eff_loose_layer1 = new TH1D("fmv_eff_loose_layer1","FMV Efficiencies Layer 1 (MRD Track)",13,0,13); - TH1D *fmv_eff_loose_avg_layer1 = new TH1D("fmv_eff_loose_avg_layer1","FMV Average Efficiencies Layer 1 (MRD Track)",13,0,13); - TH1D *fmv_eff_layer2 = new TH1D("fmv_eff_layer2","FMV Efficiencies Layer 2",13,13,26); - TH1D *fmv_eff_strict_layer2 = new TH1D("fmv_eff_strict_layer2","FMV Efficiencies Layer 2 (Strict MRD Track)",13,13,26); - TH1D *fmv_eff_strict_avg_layer2 = new TH1D("fmv_eff_strict_avg_layer2","FMV Average Efficiencies Layer 2 (Strict MRD Track)",13,13,26); - TH1D *fmv_eff_loose_layer2 = new TH1D("fmv_eff_loose_layer2","FMV Efficiencies Layer 2 (MRD Track)",13,13,26); - TH1D *fmv_eff_loose_avg_layer2 = new TH1D("fmv_eff_loose_avg_layer2","FMV Average Efficiencies Layer 2 (MRD Track)",13,13,26); - TH1D *fmv_eff_tank_layer1 = nullptr; - TH1D *fmv_eff_tank_layer2 = nullptr; + TEfficiency *fmv_eff_layer1 = new TEfficiency("fmv_eff_layer1","FMV Efficiencies Layer 1;chankey;efficiency #varepsilon",13,0,13); + TEfficiency *fmv_eff_strict_layer1 = new TEfficiency("fmv_eff_strict_layer1","FMV Efficiencies Layer 1 (Strict MRD Track);chankey;efficiency #varepsilon",13,0,13); + TEfficiency *fmv_eff_strict_avg_layer1 = new TEfficiency("fmv_eff_strict_avg_layer1","FMV Average Efficiencies Layer 1 (Strict MRD Track);chankey;efficiency #varepsilon",13,0,13); + TEfficiency *fmv_eff_loose_layer1 = new TEfficiency("fmv_eff_loose_layer1","FMV Efficiencies Layer 1 (MRD Track);chankey; efficiency #varepsilon",13,0,13); + TEfficiency *fmv_eff_loose_avg_layer1 = new TEfficiency("fmv_eff_loose_avg_layer1","FMV Average Efficiencies Layer 1 (MRD Track);chankey; efficiency #varepsilon",13,0,13); + TEfficiency *fmv_eff_layer2 = new TEfficiency("fmv_eff_layer2","FMV Efficiencies Layer 2; chankey; efficiency #varepsilon",13,13,26); + TEfficiency *fmv_eff_strict_layer2 = new TEfficiency("fmv_eff_strict_layer2","FMV Efficiencies Layer 2 (Strict MRD Track); chankey; efficiency #varepsilon",13,13,26); + TEfficiency *fmv_eff_strict_avg_layer2 = new TEfficiency("fmv_eff_strict_avg_layer2","FMV Average Efficiencies Layer 2 (Strict MRD Track); chankey; efficiency #varepsilon",13,13,26); + TEfficiency *fmv_eff_loose_layer2 = new TEfficiency("fmv_eff_loose_layer2","FMV Efficiencies Layer 2 (MRD Track); chankey; efficiency #varepsilon",13,13,26); + TEfficiency *fmv_eff_loose_avg_layer2 = new TEfficiency("fmv_eff_loose_avg_layer2","FMV Average Efficiencies Layer 2 (MRD Track); chankey; efficiency #varepsilon",13,13,26); + TEfficiency *fmv_eff_tank_layer1 = nullptr; + TEfficiency *fmv_eff_tank_layer2 = nullptr; if (has_tank){ - fmv_eff_tank_layer1 = new TH1D("fmv_eff_tank_layer1","FMV Efficiencies (Tank coincidence) Layer 1",13,0,13); - fmv_eff_tank_layer2 = new TH1D("fmv_eff_tank_layer2","FMV Efficiencies (Tank coincidence) Layer 2",13,13,26); + fmv_eff_tank_layer1 = new TEfficiency("fmv_eff_tank_layer1","FMV Efficiencies (Tank coincidence) Layer 1;chankey; efficiency #varepsilon",13,0,13); + fmv_eff_tank_layer2 = new TEfficiency("fmv_eff_tank_layer2","FMV Efficiencies (Tank coincidence) Layer 2; chankey; efficiency #varepsilon",13,13,26); } - fmv_eff_layer1->SetStats(0); - fmv_eff_strict_layer1->SetStats(0); - fmv_eff_strict_avg_layer1->SetStats(0); - fmv_eff_loose_layer1->SetStats(0); - fmv_eff_loose_avg_layer1->SetStats(0); - fmv_eff_layer2->SetStats(0); - fmv_eff_strict_layer2->SetStats(0); - fmv_eff_strict_avg_layer2->SetStats(0); - fmv_eff_loose_layer2->SetStats(0); - fmv_eff_loose_avg_layer2->SetStats(0); - fmv_eff_layer1->GetXaxis()->SetTitle("chankey"); - fmv_eff_strict_layer1->GetXaxis()->SetTitle("chankey"); - fmv_eff_strict_avg_layer1->GetXaxis()->SetTitle("chankey"); - fmv_eff_loose_layer1->GetXaxis()->SetTitle("chankey"); - fmv_eff_loose_avg_layer1->GetXaxis()->SetTitle("chankey"); - fmv_eff_layer2->GetXaxis()->SetTitle("chankey"); - fmv_eff_strict_layer2->GetXaxis()->SetTitle("chankey"); - fmv_eff_strict_avg_layer2->GetXaxis()->SetTitle("chankey"); - fmv_eff_loose_layer2->GetXaxis()->SetTitle("chankey"); - fmv_eff_loose_avg_layer2->GetXaxis()->SetTitle("chankey"); - fmv_eff_layer1->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_strict_layer1->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_strict_avg_layer1->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_loose_layer1->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_loose_avg_layer1->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_layer2->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_strict_layer2->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_strict_avg_layer2->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_loose_layer2->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_loose_avg_layer2->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_layer1->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_strict_layer1->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_strict_avg_layer1->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_loose_layer1->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_loose_avg_layer1->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_layer2->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_strict_layer2->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_strict_avg_layer2->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_loose_layer2->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_loose_avg_layer2->GetYaxis()->SetRangeUser(0.,1.); - - if (has_tank){ - fmv_eff_tank_layer1->SetStats(0); - fmv_eff_tank_layer2->SetStats(0); - fmv_eff_tank_layer1->GetXaxis()->SetTitle("chankey"); - fmv_eff_tank_layer2->GetXaxis()->SetTitle("chankey"); - fmv_eff_tank_layer1->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_tank_layer2->GetYaxis()->SetTitle("efficiency #epsilon"); - fmv_eff_tank_layer1->GetYaxis()->SetRangeUser(0.,1.); - fmv_eff_tank_layer2->GetYaxis()->SetRangeUser(0.,1.); - } - - std::vector eff_hists_strict, eff_hists_loose; + std::vector eff_hists_strict, eff_hists_loose; TFile *f = new TFile(inputfile.c_str(),"READ"); @@ -105,29 +53,22 @@ void calculate_fmv_efficiency(std::string inputfile, std::string outputfile, boo for (int i=0; i< 13; i++){ double obs_counts = obs_layer1->GetBinContent(i+1); double exp_counts = exp_layer1->GetBinContent(i+1); - if (exp_counts == 0) exp_counts = 1; - fmv_eff_layer1->SetBinContent(i+1,obs_counts/exp_counts); - double eff_error = sqrt(obs_counts/exp_counts/exp_counts+obs_counts*obs_counts/exp_counts/exp_counts/exp_counts); - fmv_eff_layer1->SetBinError(i+1,eff_error); + fmv_eff_layer1->SetTotalEvents(i+1,exp_counts); + fmv_eff_layer1->SetPassedEvents(i+1,obs_counts); double obs_counts_strict = obs_track_strict_layer1->GetBinContent(i+1); double exp_counts_strict = exp_track_strict_layer1->GetBinContent(i+1); - if (exp_counts_strict == 0) exp_counts_strict = 1; - fmv_eff_strict_layer1->SetBinContent(i+1,obs_counts_strict/exp_counts_strict); - double eff_error_strict = sqrt(obs_counts_strict/exp_counts_strict/exp_counts_strict+obs_counts_strict*obs_counts_strict/exp_counts_strict/exp_counts_strict/exp_counts_strict); - fmv_eff_strict_layer1->SetBinError(i+1,eff_error_strict); + fmv_eff_strict_layer1->SetTotalEvents(i+1,exp_counts_strict); + fmv_eff_strict_layer1->SetPassedEvents(i+1,obs_counts_strict); double obs_counts_loose = obs_track_loose_layer1->GetBinContent(i+1); double exp_counts_loose = exp_track_loose_layer1->GetBinContent(i+1); - if (exp_counts_loose == 0) exp_counts_loose = 1; - fmv_eff_loose_layer1->SetBinContent(i+1,obs_counts_loose/exp_counts_loose); - double eff_error_loose = sqrt(obs_counts_loose/exp_counts_loose/exp_counts_loose+obs_counts_loose*obs_counts_loose/exp_counts_loose/exp_counts_loose/exp_counts_loose); - fmv_eff_loose_layer1->SetBinError(i+1,eff_error_loose); + fmv_eff_loose_layer1->SetTotalEvents(i+1,exp_counts_loose); + fmv_eff_loose_layer1->SetPassedEvents(i+1,obs_counts_loose); if (has_tank){ double obs_counts_tank = obs_tank_layer1->GetBinContent(i+1); double exp_counts_tank = exp_tank_layer1->GetBinContent(i+1); - if (exp_counts_tank == 0) exp_counts_tank = 1; - fmv_eff_tank_layer1->SetBinContent(i+1,obs_counts_tank/exp_counts_tank); - double eff_error_tank = sqrt(obs_counts_tank/exp_counts_tank/exp_counts_tank+obs_counts_tank*obs_counts_tank/exp_counts_tank/exp_counts_tank/exp_counts_tank); - fmv_eff_tank_layer1->SetBinError(i+1,eff_error_tank); + //if (exp_counts_tank == 0) exp_counts_tank = 1; + fmv_eff_tank_layer1->SetTotalEvents(i+1,exp_counts_tank); + fmv_eff_tank_layer1->SetPassedEvents(i+1,obs_counts_tank); } } @@ -135,29 +76,21 @@ void calculate_fmv_efficiency(std::string inputfile, std::string outputfile, boo for (int i=0; i< 13; i++){ double obs_counts = obs_layer2->GetBinContent(i+1); double exp_counts = exp_layer2->GetBinContent(i+1); - if (exp_counts == 0) exp_counts = 1; - fmv_eff_layer2->SetBinContent(i+1,obs_counts/exp_counts); - double eff_error = sqrt(obs_counts/exp_counts/exp_counts+obs_counts*obs_counts/exp_counts/exp_counts/exp_counts); - fmv_eff_layer2->SetBinError(i+1,eff_error); + fmv_eff_layer2->SetTotalEvents(i+1,exp_counts); + fmv_eff_layer2->SetPassedEvents(i+1,obs_counts); double obs_counts_strict = obs_track_strict_layer2->GetBinContent(i+1); double exp_counts_strict = exp_track_strict_layer2->GetBinContent(i+1); - if (exp_counts_strict == 0) exp_counts_strict = 1; - fmv_eff_strict_layer2->SetBinContent(i+1,obs_counts_strict/exp_counts_strict); - double eff_error_strict = sqrt(obs_counts_strict/exp_counts_strict/exp_counts_strict+obs_counts_strict*obs_counts_strict/exp_counts_strict/exp_counts_strict/exp_counts_strict); - fmv_eff_strict_layer2->SetBinError(i+1,eff_error_strict); + fmv_eff_strict_layer2->SetTotalEvents(i+1,exp_counts_strict); + fmv_eff_strict_layer2->SetPassedEvents(i+1,obs_counts_strict); double obs_counts_loose = obs_track_loose_layer2->GetBinContent(i+1); double exp_counts_loose = exp_track_loose_layer2->GetBinContent(i+1); - if (exp_counts_loose == 0) exp_counts_loose = 1; - fmv_eff_loose_layer2->SetBinContent(i+1,obs_counts_loose/exp_counts_loose); - double eff_error_loose = sqrt(obs_counts_loose/exp_counts_loose/exp_counts_loose+obs_counts_loose*obs_counts_loose/exp_counts_loose/exp_counts_loose/exp_counts_loose); - fmv_eff_loose_layer2->SetBinError(i+1,eff_error_loose); + fmv_eff_loose_layer2->SetTotalEvents(i+1,exp_counts_loose); + fmv_eff_loose_layer2->SetPassedEvents(i+1,obs_counts_loose); if (has_tank){ double obs_counts_tank = obs_tank_layer2->GetBinContent(i+1); double exp_counts_tank = exp_tank_layer2->GetBinContent(i+1); - if (exp_counts_tank == 0) exp_counts_tank = 1; - fmv_eff_tank_layer2->SetBinContent(i+1,obs_counts_tank/exp_counts_tank); - double eff_error_tank = sqrt(obs_counts_tank/exp_counts_tank/exp_counts_tank+obs_counts_tank*obs_counts_tank/exp_counts_tank/exp_counts_tank/exp_counts_tank); - fmv_eff_tank_layer2->SetBinError(i+1,eff_error_tank); + fmv_eff_tank_layer2->SetTotalEvents(i+1,exp_counts_tank); + fmv_eff_tank_layer2->SetPassedEvents(i+1,obs_counts_tank); } } @@ -171,9 +104,9 @@ void calculate_fmv_efficiency(std::string inputfile, std::string outputfile, boo hist_obs_loose_name <<"hist_observed_loose_chankey"<Get(hist_obs_strict_name.str().c_str()); TH1F* hist_exp_strict_temp = (TH1F*) f->Get(hist_exp_strict_name.str().c_str()); TH1F* hist_obs_loose_temp = (TH1F*) f->Get(hist_obs_loose_name.str().c_str()); @@ -181,16 +114,8 @@ void calculate_fmv_efficiency(std::string inputfile, std::string outputfile, boo //Create efficiency histograms f_out->cd(); - TH1D* hist_eff_strict_temp = new TH1D(hist_eff_strict_name.str().c_str(),hist_eff_strict_title.str().c_str(),hist_obs_strict_temp->GetXaxis()->GetNbins()/2,hist_obs_strict_temp->GetXaxis()->GetXmin(),hist_obs_strict_temp->GetXaxis()->GetXmax()); - hist_eff_strict_temp->GetXaxis()->SetTitle("x [m]"); - hist_eff_strict_temp->GetYaxis()->SetTitle("efficiency #epsilon"); - hist_eff_strict_temp->GetYaxis()->SetRangeUser(0.,1.); - hist_eff_strict_temp->SetStats(0); - TH1D* hist_eff_loose_temp = new TH1D(hist_eff_loose_name.str().c_str(),hist_eff_loose_title.str().c_str(),hist_obs_loose_temp->GetXaxis()->GetNbins()/2,hist_obs_loose_temp->GetXaxis()->GetXmin(),hist_obs_loose_temp->GetXaxis()->GetXmax()); - hist_eff_loose_temp->GetXaxis()->SetTitle("x [m]"); - hist_eff_loose_temp->GetYaxis()->SetTitle("efficiency #epsilon"); - hist_eff_loose_temp->GetYaxis()->SetRangeUser(0.,1.); - hist_eff_loose_temp->SetStats(0); + TEfficiency* hist_eff_strict_temp = new TEfficiency(hist_eff_strict_name.str().c_str(),hist_eff_strict_title.str().c_str(),hist_obs_strict_temp->GetXaxis()->GetNbins()/2,hist_obs_strict_temp->GetXaxis()->GetXmin(),hist_obs_strict_temp->GetXaxis()->GetXmax()); + TEfficiency* hist_eff_loose_temp = new TEfficiency(hist_eff_loose_name.str().c_str(),hist_eff_loose_title.str().c_str(),hist_obs_loose_temp->GetXaxis()->GetNbins()/2,hist_obs_loose_temp->GetXaxis()->GetXmin(),hist_obs_loose_temp->GetXaxis()->GetXmax()); TH1F *hist_obs_strict_rebin = (TH1F*) hist_obs_strict_temp->Rebin(2); TH1F *hist_exp_strict_rebin = (TH1F*) hist_exp_strict_temp->Rebin(2); @@ -201,57 +126,53 @@ void calculate_fmv_efficiency(std::string inputfile, std::string outputfile, boo double error_avg_efficiency_strict=0; double avg_efficiency_loose=0; double error_avg_efficiency_loose=0; + int tot_exp_strict=0; + int tot_obs_strict=0; + int tot_exp_loose=0; + int tot_obs_loose=0; int non_zero_bins_strict=0; int non_zero_bins_loose=0; for (int bin=0; binGetXaxis()->GetNbins(); bin++){ double obs_counts = hist_obs_strict_rebin->GetBinContent(bin+1); double exp_counts = hist_exp_strict_rebin->GetBinContent(bin+1); - if (exp_counts == 0) exp_counts = 1; - else non_zero_bins_strict++; - hist_eff_strict_temp->SetBinContent(bin+1,obs_counts/exp_counts); - double eff_error = sqrt(obs_counts/exp_counts/exp_counts+obs_counts*obs_counts/exp_counts/exp_counts/exp_counts); - hist_eff_strict_temp->SetBinError(bin+1,eff_error); + hist_eff_strict_temp->SetTotalEvents(bin+1,exp_counts); + hist_eff_strict_temp->SetPassedEvents(bin+1,obs_counts); double obs_counts_loose = hist_obs_loose_rebin->GetBinContent(bin+1); double exp_counts_loose = hist_exp_loose_rebin->GetBinContent(bin+1); - if (exp_counts_loose == 0) exp_counts_loose = 1; - else non_zero_bins_loose++; - hist_eff_loose_temp->SetBinContent(bin+1,obs_counts_loose/exp_counts_loose); - double eff_loose_error = sqrt(obs_counts_loose/exp_counts_loose/exp_counts_loose+obs_counts_loose*obs_counts_loose/exp_counts_loose/exp_counts_loose/exp_counts_loose); - hist_eff_loose_temp->SetBinError(bin+1,eff_loose_error); + hist_eff_loose_temp->SetTotalEvents(bin+1,exp_counts_loose); + hist_eff_loose_temp->SetPassedEvents(bin+1,obs_counts_loose); if (exp_counts >0){ + tot_exp_strict+=exp_counts; + tot_obs_strict+=obs_counts; avg_efficiency_strict+=(obs_counts/exp_counts); - error_avg_efficiency_strict+=(eff_error*eff_error); } if (exp_counts_loose > 0){ + tot_exp_loose+=exp_counts_loose; + tot_obs_loose+=obs_counts_loose; avg_efficiency_loose+=(obs_counts_loose/exp_counts_loose); - error_avg_efficiency_loose+=(eff_loose_error*eff_loose_error); } } eff_hists_strict.push_back(hist_eff_strict_temp); eff_hists_loose.push_back(hist_eff_loose_temp); - //avg_efficiency_strict/=hist_obs_strict_rebin->GetXaxis()->GetNbins(); - //avg_efficiency_loose/=hist_obs_strict_rebin->GetXaxis()->GetNbins(); avg_efficiency_strict/=non_zero_bins_strict; avg_efficiency_loose/=non_zero_bins_loose; error_avg_efficiency_strict=sqrt(error_avg_efficiency_strict); - //error_avg_efficiency_strict/=hist_obs_strict_rebin->GetXaxis()->GetNbins(); error_avg_efficiency_strict/=non_zero_bins_strict; error_avg_efficiency_loose=sqrt(error_avg_efficiency_loose); - //error_avg_efficiency_loose/=hist_obs_strict_rebin->GetXaxis()->GetNbins(); error_avg_efficiency_loose/=non_zero_bins_loose; if (i < 13) { - fmv_eff_strict_avg_layer1->SetBinContent(i+1,avg_efficiency_strict); - fmv_eff_strict_avg_layer1->SetBinError(i+1,error_avg_efficiency_strict); - fmv_eff_loose_avg_layer1->SetBinContent(i+1,avg_efficiency_loose); - fmv_eff_loose_avg_layer1->SetBinError(i+1,error_avg_efficiency_loose); + fmv_eff_strict_avg_layer1->SetTotalEvents(i+1,tot_exp_strict); + fmv_eff_strict_avg_layer1->SetPassedEvents(i+1,tot_obs_strict); + fmv_eff_loose_avg_layer1->SetTotalEvents(i+1,tot_exp_loose); + fmv_eff_loose_avg_layer1->SetPassedEvents(i+1,tot_obs_loose); } else { - fmv_eff_strict_avg_layer2->SetBinContent(i-13+1,avg_efficiency_strict); - fmv_eff_strict_avg_layer2->SetBinError(i-13+1,error_avg_efficiency_strict); - fmv_eff_loose_avg_layer2->SetBinContent(i-13+1,avg_efficiency_loose); - fmv_eff_loose_avg_layer2->SetBinError(i-13+1,error_avg_efficiency_loose); + fmv_eff_strict_avg_layer2->SetTotalEvents(i-13+1,tot_exp_strict); + fmv_eff_strict_avg_layer2->SetPassedEvents(i-13+1,tot_obs_strict); + fmv_eff_loose_avg_layer2->SetTotalEvents(i-13+1,tot_exp_loose); + fmv_eff_loose_avg_layer2->SetPassedEvents(i-13+1,tot_obs_loose); } } diff --git a/configfiles/FMVEfficiency/my_inputs.txt b/configfiles/FMVEfficiency/my_inputs.txt index 5303c2123..e0f7830dc 100644 --- a/configfiles/FMVEfficiency/my_inputs.txt +++ b/configfiles/FMVEfficiency/my_inputs.txt @@ -1 +1 @@ -/pnfs/annie/persistent/users/pershint/ProcessedData/V0/ProcessedRawData_TankMRDR1623S0p3 +/pnfs/annie/persistent/users/mnieslon/data/processed_hits_improved/R3347/ProcessedRawData_TankAndMRDAndCTC_R3347S0p0 diff --git a/configfiles/MrdPaddleEfficiency/Data/FindMrdTracksConfig b/configfiles/MrdPaddleEfficiency/Data/FindMrdTracksConfig index 3ee9c3547..c9aff4e88 100644 --- a/configfiles/MrdPaddleEfficiency/Data/FindMrdTracksConfig +++ b/configfiles/MrdPaddleEfficiency/Data/FindMrdTracksConfig @@ -1,12 +1,12 @@ # FindMrdTracks Config File # all variables retrieved with m_variables.Get() must be defined here! -verbosity 5 +verbosity 0 IsData 1 OutputDirectory . -OutputFile MRDTracks_RAWDataR1613S0p89R0S0 +OutputFile MRDTracks_RAWDataR3347 DrawTruthTracks 0 # whether to add MC Truth track info for drawing in MrdPaddlePlot Tool ## note you need to run that tool to actually view the tracks! WriteTracksToFile 0 # should the track information be written to a ROOT-file? SelectTriggerType 1 #should the loaded data be filtered by trigger type? -TriggerType Cosmic #options: Cosmic, Beam, NoLoopback +TriggerType Beam #options: Cosmic, Beam, NoLoopback diff --git a/configfiles/MrdPaddleEfficiency/Data/LoadANNIEEventConfig b/configfiles/MrdPaddleEfficiency/Data/LoadANNIEEventConfig index 5d29c32f4..b405b6aef 100644 --- a/configfiles/MrdPaddleEfficiency/Data/LoadANNIEEventConfig +++ b/configfiles/MrdPaddleEfficiency/Data/LoadANNIEEventConfig @@ -1,3 +1,4 @@ -verbose 4 +verbose 1 EventOffset 0 FileForListOfInputs ./configfiles/MrdPaddleEfficiency/Data/my_inputs.txt +GlobalEvNr 1 diff --git a/configfiles/MrdPaddleEfficiency/Data/MrdPaddleEfficiencyPreparerConfig b/configfiles/MrdPaddleEfficiency/Data/MrdPaddleEfficiencyPreparerConfig index 96f7594bb..80f75e7c8 100644 --- a/configfiles/MrdPaddleEfficiency/Data/MrdPaddleEfficiencyPreparerConfig +++ b/configfiles/MrdPaddleEfficiency/Data/MrdPaddleEfficiencyPreparerConfig @@ -1,4 +1,4 @@ #MRDPaddleEfficiencyPreparer Config file -OutputFile RAWDataR1613S0p89R0S0 +OutputFile mrd_observed_new_R3347S0_Beam verbosity 1 diff --git a/configfiles/MrdPaddleEfficiency/Data/MrdPaddlePlotConfig b/configfiles/MrdPaddleEfficiency/Data/MrdPaddlePlotConfig index 3dbfddee3..e463a49e6 100644 --- a/configfiles/MrdPaddleEfficiency/Data/MrdPaddlePlotConfig +++ b/configfiles/MrdPaddleEfficiency/Data/MrdPaddlePlotConfig @@ -21,5 +21,5 @@ saverootfile 1 # save the paddle plots within a rootfile. plotDirectory ./MrdPlots # where to save plot images printTClonesTracks 0 # verbose printout of track information from TClonesArray useTApplication 0 # launch a TApplication to directly show the plots (slow on cluster) -OutputROOTFile MRDPaddlePlots_RAWDataR1613S0p89R0S0 +OutputROOTFile MRDPaddlePlots_R3347_Beam DrawOnlyTracks 1 # should subevents only be drawn if there was a track found? diff --git a/configfiles/MrdPaddleEfficiency/Data/TimeClusteringConfig b/configfiles/MrdPaddleEfficiency/Data/TimeClusteringConfig index 6ad8aafd5..5ab839cd2 100644 --- a/configfiles/MrdPaddleEfficiency/Data/TimeClusteringConfig +++ b/configfiles/MrdPaddleEfficiency/Data/TimeClusteringConfig @@ -1,13 +1,12 @@ #TimeClustering config file -verbosity 2 +verbosity 0 MinDigitsForTrack 4 MaxMrdSubEventDuration 30 MinSubeventTimeSep 30 MakeMrdDigitTimePlot 1 LaunchTApplication 0 IsData 1 -OutputROOTFile TimeClustering_RAWDataR1613S0p89R0S0 +OutputROOTFile TimeClustering_R3347 #OutputROOTFile test MapChankey_WCSimID ./configfiles/MrdPaddleEfficiency/MRD_Chankey_WCSimID.dat - diff --git a/configfiles/MrdPaddleEfficiency/Data/ToolsConfig b/configfiles/MrdPaddleEfficiency/Data/ToolsConfig index 9a8cbdf1a..fc6137983 100644 --- a/configfiles/MrdPaddleEfficiency/Data/ToolsConfig +++ b/configfiles/MrdPaddleEfficiency/Data/ToolsConfig @@ -2,5 +2,5 @@ myLoadGeometry LoadGeometry configfiles/LoadGeometry/LoadGeometryConfig myLoadANNIEEvent LoadANNIEEvent configfiles/MrdPaddleEfficiency/Data/LoadANNIEEventConfig myTimeClustering TimeClustering configfiles/MrdPaddleEfficiency/Data/TimeClusteringConfig myFindMrdTracks FindMrdTracks configfiles/MrdPaddleEfficiency/Data/FindMrdTracksConfig -#myPlotMrdTracks MrdPaddlePlot configfiles/MrdPaddleEfficiency/Data/MrdPaddlePlotConfig myMrdPaddleEfficiencyPreparer MrdPaddleEfficiencyPreparer configfiles/MrdPaddleEfficiency/Data/MrdPaddleEfficiencyPreparerConfig +#myPlotMrdTracks MrdPaddlePlot configfiles/MrdPaddleEfficiency/Data/MrdPaddlePlotConfig diff --git a/configfiles/MrdPaddleEfficiency/Data/my_inputs.txt b/configfiles/MrdPaddleEfficiency/Data/my_inputs.txt index e53ad83ef..e0f7830dc 100644 --- a/configfiles/MrdPaddleEfficiency/Data/my_inputs.txt +++ b/configfiles/MrdPaddleEfficiency/Data/my_inputs.txt @@ -1 +1 @@ -/annie/app/users/mnieslon/MyToolAnalysis5/mrdfiles_complete/RAWDataR1613S0p89R0S0 +/pnfs/annie/persistent/users/mnieslon/data/processed_hits_improved/R3347/ProcessedRawData_TankAndMRDAndCTC_R3347S0p0 diff --git a/configfiles/MrdPaddleEfficiencyCalc/MRDCorrectionFactors.dat b/configfiles/MrdPaddleEfficiencyCalc/MRDCorrectionFactors.dat new file mode 100644 index 000000000..ad3f9e7ed --- /dev/null +++ b/configfiles/MrdPaddleEfficiencyCalc/MRDCorrectionFactors.dat @@ -0,0 +1,254 @@ +52 0.80391 1.18172 +53 0.952744 0.99712 +54 0.941703 1.00881 +55 0.943432 1.00696 +56 0.938404 1.01236 +57 0.957645 0.992017 +58 0.940418 1.01019 +59 0.950881 0.999073 +60 0.951423 0.998504 +61 0.955138 0.994621 +62 0.945138 1.00514 +63 0.937649 1.01317 +64 0.940545 1.01005 +65 0.952832 0.997028 +66 0.808368 1.17521 +67 0.814864 1.16584 +68 0.947312 1.00284 +69 0.945395 1.00487 +70 0.944073 1.00628 +71 0.949777 1.00023 +72 0.957611 0.992052 +73 0.950949 0.999002 +74 0.950759 0.999201 +75 0.942096 1.00839 +76 0.958033 0.991615 +77 0.950011 0.999989 +78 0.945359 1.00491 +79 0.951678 0.998237 +80 0.949135 1.00091 +81 0.820479 1.15786 +82 0.817802 1.16165 +83 0.950717 0.999245 +84 0.94666 1.00353 +85 0.947377 1.00277 +86 0.950039 0.999959 +87 0.944171 1.00617 +88 0.954509 0.995276 +89 0.952074 0.997821 +90 0.951844 0.998062 +91 0.953808 0.996007 +92 0.94691 1.00326 +93 0.949008 1.00105 +94 0.829653 1.14506 +95 0.823042 1.15425 +96 0.945311 1.00496 +97 0.951628 0.998289 +98 0.950327 0.999656 +99 0.948223 1.00187 +100 0.948919 1.00114 +101 0.953145 0.9967 +102 0.949969 1.00003 +103 0.952345 0.997537 +104 0.952788 0.997073 +105 0.951435 0.998492 +106 0.945362 1.00491 +107 0.824502 1.15221 +108 0.834586 1.13829 +109 0.921227 1.03123 +110 0.957263 0.992413 +111 0.934416 1.01668 +112 0.944203 1.00614 +113 0.938131 1.01265 +114 0.961682 0.987853 +115 0.925637 1.02632 +116 0.942566 1.00789 +117 0.936785 1.01411 +118 0.96468 0.984782 +119 0.942529 1.00793 +120 0.946023 1.0042 +121 0.936442 1.01448 +122 0.966227 0.983206 +123 0.930268 1.02121 +124 0.848312 1.11987 +125 0.850613 1.11684 +126 0.92341 1.0288 +127 0.957913 0.991739 +128 0.936958 1.01392 +129 0.946248 1.00397 +130 0.936869 1.01402 +131 0.9539 0.995912 +132 0.935068 1.01597 +133 0.943172 1.00724 +134 0.935719 1.01526 +135 0.957978 0.991672 +136 0.94206 1.00843 +137 0.946826 1.00335 +138 0.933964 1.01717 +139 0.960076 0.989505 +140 0.932721 1.01853 +141 0.838555 1.1329 +142 0.803303 1.18262 +143 0.949556 1.00047 +144 0.950553 0.999418 +145 0.950887 0.999067 +146 0.950345 0.999637 +147 0.946221 1.00399 +148 0.945933 1.0043 +149 0.951311 0.998621 +150 0.945381 1.00489 +151 0.951269 0.998666 +152 0.951068 0.998877 +153 0.946287 1.00392 +154 0.805751 1.17902 +155 0.840818 1.12985 +156 0.949915 1.00009 +157 0.95451 0.995275 +158 0.95173 0.998183 +159 0.949355 1.00068 +160 0.948926 1.00113 +161 0.949581 1.00044 +162 0.947714 1.00241 +163 0.949806 1.0002 +164 0.952179 0.997712 +165 0.951701 0.998212 +166 0.949611 1.00041 +167 0.8172 1.16251 +168 0.867368 1.09527 +169 0.930127 1.02137 +170 0.932755 1.01849 +171 0.916486 1.03657 +172 0.931634 1.01971 +173 0.931696 1.01965 +174 0.918004 1.03485 +175 0.93625 1.01469 +176 0.938732 1.012 +177 0.918579 1.03421 +178 0.932639 1.01861 +179 0.930653 1.02079 +180 0.882071 1.07701 +181 0.867596 1.09498 +182 0.932442 1.01883 +183 0.935267 1.01575 +184 0.914272 1.03908 +185 0.934592 1.01649 +186 0.938501 1.01225 +187 0.914517 1.0388 +188 0.932282 1.019 +189 0.936893 1.01399 +190 0.917047 1.03593 +191 0.942542 1.00791 +192 0.932027 1.01928 +193 0.880896 1.07845 +194 0.811667 1.17043 +195 0.944639 1.00568 +196 0.94527 1.005 +197 0.941622 1.0089 +198 0.948677 1.0014 +199 0.943426 1.00697 +200 0.947262 1.00289 +201 0.95423 0.995567 +202 0.946957 1.00321 +203 0.950908 0.999045 +204 0.945928 1.0043 +205 0.944706 1.0056 +206 0.799076 1.18887 +207 0.83192 1.14194 +208 0.949105 1.00094 +209 0.948345 1.00175 +210 0.944793 1.00551 +211 0.946471 1.00373 +212 0.943518 1.00687 +213 0.950907 0.999046 +214 0.944453 1.00587 +215 0.948604 1.00147 +216 0.949714 1.0003 +217 0.947283 1.00287 +218 0.947239 1.00291 +219 0.804316 1.18113 +220 0.939567 1.0111 +221 0.96581 0.98363 +222 0.955483 0.994261 +223 0.961815 0.987716 +224 0.964592 0.984873 +225 0.962515 0.986998 +226 0.96032 0.989253 +227 0.961643 0.987893 +228 0.962377 0.987139 +229 0.965892 0.983547 +230 0.963556 0.985931 +231 0.957838 0.991817 +232 0.963017 0.986483 +233 0.96625 0.983183 +234 0.955837 0.993893 +235 0.950635 0.999332 +236 0.962358 0.987159 +237 0.959297 0.990308 +238 0.95864 0.990988 +239 0.960107 0.989473 +240 0.960709 0.988853 +241 0.9586 0.991029 +242 0.96241 0.987105 +243 0.95534 0.99441 +244 0.959355 0.990249 +245 0.96189 0.987639 +246 0.960901 0.988655 +247 0.959354 0.99025 +248 0.964264 0.985207 +249 0.948404 1.00168 +250 0.818084 1.16125 +251 0.938474 1.01228 +252 0.9356 1.01539 +253 0.941619 1.0089 +254 0.94223 1.00825 +255 0.93374 1.01741 +256 0.94076 1.00982 +257 0.943653 1.00673 +258 0.939091 1.01162 +259 0.938891 1.01183 +260 0.937743 1.01307 +261 0.9388 1.01193 +262 0.797765 1.19083 +263 0.847662 1.12073 +264 0.93725 1.0136 +265 0.934832 1.01623 +266 0.944593 1.00572 +267 0.93748 1.01336 +268 0.944025 1.00633 +269 0.942083 1.0084 +270 0.9384 1.01236 +271 0.938782 1.01195 +272 0.945399 1.00487 +273 0.934068 1.01706 +274 0.930168 1.02132 +275 0.801948 1.18462 +276 0.914286 1.03906 +277 0.947333 1.00281 +278 0.929174 1.02241 +279 0.941285 1.00926 +280 0.942772 1.00767 +281 0.945406 1.00486 +282 0.946511 1.00369 +283 0.946486 1.00371 +284 0.948953 1.0011 +285 0.950045 0.999953 +286 0.949955 1.00005 +287 0.947913 1.0022 +288 0.939828 1.01082 +289 0.951079 0.998866 +290 0.928101 1.0236 +291 0.92133 1.03112 +292 0.950642 0.999325 +293 0.93256 1.0187 +294 0.933838 1.01731 +295 0.941667 1.00885 +296 0.943423 1.00697 +297 0.941875 1.00863 +298 0.943168 1.00724 +299 0.938417 1.01234 +300 0.936782 1.01411 +301 0.941661 1.00886 +302 0.939305 1.01139 +303 0.937083 1.01378 +304 0.944337 1.006 +305 0.916093 1.03701 diff --git a/configfiles/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalcConfig b/configfiles/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalcConfig index 60ec37108..54f8096bc 100644 --- a/configfiles/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalcConfig +++ b/configfiles/MrdPaddleEfficiencyCalc/MrdPaddleEfficiencyCalcConfig @@ -2,10 +2,11 @@ #InputFile /annie/app/users/mnieslon/MyToolAnalysis8/mrd_paddleeff/R1619_R1624_mrdobserved.root #OutputFile R1619_R1624_mrdefficiency.root -InputFile /annie/app/users/mnieslon/MyToolAnalysis_Efficiency/mrd_observed/mrd_observed_R2135_R2146.root -OutputFile mrd_eff_R2135_R2146_MrdGeometry_09-29-20_LayerPlots.root +InputFile /annie/app/users/mnieslon/MyToolAnalysis_Efficiency/mrd_observed_new_R3845-R3850_Cosmic.root +OutputFile mrd_eff_new_R3845-R3850_Cosmic.root InactiveFile ./configfiles/MrdPaddleEfficiencyCalc/MRD_inactivech_eff.txt IsData 1 #Is this a data or MC file? MCChankeyFile ./configfiles/MrdPaddleEfficiencyCalc/MRD_Chankeys_Data_MC.dat #Needed in MC case verbosity 5 LayerPlots 1 #Should layer-wise plots be produced? +CorrectionFile ./configfiles/MrdPaddleEfficiencyCalc/MRDCorrectionFactors.dat From 90172d90263bdfb2904c576a0d7a292ba9488f24 Mon Sep 17 00:00:00 2001 From: Daniel Tobias Schmid <82974642+s4294967296@users.noreply.github.com> Date: Tue, 5 Dec 2023 14:09:14 +0100 Subject: [PATCH 13/31] Prevent throwing of a fatal error when build type is set to "MRD". (#252) * Fixed mrdtotalentries being smaller than tanktotalentries throwing a fatal error in LoadRawData.cpp when build type is set to "MRD", since in this case only MRD data is expected to be loaded. authored-by: Daniel T. Schmid --- UserTools/LoadRawData/LoadRawData.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/UserTools/LoadRawData/LoadRawData.cpp b/UserTools/LoadRawData/LoadRawData.cpp index 0a266dff8..bbddfcde9 100644 --- a/UserTools/LoadRawData/LoadRawData.cpp +++ b/UserTools/LoadRawData/LoadRawData.cpp @@ -163,7 +163,7 @@ bool LoadRawData::Execute(){ } //If more MRD events than VME events abort - if (mrdtotalentries > tanktotalentries){ + if (mrdtotalentries > tanktotalentries && BuildType != "MRD"){ std::cout << "LoadRawData tool ERROR: More MRD entries than VME entries! Stopping toolchain" << std::endl; m_data->vars.Set("StopLoop",1); } From 062a3316b0bc60ce7ac9a1fe3eee05f6b464f9e9 Mon Sep 17 00:00:00 2001 From: Steven Doran <78985334+S81D@users.noreply.github.com> Date: Tue, 6 Feb 2024 08:51:27 -0600 Subject: [PATCH 14/31] Official EventBuilding ToolChain (#253) * Official toolchain for event building EventBuilder ToolChain - very similar to DataDecoder toolchain, with some minor configuration differences: - Updated trigger mask to include all triggers (1-64) - Updated LoadGeometry file path for Gian's new gain calibration data - Added Johann's SaveConfigInfo tool - Excluded Stage1DataBuilder until bug fix - Minor fix in ANNIEEventBuilderConfig (changing true/false to 1/0) - Updated file paths for more recent data * Update BeamFetcherConfig Part of updated the BeamFetcher toolchain (needed prior to event building) * Update LoadRunInfoConfig Included a copy of the run info from the SQL webpage in the local toolanalysis directory * Add files via upload added local SQL run information for fetching beam info * Update TriggerDataDecoderConfig updated path for trigger mask to include all triggers * Update my_files.txt added new paths for event building * Added the updated gains information from Gian * Update LoadGeometryConfig Updated gains file path within the LoadGeometryConfig file in the LoadGeometry toolchain - many tools call this config file (configfiles/LoadGeometry), instead of calling their own LoadGeometryConfig file that is present within that specific toolchain. Instead of replacing every path within all config files, replace this one. * Update DefaultTriggerMask.txt After testing the new EventBuilder toolchain, including all triggers in the triggermask file seems to slow the toolchain down by 2x (or so). Going back to default file. * Update DefaultTriggerMask.txt Added necessary trigwords for AmBe external trigger (15) and laser (46 or 47, dependent on settings. Through the current laser run campaign, various configurations will either lead to the trigword being 46 or 47... not sure why). * Update ToolsConfig For now, omit BeamDecoder until we have BeamFetcherv2 up and running * Update DefaultTriggerMask.txt Include the undelayed beam trigger for retroactive LAPPD time matching with other subsystems. If there is an LAPPD event, this triggerword can be used to check if the LAPPD event is correctly aligned, in case any hardware was broken (according to Yue) * Update DefaultTriggerMask.txt I swear this is the final change. Yue initially requested I put this trigword in, however he recently encountered errors when trying to pair the LAPPDs to the MRD. For now, omitting this trigword until he can find a suitable trigword for LAPPD timing alignment * Update LoadRawDataConfig Lowering the verbosity * Update ANNIEEventBuilderConfig Since we are omitting the beamfetcher tool for now, do not store the beam information in the final annieevent * Update ANNIEEventBuilderConfig change config file comments to use `#` instead of `//` --- .../BeamFetcher/ANNIE_RunInformation_PSQL.txt | 6227 +++++++++++++++++ configfiles/BeamFetcher/BeamFetcherConfig | 4 +- configfiles/BeamFetcher/LoadRunInfoConfig | 2 +- .../EventBuilder/ANNIEEventBuilderConfig | 20 + configfiles/EventBuilder/BeamDecoderConfig | 17 + .../EventBuilder/DefaultTriggerMask.txt | 10 + configfiles/EventBuilder/LoadGeometryConfig | 8 + configfiles/EventBuilder/LoadRawDataConfig | 9 + configfiles/EventBuilder/MRDDataDecoderConfig | 2 + configfiles/EventBuilder/PMTDataDecoderConfig | 5 + .../EventBuilder/PhaseIIADCCalibratorConfig | 15 + .../EventBuilder/PhaseIIADCHitFinderConfig | 10 + configfiles/EventBuilder/SaveConfigInfoConfig | 3 + configfiles/EventBuilder/ToolChainConfig | 23 + configfiles/EventBuilder/ToolsConfig | 9 + .../EventBuilder/TriggerDataDecoderConfig | 4 + configfiles/EventBuilder/my_files.txt | 2 + .../LoadGeometry/ChannelSPEGains2023.csv | 125 + configfiles/LoadGeometry/LoadGeometryConfig | 2 +- .../TriggerDataDecoderConfig | 2 +- .../PreProcessTrigOverlap/my_files.txt | 98 +- 21 files changed, 6496 insertions(+), 101 deletions(-) create mode 100644 configfiles/BeamFetcher/ANNIE_RunInformation_PSQL.txt create mode 100644 configfiles/EventBuilder/ANNIEEventBuilderConfig create mode 100644 configfiles/EventBuilder/BeamDecoderConfig create mode 100644 configfiles/EventBuilder/DefaultTriggerMask.txt create mode 100644 configfiles/EventBuilder/LoadGeometryConfig create mode 100644 configfiles/EventBuilder/LoadRawDataConfig create mode 100644 configfiles/EventBuilder/MRDDataDecoderConfig create mode 100644 configfiles/EventBuilder/PMTDataDecoderConfig create mode 100644 configfiles/EventBuilder/PhaseIIADCCalibratorConfig create mode 100644 configfiles/EventBuilder/PhaseIIADCHitFinderConfig create mode 100644 configfiles/EventBuilder/SaveConfigInfoConfig create mode 100644 configfiles/EventBuilder/ToolChainConfig create mode 100644 configfiles/EventBuilder/ToolsConfig create mode 100644 configfiles/EventBuilder/TriggerDataDecoderConfig create mode 100644 configfiles/EventBuilder/my_files.txt create mode 100644 configfiles/LoadGeometry/ChannelSPEGains2023.csv diff --git a/configfiles/BeamFetcher/ANNIE_RunInformation_PSQL.txt b/configfiles/BeamFetcher/ANNIE_RunInformation_PSQL.txt new file mode 100644 index 000000000..038c5ceba --- /dev/null +++ b/configfiles/BeamFetcher/ANNIE_RunInformation_PSQL.txt @@ -0,0 +1,6227 @@ +6588 4578 0 2023-09-10 17:22:14.000078 2023-09-10 18:13:25.706248 35 228748 +6587 4577 0 2023-09-10 16:24:44.752645 2023-09-10 17:15:13.2739 35 223623 +6586 4576 0 2023-09-10 14:55:58.718661 2023-09-10 16:03:09.696024 40 75221 +6585 4575 0 2023-09-08 21:45:59.2592 2023-09-10 14:40:07.068671 40 2760874 +6584 4574 0 2023-09-08 20:54:43.553465 2023-09-08 21:07:16.138357 40 13333 +6583 4573 0 2023-09-07 18:10:21.485705 2023-09-08 19:41:14.00356 40 1721222 +6582 4572 0 2023-09-06 23:28:00.76777 2023-09-07 15:52:25.720732 40 1106913 +6581 4571 0 2023-09-06 22:32:10.295639 2023-09-06 23:18:09.800514 40 50456 +6580 4570 0 2023-09-06 22:06:08.469313 2023-09-06 22:23:46.988151 40 18952 +6579 4569 0 2023-09-06 02:06:47.656981 2023-09-06 15:00:20.515115 40 869530 +6578 4568 0 2023-09-05 20:33:41.661791 2023-09-06 01:10:12.475783 40 342746 +6577 4567 0 2023-09-02 08:21:55.388536 2023-09-05 11:40:06.477226 37 567755 +6576 4566 0 2023-09-01 07:33:54.633101 2023-09-01 23:06:21.109532 40 6500 +6575 4565 0 2023-09-01 05:04:03.250185 2023-09-01 07:25:32.631588 40 981 +6574 4564 0 2023-09-01 04:51:37.167161 2023-09-01 04:57:31.868499 40 33 +6573 4563 0 2023-08-31 02:11:38.793037 2023-08-31 23:45:28.187817 40 1454561 +6572 4562 0 2023-08-30 16:19:08.610753 2023-08-31 02:04:00.43971 40 656902 +6571 4561 0 2023-08-29 23:42:08.6669 2023-08-30 14:55:47.294308 40 1128013 +6570 4560 0 2023-08-29 23:18:09.297924 2023-08-29 23:32:41.612156 40 11386 +6569 4559 0 2023-08-29 22:56:58.690986 2023-08-29 23:15:28.743514 40 21989 +6568 4558 0 2023-08-29 21:28:39.628203 2023-08-29 22:47:32.940035 40 96091 +6567 4557 0 2023-08-29 21:25:26.568267 2023-08-29 21:26:18.936932 40 0 +6566 4556 0 2023-08-29 16:26:02.863879 2023-08-29 20:58:08.257745 35 1245549 +6322 4314 0 2023-05-14 22:38:45.141672 2023-05-15 12:53:03.970512 34 1042847 +6230 4224 0 2023-03-26 18:10:29.270308 2023-03-27 15:16:41.669105 34 1689801 +6212 4206 0 2023-03-10 17:14:07.314998 2023-03-10 21:20:30.554759 36 32442 +6211 4205 0 2023-03-10 05:00:41.216661 2023-03-10 17:08:32.34053 37 85161 +6210 4204 0 2023-03-10 01:11:50.552832 2023-03-10 04:55:48.197707 35 1021553 +6209 4203 0 2023-03-09 22:07:36.490258 2023-03-10 01:06:23.920087 35 872515 +6208 4202 0 2023-03-09 17:18:56.367847 2023-03-09 21:51:44.712862 37 32116 +6207 4201 0 2023-03-09 07:21:58.193053 2023-03-09 17:05:22.374428 37 95643 +6206 4200 0 2023-03-09 00:56:16.002822 2023-03-09 07:14:23.56712 34 535760 +6205 4199 0 2023-03-08 20:39:51.218553 2023-03-09 00:54:02.139329 37 28899 +6204 4198 0 2023-03-08 19:05:17.410049 2023-03-08 20:19:17.969109 37 8351 +6203 4197 0 2023-03-07 23:45:46.763098 2023-03-08 17:45:18.061091 34 1401044 +6202 4196 0 2023-03-07 22:04:13.410522 2023-03-07 23:41:47.463879 39 144757 +6201 4195 0 2023-03-04 17:36:35.79689 2023-03-07 21:56:23.496916 34 6521684 +6200 4194 0 2023-03-01 21:34:48.929182 2023-03-04 17:34:14.762925 34 6110705 +6199 4193 0 2023-03-01 21:25:50.237654 2023-03-01 21:29:58.572152 34 6218 +6198 4192 0 2023-03-01 21:16:39.835659 2023-03-01 21:20:26.075965 34 4581 +6197 4191 0 2023-02-28 21:47:14.124791 2023-03-01 20:03:32.412082 34 1975186 +6196 4190 0 2023-02-28 21:34:07.699865 2023-02-28 21:44:24.664219 36 318 +6195 4189 0 2023-02-26 15:38:07.948277 2023-02-28 21:29:03.583711 34 2844222 +6194 4188 0 2023-02-24 20:05:33.447165 39 +6193 4187 0 2023-02-24 19:49:52.505623 2023-02-24 19:53:49.107511 39 2298 +6192 4186 0 2023-02-24 18:16:16.357652 2023-02-24 19:47:00.350187 39 165 +6191 4185 0 2023-02-24 17:55:24.453006 2023-02-24 17:57:52.071679 39 1626 +6190 4184 0 2023-02-24 17:42:33.325601 2023-02-24 17:43:59.756364 39 763 +6189 4183 0 2023-02-24 01:31:04.784156 2023-02-24 15:14:02.869759 39 727691 +6188 4182 0 2023-02-23 18:18:31.040795 2023-02-24 01:25:22.19185 39 455750 +6187 4181 0 2023-02-23 16:33:05.211093 2023-02-23 17:19:16.728307 40 51573 +6186 4180 0 2023-02-23 00:20:39.040219 2023-02-23 16:21:12.312932 39 824141 +6185 4179 0 2023-02-22 23:22:02.608534 2023-02-23 00:01:54.520534 40 52018 +6184 4178 0 2023-02-22 21:41:41.242267 40 +6183 4177 0 2023-02-22 19:50:19.438258 2023-02-22 20:17:26.769978 40 32940 +6182 4176 0 2023-02-22 19:35:01.015684 2023-02-22 19:44:12.762839 37 1033 +6181 4175 0 2023-02-22 18:17:16.08654 2023-02-22 19:30:15.142541 37 8330 +6180 4174 0 2023-02-22 13:19:21.597705 2023-02-22 17:40:07.911041 37 29999 +6179 4173 0 2023-02-22 11:10:01.735707 2023-02-22 13:16:43.676229 39 100888 +6178 4172 0 2023-02-22 10:20:49.512328 2023-02-22 11:06:30.990862 39 39588 +6177 4171 0 2023-02-21 23:24:19.957724 2023-02-22 10:16:15.623485 39 574642 +6176 4170 0 2023-02-21 23:16:23.046331 2023-02-21 23:18:11.413311 39 748 +6175 4169 0 2023-02-20 15:19:51.181516 2023-02-21 20:24:29.716468 39 1536351 +6174 4168 0 2023-02-17 02:12:33.053476 2023-02-20 15:17:35.402033 39 4413132 +6173 4167 0 2023-02-17 02:03:38.070346 2023-02-17 02:06:23.089226 39 320 +6172 4166 0 2023-02-15 19:25:53.501293 2023-02-17 02:00:26.953557 37 213403 +6171 4165 0 2023-02-10 16:49:22.563155 38 +6170 4164 0 2023-02-09 22:11:11.930178 2023-02-10 16:10:28.692386 39 191490 +6169 4163 0 2023-02-09 21:51:49.591271 2023-02-09 21:58:45.805961 39 1058 +6168 4162 0 2023-02-09 21:46:00.65726 2023-02-09 21:47:31.570531 39 156 +6167 4161 0 2023-02-09 21:31:08.40636 2023-02-09 21:39:29.391031 39 1404 +6166 4160 0 2023-02-08 16:47:52.711752 2023-02-09 18:58:18.725942 39 281450 +6165 4159 0 2023-02-08 16:33:04.784027 2023-02-08 16:43:41.159592 39 1764 +6164 4158 0 2023-02-08 16:10:50.868275 2023-02-08 16:28:36.767335 39 3018 +6163 4157 0 2023-02-08 15:30:44.879351 2023-02-08 15:48:28.152852 39 3035 +6162 4156 0 2023-02-08 15:18:50.346444 2023-02-08 15:28:02.597268 39 1571 +6161 4155 0 2023-02-08 14:53:52.361056 2023-02-08 15:07:55.347219 39 2282 +6160 4154 0 2023-02-08 13:24:35.589757 2023-02-08 14:27:54.450432 39 11404 +6159 4153 1 2023-02-08 13:22:35.948361 39 +6158 4153 0 2023-02-08 13:11:54.606167 2023-02-08 13:21:58.082382 39 3117 +6157 4152 0 2023-02-08 12:44:11.465298 39 +6156 4151 0 2023-02-08 12:31:59.244727 2023-02-08 12:35:05.893094 39 4529 +6155 4150 0 2023-02-08 12:07:51.415123 39 +6154 4149 0 2023-02-08 11:55:19.404355 2023-02-08 12:06:08.38287 39 1738 +6153 4148 0 2023-02-08 01:08:58.875488 2023-02-08 11:21:12.277484 38 70728 +6152 4147 0 2023-02-08 00:02:34.35528 2023-02-08 01:05:43.090991 35 282769 +6151 4146 0 2023-02-07 22:49:00.436449 2023-02-07 23:57:04.566279 35 299919 +6150 4145 0 2023-02-07 20:41:15.934063 2023-02-07 22:40:44.46565 39 21118 +6149 4144 0 2023-02-07 19:25:03.923298 2023-02-07 20:05:20.472891 39 7282 +6148 4143 0 2023-02-07 17:44:19.005961 2023-02-07 18:19:48.573174 40 43014 +6147 4142 1 2023-02-07 17:40:37.524942 40 +6146 4142 0 2023-02-07 17:22:53.213132 2023-02-07 17:38:54.895431 40 16560 +6145 4141 0 2023-02-07 15:37:31.610725 2023-02-07 16:30:06.580941 39 9245 +6144 4140 0 2023-02-07 00:11:57.305946 2023-02-07 15:31:13.830908 39 162929 +6143 4139 0 2023-02-06 18:18:40.706537 2023-02-07 00:03:38.491675 39 60958 +6142 4138 0 2023-02-06 17:14:37.018034 2023-02-06 17:59:48.890576 39 7914 +6141 4137 0 2023-02-06 16:14:00.891953 2023-02-06 17:05:47.600344 39 9048 +6140 4136 0 2023-02-03 20:15:07.047254 2023-02-06 14:51:38.899452 39 2693778 +6139 4135 0 2023-02-03 17:13:46.269748 2023-02-03 20:06:57.519385 39 152237 +6138 4134 0 2023-02-03 06:54:43.09313 2023-02-03 17:06:40.360394 39 538459 +6137 4133 0 2023-02-03 06:40:25.988293 2023-02-03 06:41:01.198355 39 0 +6136 4132 0 2023-02-02 23:14:08.538009 2023-02-03 06:32:42.616191 39 385461 +6135 4131 0 2023-02-02 00:05:12.116374 2023-02-02 22:42:33.957496 39 767950 +6134 4130 0 2023-02-01 22:23:09.75885 2023-02-01 22:26:20.791897 39 2504 +6133 4129 0 2023-01-31 20:44:28.261857 2023-02-01 22:18:39.516657 34 1351469 +6132 4128 0 2023-01-31 20:13:55.767512 2023-01-31 20:17:31.204443 34 2459 +6131 4127 0 2023-01-31 20:08:41.99747 2023-01-31 20:10:15.92445 34 803 +6130 4126 0 2023-01-31 18:17:43.683633 2023-01-31 19:49:14.67355 34 80113 +6129 4125 0 2023-01-30 22:48:37.646069 2023-01-31 13:22:51.218308 34 767683 +6128 4124 0 2023-01-30 22:25:48.924813 2023-01-30 22:45:56.553317 34 6341 +6127 4123 0 2023-01-30 22:04:05.646526 2023-01-30 22:18:19.98641 34 12080 +6126 4122 0 2023-01-30 21:40:45.213631 2023-01-30 21:58:38.362305 34 13133 +6125 4121 0 2023-01-30 16:07:00.555776 2023-01-30 21:06:25.192773 34 250707 +6124 4120 0 2023-01-29 19:50:43.038636 2023-01-30 13:46:36.161814 34 946487 +6123 4119 0 2023-01-27 20:30:42.743584 2023-01-29 19:48:26.617263 34 2495896 +6122 4118 0 2023-01-27 20:22:43.703467 2023-01-27 20:25:57.694832 34 2480 +6121 4117 0 2023-01-27 19:12:14.746564 2023-01-27 20:18:40.378161 34 59012 +6120 4116 0 2023-01-27 18:37:01.618006 2023-01-27 19:07:25.707155 34 26607 +6119 4115 0 2023-01-26 21:40:11.965143 2023-01-27 18:35:17.755101 34 1076352 +6118 4114 0 2023-01-26 21:08:46.775591 2023-01-26 21:35:43.734017 34 9456 +6117 4113 0 2023-01-26 21:03:31.531773 2023-01-26 21:06:47.073353 34 111 +6116 4112 0 2023-01-26 20:38:54.252078 2023-01-26 21:00:50.591391 34 18293 +6115 4111 0 2023-01-25 23:42:06.916194 2023-01-26 20:36:07.36394 34 1083249 +6114 4110 0 2023-01-25 20:59:39.905203 2023-01-25 23:38:05.810973 38 19330 +6113 4109 0 2023-01-25 19:00:34.900915 2023-01-25 20:54:29.65151 35 517144 +6112 4108 0 2023-01-25 16:50:13.409681 2023-01-25 18:54:47.682534 35 566811 +6111 4107 0 2023-01-25 14:04:40.51685 2023-01-25 16:39:43.256537 38 18056 +6110 4106 0 2023-01-24 20:31:48.186905 2023-01-25 14:02:39.263886 34 896223 +6109 4105 0 2023-01-24 05:47:28.558339 2023-01-24 20:29:28.339595 34 739864 +6108 4104 0 2023-01-24 05:29:37.684336 2023-01-24 05:40:37.452423 34 8671 +6107 4103 0 2023-01-23 23:29:05.080976 2023-01-24 05:26:19.985299 34 314088 +6106 4102 0 2023-01-23 18:58:17.084441 2023-01-23 23:25:55.412554 34 227083 +6105 4101 0 2023-01-23 18:50:02.612742 2023-01-23 18:52:11.967054 34 1603 +6104 4100 0 2023-01-23 13:47:30.430129 2023-01-23 18:32:04.899273 34 232689 +6103 4099 0 2023-01-22 21:07:20.813791 2023-01-23 13:44:30.357827 34 878083 +6102 4098 0 2023-01-18 17:52:58.120663 2023-01-22 21:04:56.020711 34 5233056 +6101 4097 0 2023-01-17 23:02:40.262212 2023-01-18 17:29:51.692934 34 966838 +6100 4096 0 2023-01-17 22:43:35.377182 2023-01-17 22:56:04.164762 34 10298 +6099 4095 0 2023-01-17 19:21:41.293132 2023-01-17 22:33:41.384047 34 166786 +6098 4094 0 2023-01-17 18:49:41.844872 2023-01-17 19:19:04.845742 34 22506 +6097 4093 0 2023-01-17 18:04:55.934405 2023-01-17 18:36:46.199208 34 26975 +6096 4092 0 2023-01-17 14:42:38.43259 2023-01-17 18:02:47.068643 34 174858 +6095 4091 0 2023-01-15 15:34:49.626754 2023-01-17 14:38:54.915158 34 2474309 +6094 4090 0 2023-01-12 20:46:00.460189 2023-01-15 15:30:52.506674 34 3473785 +6093 4089 0 2023-01-12 19:16:01.417579 2023-01-12 20:35:12.655526 35 354772 +6092 4088 0 2023-01-12 18:02:25.697823 2023-01-12 19:10:28.6131 35 300138 +6091 4087 0 2023-01-05 18:11:08.65366 2023-01-12 17:26:42.972042 34 8704310 +6090 4086 0 2023-01-04 17:46:08.582511 2023-01-05 17:50:00.524158 34 1272127 +6089 4085 0 2022-12-30 20:45:50.809617 2023-01-04 17:41:45.818583 34 6215724 +6088 4084 0 2022-12-29 17:14:58.148615 2022-12-30 19:21:42.616233 34 1384490 +6087 4083 0 2022-12-27 10:29:41.475908 2022-12-29 17:09:14.197436 34 2932964 +6086 4082 0 2022-12-25 00:32:16.240453 2022-12-27 10:22:01.823657 34 3073193 +6085 4081 0 2022-12-25 00:05:16.327386 2022-12-25 00:30:47.245127 34 22068 +6084 4080 0 2022-12-23 13:44:00.002913 2022-12-25 00:03:40.025402 34 1814433 +6083 4079 0 2022-12-23 11:35:35.814054 2022-12-23 13:42:52.549841 37 13461 +6082 4078 0 2022-12-23 09:32:09.668332 2022-12-23 11:34:34.79063 38 13092 +6081 4077 0 2022-12-22 18:51:28.626393 2022-12-23 09:31:13.428084 34 778730 +6080 4076 0 2022-12-22 14:49:52.706796 2022-12-22 18:47:04.500505 34 1647 +6079 4075 0 2022-12-22 13:16:44.50733 2022-12-22 14:40:59.176618 34 585 +6078 4074 0 2022-12-22 13:08:02.664508 2022-12-22 13:15:22.29356 37 51 +6077 4073 0 2022-12-22 12:58:44.197397 2022-12-22 13:01:09.976211 37 191 +6076 4072 0 2022-12-22 12:52:43.455034 2022-12-22 12:57:14.846417 34 3208 +6075 4071 1 2022-12-22 12:46:27.589899 34 +6074 4071 0 2022-12-22 11:25:43.909182 2022-12-22 11:28:18.842037 34 184 +6073 4070 0 2022-12-22 11:07:25.300426 2022-12-22 11:16:42.946756 34 232 +6072 4069 1 2022-12-22 10:15:41.409996 34 +6071 4069 0 2022-12-22 10:08:39.82354 2022-12-22 10:14:37.933326 34 274 +6070 4068 0 2022-12-22 09:38:28.589155 2022-12-22 09:47:00.974951 34 213 +6069 4067 0 2022-12-22 09:15:59.982802 2022-12-22 09:27:08.622592 34 222 +6068 4066 0 2022-12-22 09:07:12.24781 2022-12-22 09:09:26.205889 34 10 +6067 4065 0 2022-12-22 08:49:04.713226 2022-12-22 08:59:39.61114 34 220 +6066 4064 0 2022-12-22 08:33:42.024537 2022-12-22 08:41:50.906483 34 74 +6065 4063 0 2022-12-21 22:53:14.660749 2022-12-22 08:31:41.704633 37 60429 +6064 4062 0 2022-12-21 22:41:46.958716 2022-12-21 22:44:05.814946 37 31 +6063 4061 0 2022-12-21 22:22:28.638083 2022-12-21 22:28:36.698812 37 49 +6062 4060 0 2022-12-21 16:47:08.905796 2022-12-21 22:21:05.673627 37 0 +6061 4059 0 2022-12-21 16:31:17.577287 2022-12-21 16:45:05.798971 37 0 +6060 4058 0 2022-12-21 16:14:06.183295 37 +6059 4057 0 2022-12-21 15:58:16.429182 2022-12-21 16:02:55.565608 37 0 +6058 4056 0 2022-12-21 12:33:16.470981 2022-12-21 13:32:37.002067 37 52244 +6057 4055 0 2022-12-19 16:31:20.411875 34 +6056 4054 0 2022-12-19 16:29:54.776302 2022-12-19 16:30:31.446544 34 0 +6055 4053 0 2022-12-16 21:03:57.031648 2022-12-19 15:45:25.092391 37 3538219 +6054 4052 0 2022-12-16 14:05:05.932462 2022-12-16 16:10:56.606952 37 110633 +6053 4051 0 2022-12-16 12:24:25.560595 2022-12-16 14:03:42.502184 38 87713 +6052 4050 0 2022-12-09 23:01:25.929437 34 +6051 4049 0 2022-12-09 19:28:45.607925 2022-12-09 19:30:48.058727 34 6 +6050 4048 0 2022-12-09 19:24:53.038408 2022-12-09 19:27:07.886151 34 8 +6049 4047 0 2022-12-09 16:54:21.177858 2022-12-09 18:51:38.454837 33 11807 +6048 4046 0 2022-12-09 15:12:22.18093 2022-12-09 16:53:16.466063 34 10557 +6047 4045 0 2022-12-09 15:10:41.393953 34 +6046 4044 0 2022-12-09 14:46:42.396981 2022-12-09 14:49:02.043124 33 0 +6045 4043 0 2022-12-09 14:40:06.046289 33 +6044 4042 0 2022-12-09 14:27:56.754078 2022-12-09 14:36:23.262964 34 38 +6043 4041 0 2022-12-09 14:19:10.26092 2022-12-09 14:26:30.317024 34 34 +6042 4040 0 2022-12-09 14:16:31.541533 2022-12-09 14:17:37.482818 34 6 +6041 4039 0 2022-12-09 14:11:10.213774 2022-12-09 14:13:02.502076 34 6 +6040 4038 0 2022-12-09 14:07:40.46729 2022-12-09 14:09:59.994397 34 10 +6039 4037 0 2022-12-09 13:47:48.598648 2022-12-09 14:04:50.285339 34 72 +6038 4036 0 2022-12-09 11:26:02.646251 2022-12-09 11:36:26.186876 34 8818 +6037 4035 0 2022-12-09 10:42:56.91139 2022-12-09 11:16:30.527322 34 29236 +6036 4034 0 2022-12-09 10:30:39.16032 2022-12-09 10:33:59.242926 34 2600 +6035 4033 0 2022-12-09 10:17:06.707598 2022-12-09 10:19:09.045839 34 833 +6034 4032 0 2022-12-08 22:04:05.044241 2022-12-09 10:14:12.548706 34 646345 +6033 4031 0 2022-12-08 21:40:57.773279 2022-12-08 21:54:48.677448 34 8955 +6032 4030 0 2022-12-07 21:45:18.042671 34 +6031 4029 0 2022-12-07 21:40:20.969874 2022-12-07 21:42:50.89907 34 1368 +6030 4028 0 2022-12-07 12:12:20.631325 2022-12-07 21:26:39.105445 34 469355 +6029 4027 0 2022-12-07 09:29:08.381518 2022-12-07 11:21:59.255006 34 65132 +6028 4026 0 2022-12-07 09:12:57.407451 2022-12-07 09:26:29.611633 34 1225 +6027 4025 0 2022-12-07 09:10:20.893091 2022-12-07 09:11:45.791385 34 809 +6026 4024 0 2022-12-07 08:53:48.582042 2022-12-07 09:05:30.09716 34 4552 +6025 4023 0 2022-12-06 19:08:18.373983 2022-12-07 08:22:07.26356 34 702670 +6024 4022 0 2022-12-06 18:40:54.611996 34 +6023 4021 0 2022-12-05 22:39:38.466351 34 +6022 4020 0 2022-12-05 22:07:59.446427 2022-12-05 22:37:35.986929 34 29325 +6021 4019 0 2022-12-05 17:45:09.290045 2022-12-05 21:34:36.719939 34 22246 +6020 4018 0 2022-12-05 17:28:55.255663 2022-12-05 17:43:08.745465 34 14827 +6019 4017 0 2022-12-05 17:07:42.64429 2022-12-05 17:26:22.871659 34 18731 +6018 4016 0 2022-12-05 16:36:05.782795 2022-12-05 17:06:17.465839 34 7620 +6017 4015 0 2022-12-05 15:50:33.577649 2022-12-05 16:16:57.416005 34 22721 +6016 4014 0 2022-12-05 14:59:22.998802 2022-12-05 15:34:15.680058 34 25500 +6015 4013 0 2022-12-05 14:56:20.199881 2022-12-05 14:57:08.033526 34 0 +6014 4012 0 2022-12-05 14:21:28.584711 2022-12-05 14:46:51.180766 34 2792 +6013 4011 0 2022-12-04 21:47:23.783209 2022-12-05 14:17:38.106539 34 257156 +6012 4010 0 2022-12-04 21:07:26.795337 2022-12-04 21:09:17.59684 34 4 +6011 4009 0 2022-12-03 00:36:45.121674 2022-12-03 10:24:31.278093 34 163670 +6010 4008 0 2022-12-03 00:29:55.236667 2022-12-03 00:31:38.757893 34 678 +6009 4007 0 2022-12-02 22:27:19.986941 2022-12-02 22:35:49.499115 34 13305 +6008 4006 0 2022-12-02 22:20:22.215262 2022-12-02 22:22:45.456827 34 1363 +6007 4005 0 2022-12-02 22:00:43.583676 2022-12-02 22:09:10.84349 34 5447 +6006 4004 0 2022-12-02 20:30:33.921937 2022-12-02 20:32:35.757357 33 968 +6005 4003 0 2022-12-02 20:19:00.078669 2022-12-02 20:23:49.821861 33 3888 +6004 4002 0 2022-12-02 20:13:35.333535 2022-12-02 20:16:03.35405 33 1952 +6003 4001 0 2022-12-02 19:44:16.152005 2022-12-02 20:04:10.417642 34 20930 +6002 4000 0 2022-12-02 19:27:51.973389 34 +6001 3999 0 2022-12-02 19:24:31.284212 33 dummy +5992 3869 0 2022-09-29 13:14:07 2022-09-29 13:15:22 3 64 +5991 3868 0 2022-09-29 13:12:39 3 0 +5990 3867 0 2022-09-02 18:26:05 7 0 +5989 3866 0 2022-09-02 18:14:00 2022-09-02 18:14:55 7 703 +5988 3865 0 2022-09-02 11:16:12 2022-09-02 13:02:29 3 20430 +5987 3864 0 2022-09-02 03:11:32 7 0 +5986 3863 0 2022-09-01 18:19:55 7 0 +5985 3862 0 2022-09-01 18:03:14 2022-09-01 18:16:12 7 21449 +5984 3861 0 2022-07-20 12:03:58.695822 2022-07-20 12:17:56.095833 3 0 121 +5983 3860 0 2022-07-20 11:29:49.375775 2022-07-20 11:33:14.582398 7 0 16 +5982 3859 0 2022-07-20 10:43:00.424139 2022-07-20 10:54:32.115758 7 0 50 +5981 3858 0 2022-07-19 17:00:34.916101 2022-07-19 17:23:29.30967 1 0 69682 +5980 3857 0 2022-07-19 16:35:45.592073 2022-07-19 16:50:28.451422 7 0 1251 +5979 3856 0 2022-07-17 22:30:50.776424 2022-07-19 06:21:00.345407 7 0 255127 +5978 3855 0 2022-07-17 00:29:01.010375 7 0 +5977 3854 0 2022-07-16 01:01:31.239493 7 0 +5976 3853 0 2022-07-15 21:57:41.221258 7 0 +5975 3852 0 2022-07-15 07:00:21.142389 7 0 +5974 3851 0 2022-07-15 06:33:01.851156 7 0 +5973 3850 0 2022-07-14 20:24:40.46671 7 0 +5972 3849 0 2022-07-12 23:02:10.211642 7 0 +5971 3848 0 2022-07-12 16:03:30.748457 7 0 +5970 3847 0 2022-07-12 15:42:09.261833 2022-07-12 15:58:04.961585 1 0 72039 +5969 3846 0 2022-07-12 15:17:24.06128 2022-07-12 15:33:05.564238 1 0 71038 +5968 3845 0 2022-07-10 01:41:50.381196 2022-07-12 15:09:05.957671 7 0 441102 +5967 3844 0 2022-07-09 04:47:59.967775 2022-07-10 01:35:26.475016 3 0 1618551 +5966 3843 0 2022-07-08 16:49:00.559972 2022-07-09 04:34:20.157441 3 0 1090433 +5965 3842 0 2022-07-07 17:04:51.838884 2022-07-08 16:42:47.079128 3 0 2112251 +5964 3841 0 2022-07-06 17:12:35.915809 2022-07-07 16:57:14.168934 3 0 2336181 +5963 3840 0 2022-07-05 16:27:03.911344 2022-07-06 17:03:32.398956 3 0 1414102 +5962 3839 0 2022-07-05 16:06:52.932085 2022-07-05 16:22:06.463188 1 0 67434 +5961 3838 0 2022-07-05 15:40:04.238585 2022-07-05 15:55:30.495418 1 0 68206 +5960 3837 0 2022-07-04 18:26:05.474875 2022-07-05 15:27:20.047127 3 0 1666335 +5959 3836 0 2022-07-04 00:20:00.383739 2022-07-04 18:17:29.744719 3 0 1758035 +5958 3835 0 2022-07-03 23:16:30.399726 3 0 +5957 3834 0 2022-07-02 19:04:09.867528 2022-07-03 23:07:59.690961 3 0 2642858 +5956 3833 0 2022-07-01 14:52:35.049774 2022-07-02 18:57:56.085775 3 0 2554727 +5955 3832 0 2022-06-30 16:11:14.024054 2022-07-01 14:45:32.993262 3 0 1048891 +5954 3831 0 2022-06-30 15:43:31.276228 2022-06-30 16:01:52.609843 1 0 81497 +5953 3830 0 2022-06-30 15:19:54.399358 2022-06-30 15:35:31.376339 1 0 69103 +5952 3829 0 2022-06-29 12:53:21.331688 2022-06-30 14:58:59.312556 3 0 2208050 +5951 3828 0 2022-06-28 16:38:06.732402 3 0 +5950 3827 0 2022-06-28 16:14:10.096483 2022-06-28 16:27:36.147706 1 0 66796 +5949 3826 0 2022-06-28 15:54:49.884128 2022-06-28 16:08:30.675517 1 0 67661 +5948 3825 0 2022-06-28 13:11:34.631453 2022-06-28 15:40:33.175915 3 0 255976 +5947 3824 0 2022-06-28 09:53:30.454813 2022-06-28 13:03:47.633202 7 0 22615 +5946 3823 0 2022-06-27 21:08:07.567391 2022-06-28 09:45:18.105492 3 0 595538 +5945 3822 0 2022-06-27 19:01:06.746948 2022-06-27 20:59:03.499342 3 0 96415 +5944 3821 0 2022-06-27 15:46:40.503814 2022-06-27 18:29:01.803797 3 0 129180 +5943 3820 0 2022-06-27 14:38:44.015288 2022-06-27 15:35:29.740534 3 0 44458 +5942 3819 0 2022-06-27 12:27:09.04126 2022-06-27 14:31:55.950134 7 0 14742 +5941 3818 0 2022-06-27 10:23:57.790469 2022-06-27 12:20:32.379056 3 0 133405 +5940 3817 0 2022-06-27 04:39:10.351884 2022-06-27 10:09:39.450106 3 0 515963 +5939 3816 0 2022-06-27 03:41:05.042366 2022-06-27 03:53:49.669427 3 0 19562 +5938 3815 0 2022-06-27 02:53:06.609941 2022-06-27 03:35:51.539263 3 0 66219 +5937 3814 0 2022-06-26 11:46:56.205263 2022-06-27 02:47:32.98256 3 0 1385742 +5936 3813 0 2022-06-26 11:27:44.992559 2022-06-26 11:36:33.983038 3 0 13250 +5935 3812 0 2022-06-26 11:08:30.556218 2022-06-26 11:11:29.101641 3 0 4129 +5934 3811 0 2022-06-25 16:56:40.777731 2022-06-26 10:54:42.399978 3 0 1676638 +5933 3810 0 2022-06-25 16:34:44.423475 2022-06-25 16:43:40.045124 3 0 13535 +5932 3809 0 2022-06-25 15:51:35.374279 2022-06-25 16:29:11.814163 3 0 58264 +5931 3808 0 2022-06-25 15:09:21.404592 2022-06-25 15:21:36.624969 3 0 1702 +5930 3807 0 2022-06-25 14:53:05.589122 2022-06-25 14:57:03.711044 3 0 4431 +5929 3806 0 2022-06-25 14:37:19.525936 2022-06-25 14:44:21.281463 3 0 9037 +5928 3805 0 2022-06-25 14:22:28.774194 2022-06-25 14:27:38.808187 3 0 3868 +5927 3804 0 2022-06-25 13:59:34.998175 2022-06-25 14:14:19.996492 3 0 11845 +5926 3803 0 2022-06-25 13:22:45.398503 2022-06-25 13:38:59.777667 3 0 24800 +5925 3802 0 2022-06-25 10:54:51.364199 2022-06-25 13:16:33.674848 7 0 17101 +5924 3801 0 2022-06-25 09:40:10.174295 7 0 +5923 3800 0 2022-06-24 18:57:00.39 2022-06-25 09:35:49.887599 3 0 1343892 +5922 3799 0 2022-06-24 17:24:49.668953 3 0 +5921 3798 0 2022-06-24 02:56:20.440054 2022-06-24 17:18:51.671131 3 0 1360074 +5920 3797 0 2022-06-24 01:32:00.435257 2022-06-24 02:50:52.942098 7 0 10668 +5919 3796 0 2022-06-23 19:46:38.234327 2022-06-24 01:24:55.593239 3 0 514497 +5918 3795 0 2022-06-23 10:15:09.140601 2022-06-23 19:42:07.664265 3 0 843723 +5917 3794 0 2022-06-23 00:37:10.47867 2022-06-23 10:08:56.549394 3 0 914000 +5916 3793 0 2022-06-22 23:10:39.024933 2022-06-23 00:29:43.87854 7 0 9363 +5915 3792 0 2022-06-22 22:37:30.486105 2022-06-22 23:04:17.408083 3 0 22470 +5914 3791 0 2022-06-22 17:06:51.711723 2022-06-22 22:31:21.058285 3 0 393111 +5913 3790 0 2022-06-22 16:45:28.422143 2022-06-22 17:00:04.899283 3 0 12440 +5912 3789 0 2022-06-22 16:13:04.260156 2022-06-22 16:38:38.585991 7 0 27808 +5911 3788 0 2022-06-22 09:24:01.39194 7 0 +5910 3787 0 2022-06-22 07:02:30.097076 7 0 +5909 3786 0 2022-06-22 00:12:30.434737 2022-06-22 06:55:41.672305 3 0 600516 +5908 3785 0 2022-06-21 23:32:40.494044 2022-06-22 00:04:00.575807 3 0 49233 +5907 3784 0 2022-06-21 22:24:00.590695 2022-06-21 23:28:11.837971 3 0 102064 +5906 3783 0 2022-06-21 18:25:50.201035 2022-06-21 22:19:10.869641 3 0 366969 +5905 3782 0 2022-06-21 17:48:40.747733 2022-06-21 18:21:42.456796 7 0 35503 +5904 3781 0 2022-06-21 17:31:21.086224 2022-06-21 17:45:38.658835 1 0 70396 +5903 3780 0 2022-06-21 17:15:16.674603 2022-06-21 17:28:34.085931 1 0 65676 +5902 3779 0 2022-06-21 14:06:40.677927 2022-06-21 17:09:35.876816 3 0 294596 +5901 3778 0 2022-06-21 10:11:56.807 2022-06-21 14:01:54.671951 3 0 366577 +5900 3777 0 2022-06-20 11:52:48.077727 2022-06-21 10:05:58.54245 3 0 1566253 +5899 3776 0 2022-06-19 11:16:34.899341 2022-06-20 11:43:26.44038 3 0 2126156 +5898 3775 0 2022-06-18 19:22:46.100033 2022-06-19 11:08:15.949007 3 0 733802 +5897 3774 0 2022-06-17 11:53:32.574948 2022-06-18 19:08:53.949157 3 0 2737123 +5896 3773 0 2022-06-17 06:42:38.103407 2022-06-17 11:06:06.525845 3 0 439789 +5895 3772 0 2022-06-17 06:33:07.871797 2022-06-17 06:33:57.853646 3 0 830 +5894 3771 0 2022-06-16 18:19:02.749008 2022-06-17 05:01:14.241537 3 0 1003436 +5893 3770 0 2022-06-16 18:14:59.167241 3 0 +5892 3769 0 2022-06-16 15:20:16.009534 2022-06-16 15:28:38.856196 3 0 14786 +5891 3768 0 2022-06-16 14:54:34.362522 2022-06-16 15:15:49.803996 1 0 94862 +5890 3767 0 2022-06-16 14:34:04.75667 2022-06-16 14:49:10.697077 1 0 66729 +5889 3766 0 2022-06-16 10:39:11.202784 2022-06-16 14:19:57.918738 3 0 326891 +5888 3765 0 2022-06-16 09:03:05.754919 2022-06-16 10:28:35.741379 3 0 74472 +5887 3764 0 2022-06-16 08:17:47.450549 2022-06-16 08:57:28.862155 7 0 4671 +5886 3763 0 2022-06-15 13:50:39.536489 2022-06-16 08:08:22.478526 3 0 1655819 +5885 3762 0 2022-06-15 09:16:34.616659 2022-06-15 13:45:58.085004 7 0 31926 +5884 3761 0 2022-06-15 08:43:05.908479 7 0 +5883 3760 0 2022-06-14 19:17:54.931144 2022-06-15 08:37:08.450257 3 0 1150282 +5882 3759 0 2022-06-14 19:10:09.62504 2022-06-14 19:14:17.336706 7 0 4208 +5881 3758 0 2022-06-14 10:14:41.650217 2022-06-14 19:04:48.375082 3 0 724702 +5880 3757 0 2022-06-14 10:01:28.853673 2022-06-14 10:01:58.766573 3 0 1012 +5879 3756 0 2022-06-13 09:02:26.692654 2022-06-14 09:49:09.493378 3 0 2148188 +5878 3755 0 2022-06-13 08:46:41.52281 2022-06-13 08:58:54.152724 7 0 7419 +5877 3754 0 2022-06-12 21:54:12.995253 2022-06-13 08:39:29.381762 3 0 987266 +5876 3753 0 2022-06-12 20:59:34.155087 2022-06-12 21:50:13.302063 7 0 29402 +5875 3752 0 2022-06-12 11:08:35.216796 2022-06-12 20:50:47.311523 3 0 883984 +5874 3751 0 2022-06-11 19:56:24.902818 2022-06-12 11:02:33.851004 3 0 1445461 +5873 3750 0 2022-06-10 18:08:27.532851 2022-06-11 19:50:08.973881 3 0 2398621 +5872 3749 0 2022-06-10 17:48:09.52781 2022-06-10 17:59:49.075462 3 0 19827 +5871 3748 0 2022-06-10 17:39:19.079074 2022-06-10 17:41:52.676983 8 0 2593 +5870 3747 0 2022-06-10 17:03:29.862311 2022-06-10 17:29:41.031954 3 0 45306 +5869 3746 0 2022-06-10 16:41:37.475101 2022-06-10 16:59:04.139264 1 0 77336 +5868 3745 0 2022-06-10 16:19:22.393605 2022-06-10 16:35:10.948385 1 0 70045 +5867 3744 0 2022-06-10 10:41:07.025315 2022-06-10 16:05:29.06603 3 0 570467 +5866 3743 0 2022-06-09 12:36:10.625914 2022-06-10 10:32:23.949354 3 0 2112241 +5865 3742 0 2022-06-08 10:34:25.685417 2022-06-09 12:22:58.432612 3 0 2217873 +5864 3741 0 2022-06-07 11:14:13.162691 2022-06-08 10:26:57.141228 3 0 1843810 +5863 3740 0 2022-06-07 11:09:30.683484 2022-06-07 11:10:55.462933 8 0 1333 +5862 3739 0 2022-06-07 10:53:44.580876 2022-06-07 10:54:41.67657 3 0 1047 +5861 3738 0 2022-06-07 02:28:28.762781 2022-06-07 10:48:13.66206 3 0 796077 +5860 3737 0 2022-06-06 19:19:04.809797 2022-06-07 02:23:42.149954 3 0 664633 +5859 3736 0 2022-06-06 19:11:59.961728 2022-06-06 19:13:26.91718 8 0 2173 +5858 3735 0 2022-06-06 19:07:48.05867 2022-06-06 19:08:38.821715 3 0 841 +5857 3734 0 2022-06-06 19:02:30.0579 2022-06-06 19:03:03.473951 8 0 468 +5856 3733 0 2022-06-06 18:56:39.56985 2022-06-06 18:57:27.768482 3 0 686 +5855 3732 0 2022-06-06 15:24:43.36465 2022-06-06 18:52:11.624245 3 0 324639 +5854 3731 0 2022-06-06 13:49:01.657827 2022-06-06 15:20:49.948603 7 0 71168 +5853 3730 0 2022-06-06 13:41:21.831194 2022-06-06 13:43:40.273301 3 0 42 +5852 3729 0 2022-06-06 12:20:28.836201 2022-06-06 13:24:23.467802 8 0 78871 +5851 3728 0 2022-06-06 11:40:21.093769 2022-06-06 12:05:18.604905 8 0 30590 +5850 3727 0 2022-06-06 09:51:46.535463 7 0 +5849 3726 0 2022-06-06 08:47:23.916685 7 0 +5848 3725 0 2022-06-05 16:53:38.54542 2022-06-06 08:39:44.100609 3 0 1316221 +5847 3724 0 2022-06-04 16:38:54.384278 2022-06-05 16:46:13.533196 3 0 2297842 +5846 3723 0 2022-06-04 11:30:09.609029 2022-06-04 16:32:27.398834 3 0 450432 +5845 3722 0 2022-06-04 09:15:15.807179 2022-06-04 11:25:43.449009 7 0 127336 +5844 3721 0 2022-06-04 09:01:26.810419 2022-06-04 09:10:58.252673 8 0 10404 +5843 3720 0 2022-06-04 08:43:12.30519 2022-06-04 08:49:24.457647 7 0 711 +5842 3719 0 2022-06-04 08:28:25.053826 2022-06-04 08:34:18.978747 8 0 6333 +5841 3718 0 2022-06-04 07:53:02.280897 7 0 +5840 3717 0 2022-06-03 17:03:13.034024 2022-06-04 07:44:35.542093 3 0 1384863 +5839 3716 0 2022-06-03 15:35:23.252125 3 0 +5838 3715 0 2022-06-03 15:07:58.241674 2022-06-03 15:27:49.83403 3 0 30762 +5837 3714 0 2022-06-03 14:53:13.164441 2022-06-03 14:54:51.366019 8 0 1596 +5836 3713 0 2022-06-03 14:40:00.355059 2022-06-03 14:45:09.720927 3 0 7659 +5835 3712 0 2022-06-03 14:34:31.029924 2022-06-03 14:36:13.180432 8 0 1634 +5834 3711 0 2022-06-03 14:22:00.701195 2022-06-03 14:23:49.619055 3 0 2806 +5833 3710 0 2022-06-03 14:16:46.768554 2022-06-03 14:18:42.800566 8 0 1882 +5832 3709 0 2022-06-03 13:52:03.09095 2022-06-03 14:09:03.247685 3 0 31985 +5831 3708 0 2022-06-03 07:35:17.694296 2022-06-03 13:47:52.535743 3 0 420461 +5830 3707 0 2022-06-03 07:30:47.082537 2022-06-03 07:32:11.273358 8 0 1272 +5829 3706 0 2022-06-03 07:07:28.050433 2022-06-03 07:12:15.610975 3 0 3113 +5828 3705 0 2022-06-03 06:36:11.868218 2022-06-03 06:45:51.174251 3 0 4497 +5827 3704 0 2022-06-03 06:23:11.78434 2022-06-03 06:31:59.976409 3 0 5935 +5826 3703 0 2022-06-03 06:15:13.992848 2022-06-03 06:16:47.465966 3 0 859 +5825 3702 0 2022-06-03 06:09:19.395219 2022-06-03 06:11:55.70969 8 0 2673 +5824 3701 0 2022-06-03 06:02:42.69026 3 0 +5823 3700 0 2022-06-03 05:57:45.832284 2022-06-03 05:58:27.570562 3 0 250 +5822 3699 0 2022-06-03 05:53:33.345065 2022-06-03 05:54:56.676213 8 0 1227 +5821 3698 0 2022-06-03 05:48:38.331042 2022-06-03 05:49:23.97257 3 0 289 +5820 3697 0 2022-06-03 05:45:01.317986 2022-06-03 05:45:40.773462 8 0 498 +5819 3696 0 2022-06-03 05:41:01.073905 2022-06-03 05:41:43.063851 3 0 166 +5818 3695 0 2022-06-02 13:32:42.451743 2022-06-03 05:36:39.787826 3 0 1425329 +5817 3694 0 2022-06-02 13:26:51.381496 2022-06-02 13:29:21.568019 8 0 2481 +5816 3693 0 2022-06-02 13:18:49.697859 2022-06-02 13:19:45.188525 3 0 444 +5815 3692 0 2022-06-02 13:15:03.244617 2022-06-02 13:15:54.266222 8 0 632 +5814 3691 0 2022-06-02 13:09:00.88303 2022-06-02 13:10:30.962056 3 0 835 +5813 3690 0 2022-06-02 11:47:11.71576 3 0 +5812 3689 0 2022-06-01 19:02:03.980915 2022-06-02 11:39:53.82679 3 0 1368216 +5811 3688 0 2022-06-01 11:48:54.273613 2022-06-01 18:55:49.958719 3 0 619339 +5810 3687 0 2022-06-01 11:23:21.087937 2022-06-01 11:43:01.468739 1 0 87485 +5809 3686 0 2022-06-01 10:52:25.858187 2022-06-01 11:07:00.096458 1 0 64268 +5808 3685 0 2022-05-31 22:19:37.094205 2022-06-01 10:46:50.757184 3 0 534337 +5807 3684 0 2022-05-31 21:11:51.206118 3 0 +5806 3683 0 2022-05-31 21:06:56.782493 2022-05-31 21:08:17.608419 8 0 1232 +5805 3682 0 2022-05-31 21:01:45.566812 2022-05-31 21:02:47.090323 3 0 580 +5804 3681 0 2022-05-31 19:02:44.585391 2022-05-31 20:53:07.526214 3 0 97489 +5803 3680 0 2022-05-31 16:57:15.962097 3 0 +5802 3679 0 2022-05-31 15:26:15.580103 2022-05-31 16:50:29.80593 3 0 53662 +5801 3678 0 2022-05-31 13:44:47.391443 2022-05-31 15:21:03.951643 7 0 11667 +5800 3677 0 2022-05-31 13:38:33.398836 2022-05-31 13:41:24.330058 8 0 3194 +5799 3676 0 2022-05-31 13:30:36.836921 2022-05-31 13:33:51.60592 7 0 348 +5798 3675 0 2022-05-31 10:22:47.985414 2022-05-31 13:23:51.553665 3 0 225905 +5797 3674 0 2022-05-31 10:17:20.541071 2022-05-31 10:18:17.764928 8 0 1232 +5796 3673 0 2022-05-31 10:10:43.866774 2022-05-31 10:12:07.971838 3 0 1590 +5795 3672 0 2022-05-31 03:34:42.443583 2022-05-31 10:05:21.179848 3 0 586482 +5794 3671 0 2022-05-31 03:05:31.050845 2022-05-31 03:30:47.594837 7 0 12359 +5793 3670 0 2022-05-30 09:14:37.030939 2022-05-31 03:00:14.597395 3 0 1558312 +5792 3669 0 2022-05-30 09:06:09.554658 3 0 +5791 3668 0 2022-05-29 17:03:39.21835 2022-05-30 09:01:17.278163 3 0 1460345 +5790 3667 0 2022-05-28 21:17:54.482725 2022-05-29 16:55:33.409406 3 0 1830632 +5789 3666 0 2022-05-28 20:50:41.208979 2022-05-28 21:13:03.111123 3 0 34242 +5788 3665 0 2022-05-28 20:32:55.14218 3 0 +5787 3664 0 2022-05-28 20:23:00.794156 2022-05-28 20:24:22.734871 3 0 1485 +5786 3663 0 2022-05-28 13:55:49.738147 2022-05-28 20:16:26.854144 3 0 591956 +5785 3662 0 2022-05-28 00:44:17.170315 2022-05-28 13:49:38.623896 3 0 1149874 +5784 3661 0 2022-05-27 23:07:36.099891 2022-05-28 00:35:48.545148 3 0 57199 +5783 3660 0 2022-05-27 22:22:35.296931 2022-05-27 22:59:52.905203 3 0 58485 +5782 3659 0 2022-05-27 19:08:55.60291 2022-05-27 22:14:37.758206 3 0 291053 +5781 3658 0 2022-05-27 15:06:25.943039 2022-05-27 19:02:07.104204 3 0 368805 +5780 3657 0 2022-05-27 12:39:29.319826 2022-05-27 14:59:22.746491 3 0 233826 +5779 3656 0 2022-05-27 12:32:37.109176 2022-05-27 12:34:53.982477 3 0 3332 +5778 3655 0 2022-05-27 12:06:15.462372 2022-05-27 12:28:43.08169 8 0 24993 +5777 3654 0 2022-05-27 08:27:01.71936 2022-05-27 11:59:59.555767 8 0 552817 +5776 3653 0 2022-05-26 15:02:29.358512 2022-05-27 08:20:29.034128 3 0 1713063 +5775 3652 0 2022-05-26 14:22:53.913026 2022-05-26 14:54:53.476592 3 0 55927 +5774 3651 0 2022-05-26 14:14:26.100178 2022-05-26 14:17:04.682037 3 0 4073 +5773 3650 0 2022-05-26 13:43:56.686228 2022-05-26 14:04:02.247105 3 0 34836 +5772 3649 0 2022-05-25 13:53:31.240352 2022-05-26 13:19:49.790233 3 0 2418411 +5771 3648 0 2022-05-25 13:32:52.928179 2022-05-25 13:47:25.374274 1 0 64305 +5770 3647 0 2022-05-25 13:13:23.697132 2022-05-25 13:28:21.800282 1 0 66139 +5769 3646 0 2022-05-25 09:34:52.089833 2022-05-25 13:01:23.755099 3 0 371591 +5768 3645 0 2022-05-25 09:26:03.383829 3 0 +5767 3644 0 2022-05-24 17:08:00.272853 2022-05-25 09:15:15.153333 3 0 1668940 +5766 3643 0 2022-05-24 08:39:19.111519 2022-05-24 17:02:44.164727 8 0 2495118 +5765 3642 0 2022-05-24 07:11:01.637197 2022-05-24 08:30:17.660086 7 0 9542 +5764 3641 0 2022-05-23 19:13:10.513804 2022-05-24 07:01:18.18308 3 0 1119074 +5763 3640 0 2022-05-23 18:42:34.430957 2022-05-23 19:08:12.596892 7 0 6438 +5762 3639 0 2022-05-23 05:56:53.161763 2022-05-23 18:33:35.031066 3 0 1225695 +5761 3638 0 2022-05-22 09:10:27.227926 2022-05-23 05:53:03.612284 3 0 1933039 +5760 3637 0 2022-05-21 10:58:24.318167 2022-05-22 09:06:18.579427 3 0 2140418 +5759 3636 0 2022-05-21 10:36:39.08112 2022-05-21 10:53:53.849192 3 0 28175 +5758 3635 0 2022-05-21 10:23:45.627409 2022-05-21 10:28:33.313315 3 0 7286 +5757 3634 0 2022-05-21 06:59:41.918624 2022-05-21 10:19:51.268648 3 0 326881 +5756 3633 0 2022-05-20 14:53:11.605794 3 0 +5755 3632 0 2022-05-20 13:20:47.755647 3 0 +5754 3631 0 2022-05-20 12:55:37.061697 3 0 +5753 3630 0 2022-05-20 12:37:27.953357 2022-05-20 12:48:49.482068 3 0 18654 +5752 3629 0 2022-05-20 12:29:09.749815 2022-05-20 12:30:02.164448 3 0 888 +5751 3628 0 2022-05-20 10:15:04.168951 2022-05-20 12:24:16.096152 3 0 181696 +5750 3627 0 2022-05-19 17:25:54.166792 2022-05-20 10:08:25.323617 3 0 1402155 +5749 3626 0 2022-05-18 13:31:56.963788 2022-05-19 17:21:12.20804 3 0 2623606 +5748 3625 0 2022-05-18 11:28:50.518879 3 0 +5747 3624 0 2022-05-18 07:37:37.803749 3 0 +5746 3623 0 2022-05-18 01:16:07.042887 3 0 +5745 3622 0 2022-05-17 19:43:43.954014 2022-05-17 20:20:43.878974 3 0 58281 +5744 3621 0 2022-05-17 19:20:32.267741 2022-05-17 19:38:15.32303 3 0 27748 +5743 3620 0 2022-05-17 19:12:33.865191 3 0 +5742 3619 0 2022-05-17 19:00:06.242904 2022-05-17 19:05:52.70423 3 0 8622 +5741 3618 0 2022-05-17 18:41:01.036718 2022-05-17 18:43:15.770069 3 0 3045 +5740 3617 0 2022-05-17 18:15:31.98924 2022-05-17 18:25:59.586098 3 0 16139 +5739 3616 0 2022-05-17 16:37:19.435828 3 0 +5738 3615 0 2022-05-17 16:00:25.84627 2022-05-17 16:19:24.186921 3 0 30305 +5737 3614 0 2022-05-17 15:47:43.668291 2022-05-17 15:53:00.663864 3 0 8506 +5736 3613 0 2022-05-17 14:40:18.592303 3 0 +5735 3612 0 2022-05-17 10:52:01.533792 2022-05-17 14:33:41.92279 3 0 384408 +5734 3611 0 2022-05-17 07:31:36.47364 2022-05-17 10:44:55.976652 3 0 363479 +5733 3610 0 2022-05-17 07:19:39.650861 2022-05-17 07:20:24.280141 3 0 2069 +5732 3609 0 2022-05-17 07:17:45.937628 3 0 +5731 3608 0 2022-05-17 07:11:47.583617 2022-05-17 07:13:09.61199 3 0 1661 +5730 3607 0 2022-05-17 05:21:22.918993 2022-05-17 05:22:45.481755 3 0 1639 +5729 3606 0 2022-05-17 04:26:03.945971 2022-05-17 04:30:24.964149 3 0 6443 +5728 3605 0 2022-05-17 04:07:14.779815 2022-05-17 04:15:23.313319 3 0 12288 +5727 3604 0 2022-05-16 21:04:31.183333 3 0 +5726 3603 0 2022-05-16 20:45:50.116617 2022-05-16 20:59:58.174892 1 0 69862 +5725 3602 0 2022-05-16 20:27:37.331323 2022-05-16 20:40:45.645277 1 0 64391 +5724 3601 0 2022-05-16 09:04:27.125286 2022-05-16 20:20:44.126277 3 0 933255 +5723 3600 0 2022-05-16 07:18:07.135473 2022-05-16 08:56:18.686969 7 0 11823 +5722 3599 0 2022-05-15 18:33:13.549614 2022-05-16 07:13:55.144144 3 0 548976 +5721 3598 0 2022-05-14 20:55:41.380601 3 0 +5720 3597 0 2022-05-14 11:19:48.467413 3 0 +5719 3596 0 2022-05-13 23:05:48.214943 3 0 +5718 3595 0 2022-05-13 15:03:36.95043 3 0 +5717 3594 0 2022-05-13 14:57:28.314318 2022-05-13 15:00:52.799848 3 0 4756 +5716 3593 0 2022-05-13 14:51:59.747124 2022-05-13 14:54:33.222611 3 0 3308 +5715 3592 0 2022-05-13 14:43:48.586665 2022-05-13 14:48:01.53591 3 0 5841 +5714 3591 0 2022-05-13 13:53:41.961997 2022-05-13 14:27:28.248763 3 0 51283 +5713 3590 0 2022-05-13 12:35:10.008694 2022-05-13 13:42:32.660587 3 0 103468 +5712 3589 0 2022-05-13 10:11:49.528606 2022-05-13 11:38:15.201807 3 0 112744 +5711 3588 0 2022-05-13 02:59:06.087429 2022-05-13 10:08:18.911984 7 0 63639 +5710 3587 0 2022-05-13 02:03:02.291128 7 0 +5709 3586 0 2022-05-12 23:09:32.90719 2022-05-13 01:58:06.278557 3 0 67408 +5708 3585 0 2022-05-12 12:49:50.664483 3 0 +5707 3584 0 2022-05-12 12:31:52.157639 2022-05-12 12:45:16.710697 7 0 2087 +5706 3583 0 2022-05-12 10:46:24.210786 2022-05-12 11:08:35.54361 8 0 112690 +5705 3582 0 2022-05-12 10:19:38.881779 2022-05-12 10:42:26.131218 8 0 107856 +5704 3581 0 2022-05-12 09:57:24.686873 2022-05-12 10:16:24.656035 8 0 102509 +5703 3580 0 2022-05-12 09:33:17.022003 2022-05-12 09:53:53.785752 8 0 104491 +5702 3579 0 2022-05-12 09:06:15.945441 2022-05-12 09:25:01.872295 8 0 82889 +5701 3578 0 2022-05-12 06:17:17.704144 2022-05-12 08:53:48.876294 7 0 50700 +5700 3577 0 2022-05-11 14:32:10.459297 2022-05-12 06:13:02.387908 3 0 1451741 +5699 3576 0 2022-05-10 16:55:45.859795 2022-05-11 14:28:04.890232 3 0 1977856 +5698 3575 0 2022-05-10 16:46:21.719539 2022-05-10 16:50:46.991224 3 0 6180 +5697 3574 0 2022-05-10 15:06:44.807058 3 0 +5696 3573 0 2022-05-09 10:33:09.281983 2022-05-10 11:35:53.515592 3 0 2094197 +5695 3572 0 2022-05-08 19:47:13.362067 3 0 +5694 3571 0 2022-05-08 15:41:31.845085 3 0 +5693 3570 0 2022-05-07 17:04:28.775972 2022-05-08 15:37:32.97836 3 0 2085000 +5692 3569 0 2022-05-06 17:08:09.850693 2022-05-07 16:59:56.700234 3 0 2207510 +5691 3568 0 2022-05-05 22:30:07.720903 2022-05-06 17:02:16.050932 3 0 1532675 +5690 3567 0 2022-05-05 20:50:48.20196 3 0 +5689 3566 0 2022-05-05 20:33:24.338958 2022-05-05 20:47:38.989144 1 0 63300 +5688 3565 0 2022-05-05 20:14:08.567908 2022-05-05 20:28:52.294038 1 0 65330 +5687 3564 0 2022-05-05 13:19:05.462059 2022-05-05 20:10:25.21367 3 0 492100 +5686 3563 0 2022-05-05 12:19:52.693313 2022-05-05 12:20:24.168814 3 0 398 +5685 3562 0 2022-05-05 12:07:32.255491 2022-05-05 12:08:26.934424 3 0 874 +5684 3561 0 2022-05-05 12:00:25.738523 2022-05-05 12:02:37.663701 3 0 2880 +5683 3560 0 2022-05-05 11:54:53.168288 2022-05-05 11:55:27.77341 3 0 487 +5682 3559 0 2022-05-05 11:49:37.405408 2022-05-05 11:50:46.341768 3 0 1362 +5681 3558 0 2022-05-05 11:27:11.813391 2022-05-05 11:29:51.556257 3 0 4388 +5680 3557 0 2022-05-05 11:25:08.056704 3 0 +5679 3556 0 2022-05-05 11:23:46.722648 3 0 +5678 3555 0 2022-05-05 11:18:56.626619 2022-05-05 11:19:33.88813 3 0 266 +5677 3554 0 2022-05-05 10:41:28.784935 2022-05-05 10:57:25.67646 3 0 13980 +5676 3553 0 2022-05-05 10:06:10.017978 2022-05-05 10:07:34.573062 3 0 203 +5675 3552 0 2022-05-05 10:02:22.409049 2022-05-05 10:03:04.989366 3 0 514 +5674 3551 0 2022-05-05 09:57:39.223282 2022-05-05 09:58:40.579246 3 0 1074 +5673 3550 0 2022-05-05 09:41:29.412464 2022-05-05 09:42:42.863715 3 0 1353 +5672 3549 0 2022-05-05 09:22:00.298392 2022-05-05 09:22:42.663301 3 0 615 +5671 3548 0 2022-05-05 09:12:23.722285 2022-05-05 09:13:26.272201 3 0 3269 +5670 3547 0 2022-05-05 08:58:30.755993 2022-05-05 09:00:55.273455 3 0 3283 +5669 3546 0 2022-05-05 08:39:03.026192 2022-05-05 08:41:15.472738 3 0 2830 +5668 3545 0 2022-05-05 08:25:36.889491 2022-05-05 08:31:10.563889 3 0 4436 +5667 3544 0 2022-05-04 19:22:47.086772 2022-05-05 08:21:05.244538 3 0 1196362 +5666 3543 0 2022-05-04 18:56:01.053033 2022-05-04 19:16:12.472002 3 0 30575 +5665 3542 0 2022-05-04 18:08:49.809611 2022-05-04 18:39:27.46128 3 0 46700 +5664 3541 0 2022-05-04 17:53:27.568643 2022-05-04 17:55:23.248556 3 0 2398 +5663 3540 0 2022-05-04 17:27:04.444698 3 0 +5662 3539 0 2022-05-04 16:17:59.75898 3 0 +5661 3538 0 2022-05-04 14:51:05.050905 3 0 +5660 3537 0 2022-05-04 10:40:40.320675 2022-05-04 14:38:45.394145 3 0 343821 +5659 3536 0 2022-05-04 10:20:17.51663 2022-05-04 10:28:36.543022 3 0 2951 +5658 3535 0 2022-05-04 08:32:53.227736 2022-05-04 10:01:07.839341 3 0 128951 +5657 3534 0 2022-05-03 23:11:56.516647 2022-05-04 08:29:38.814402 3 0 815874 +5656 3533 0 2022-05-03 22:49:19.007813 2022-05-03 23:02:51.997072 3 0 19232 +5655 3532 0 2022-05-03 22:43:48.713984 2022-05-03 22:44:56.047998 3 0 1229 +5654 3531 0 2022-05-03 17:02:53.853717 3 0 +5653 3530 0 2022-05-03 10:39:52.824938 2022-05-03 16:56:53.173751 3 0 564989 +5652 3529 0 2022-05-03 08:41:31.352817 2022-05-03 10:01:13.068749 3 0 124092 +5651 3528 0 2022-05-03 06:55:02.808711 2022-05-03 07:56:22.266345 3 0 96049 +5650 3527 0 2022-05-03 06:38:03.771096 2022-05-03 06:42:47.196528 3 0 6762 +5649 3526 0 2022-05-02 09:06:44.879108 2022-05-03 06:35:22.834951 3 0 2209064 +5648 3525 0 2022-05-01 02:57:55.828774 2022-05-02 09:03:02.769946 3 0 3192352 +5647 3524 0 2022-05-01 01:52:02.200638 3 0 +5646 3523 0 2022-04-30 09:38:12.396339 3 0 +5645 3522 0 2022-04-29 12:02:06.82471 2022-04-30 09:34:54.495629 3 0 2143834 +5644 3521 0 2022-04-29 11:47:52.989924 2022-04-29 11:58:54.327119 3 0 19696 +5643 3520 0 2022-04-29 11:43:22.157745 2022-04-29 11:44:06.041372 3 0 615 +5642 3519 0 2022-04-29 11:20:28.886365 2022-04-29 11:39:16.880125 3 0 34314 +5641 3518 0 2022-04-29 11:14:49.924516 2022-04-29 11:16:30.988447 3 0 2565 +5640 3517 0 2022-04-29 10:14:39.724908 2022-04-29 11:06:57.113579 3 0 140837 +5639 3516 0 2022-04-29 09:34:39.759847 3 0 +5638 3515 0 2022-04-29 09:29:38.049517 3 0 +5637 3514 0 2022-04-29 09:29:09.351355 3 0 +5636 3513 0 2022-04-29 08:58:29.81432 2022-04-29 09:01:46.516179 3 0 5551 +5635 3512 0 2022-04-29 08:50:28.93242 2022-04-29 08:55:22.274706 3 0 8479 +5634 3511 0 2022-04-29 08:30:05.053859 2022-04-29 08:34:56.858382 3 0 12913 +5633 3510 0 2022-04-29 08:27:16.847079 3 0 +5632 3509 0 2022-04-29 07:53:29.293674 2022-04-29 08:09:35.48356 3 0 26518 +5631 3508 0 2022-04-29 07:12:08.255503 2022-04-29 07:15:53.512231 3 0 5371 +5630 3507 0 2022-04-29 06:56:18.714934 2022-04-29 07:01:10.182577 3 0 7065 +5629 3506 0 2022-04-29 02:40:40.118383 2022-04-29 06:52:38.203587 3 0 395295 +5628 3505 0 2022-04-29 02:27:18.628761 2022-04-29 02:37:55.208669 3 0 16195 +5627 3504 0 2022-04-29 01:23:11.676432 3 0 +5626 3503 0 2022-04-29 01:00:05.999983 2022-04-29 01:18:19.784846 3 0 28115 +5625 3502 0 2022-04-29 00:44:48.674548 3 0 +5624 3501 0 2022-04-29 00:37:03.641123 2022-04-29 00:37:45.87812 3 0 642 +5623 3500 0 2022-04-29 00:31:56.602572 2022-04-29 00:32:55.241441 3 0 1013 +5622 3499 0 2022-04-28 21:36:26.746912 3 0 +5621 3498 0 2022-04-28 09:36:21.877333 3 0 +5620 3497 0 2022-04-26 18:19:30.591992 2022-04-28 09:33:32.125477 3 0 3693416 +5619 3496 0 2022-04-26 18:02:34.589582 2022-04-26 18:15:37.450903 1 0 63786 +5618 3495 0 2022-04-26 17:44:24.368571 2022-04-26 17:58:10.842591 1 0 67274 +5617 3494 0 2022-04-26 12:22:47.995457 2022-04-26 17:40:30.205051 3 0 499407 +5616 3493 0 2022-04-26 10:18:03.38394 3 0 +5615 3492 0 2022-04-26 09:27:54.804444 2022-04-26 10:10:50.577378 3 0 66802 +5614 3491 0 2022-04-24 13:00:51.983864 2022-04-26 09:23:56.236055 3 0 4278727 +5613 3490 0 2022-04-23 20:10:42.945229 3 0 +5612 3489 0 2022-04-22 21:20:56.415317 2022-04-23 20:06:48.043381 3 0 2139655 +5611 3488 0 2022-04-22 12:13:05.393433 3 0 +5610 3487 0 2022-04-22 08:20:47.995886 3 0 +5609 3486 0 2022-04-22 08:10:00.73417 3 0 +5608 3485 0 2022-04-22 06:44:10.508954 2022-04-22 07:43:48.82452 3 0 115355 +5607 3484 0 2022-04-22 06:29:14.713864 3 0 +5606 3483 0 2022-04-22 01:34:51.870168 2022-04-22 06:22:40.389169 3 0 451381 +5605 3482 0 2022-04-21 18:35:59.858392 3 0 +5604 3481 0 2022-04-20 10:55:11.587231 2022-04-21 18:32:40.844248 3 +5603 3480 0 2022-04-20 10:49:06.514867 3 0 +5602 3479 0 2022-04-20 10:45:03.600743 3 0 +5601 3478 0 2022-04-20 09:57:30.832366 2022-04-20 10:42:36.170735 3 0 70736 +5600 3477 0 2022-04-18 19:29:25.776922 2022-04-20 09:25:59.691669 3 0 3544581 +5599 3476 0 2022-04-18 11:28:48.074544 3 0 +5598 3475 0 2022-04-18 05:17:14.185869 3 0 +5597 3474 0 2022-04-17 16:02:36.492694 3 0 +5596 3473 0 2022-04-17 15:47:12.07608 3 0 +5595 3472 0 2022-04-17 12:57:15.34639 3 0 +5594 3471 0 2022-04-16 17:18:50.952241 3 0 +5593 3470 0 2022-04-15 22:02:48.197132 2022-04-16 17:16:05.474006 3 0 1808197 +5592 3469 0 2022-04-15 14:12:13.652733 3 0 +5591 3468 0 2022-04-15 13:54:57.235259 2022-04-15 14:08:39.40244 1 0 67881 +5590 3467 0 2022-04-15 13:38:08.512009 2022-04-15 13:51:39.379567 1 0 67099 +5589 3466 0 2022-04-15 12:18:58.664074 2022-04-15 13:32:41.178971 7 0 17739 +5588 3465 0 2022-04-14 13:13:55.997792 2022-04-15 11:17:29.415049 3 0 2075586 +5587 3464 0 2022-04-14 07:21:44.379975 2022-04-14 12:02:05.267535 3 0 445399 +5586 3463 0 2022-04-14 04:42:58.363866 3 0 +5585 3462 0 2022-04-13 19:23:45.402498 3 0 +5584 3461 0 2022-04-13 18:08:38.378899 3 0 +5583 3460 0 2022-04-13 16:52:38.659431 2022-04-13 18:05:41.666495 8 0 328035 +5582 3459 0 2022-04-13 16:24:57.943428 2022-04-13 16:49:35.063015 3 0 21466 +5581 3458 0 2022-04-13 15:55:11.375085 2022-04-13 16:22:04.69052 8 0 149236 +5580 3457 0 2022-04-13 15:21:26.220167 2022-04-13 15:51:06.758974 8 0 131802 +5579 3456 0 2022-04-13 13:33:57.15784 2022-04-13 15:13:21.557311 3 0 86932 +5578 3455 0 2022-04-13 10:34:22.101751 2022-04-13 13:30:59.962384 1 0 809487 +5577 3454 0 2022-04-13 09:16:50.761431 2022-04-13 10:28:42.711622 7 0 8979 +5576 3453 0 2022-04-13 07:36:31.238638 7 0 +5575 3452 0 2022-04-12 21:09:58.248069 2022-04-13 07:33:54.33575 3 0 490540 +5574 3451 0 2022-04-12 21:05:03.537127 2022-04-12 21:06:04.993623 3 0 514 +5573 3450 0 2022-04-12 13:34:16.499569 3 0 +5572 3449 0 2022-04-11 17:10:54.743992 2022-04-12 11:31:20.153332 3 0 1330550 +5571 3448 0 2022-04-11 09:45:13.296456 3 0 +5570 3447 0 2022-04-10 21:21:22.704832 2022-04-11 09:41:31.771197 3 0 1014750 +5569 3446 0 2022-04-10 21:09:00.724201 3 0 +5568 3445 0 2022-04-10 16:55:13.760532 3 0 +5567 3444 0 2022-04-10 16:49:39.023762 2022-04-10 16:50:17.207605 3 0 299 +5566 3443 0 2022-04-10 16:44:06.741048 2022-04-10 16:45:06.971962 3 0 408 +5565 3442 0 2022-04-10 08:25:10.016294 3 0 +5564 3441 0 2022-04-09 21:50:22.860791 3 0 +5563 3440 0 2022-04-09 17:08:55.662307 3 0 +5562 3439 0 2022-04-09 17:03:55.108161 2022-04-09 17:05:29.295103 3 0 1977 +5561 3438 0 2022-04-09 14:58:57.625319 3 0 +5560 3437 0 2022-04-08 10:25:15.734004 3 0 +5559 3436 0 2022-04-08 09:21:53.745919 2022-04-08 10:22:24.0855 3 0 110848 +5558 3435 1 2022-04-08 09:07:58.542571 2022-04-08 09:11:51.12357 3 0 0 +5557 3435 0 2022-04-08 05:05:05.594917 2022-04-08 09:05:37.858265 3 0 441683 +5556 3434 0 2022-04-07 12:02:42.914213 3 0 +5555 3433 0 2022-04-07 11:07:16.757716 2022-04-07 11:47:25.935821 3 0 73401 +5554 3432 0 2022-04-06 21:11:51.041504 3 0 +5553 3431 0 2022-04-06 20:54:59.407734 2022-04-06 21:07:59.909129 1 0 64091 +5552 3430 0 2022-04-06 20:37:36.869492 2022-04-06 20:51:19.562701 1 0 68045 +5551 3429 0 2022-04-06 18:48:30.872746 2022-04-06 20:33:32.449417 3 0 197055 +5550 3428 0 2022-04-06 17:07:52.517568 2022-04-06 18:43:12.087848 7 0 104104 +5549 3427 0 2022-04-06 16:42:31.238319 2022-04-06 17:04:29.443855 8 0 97282 +5548 3426 0 2022-04-06 11:36:57.696697 2022-04-06 15:09:19.037282 7 0 26346 +5547 3425 0 2022-04-06 10:35:06.160355 7 0 +5546 3424 0 2022-04-06 10:21:15.797738 2022-04-06 10:29:21.230303 3 0 56 +5545 3423 0 2022-04-06 07:02:22.389533 7 0 +5544 3422 0 2022-04-05 20:48:39.328587 2022-04-06 06:59:06.10377 3 0 991824 +5543 3421 0 2022-04-05 19:17:12.749459 3 0 +5542 3420 0 2022-04-05 17:01:42.792655 2022-04-05 18:03:48.862492 3 0 109715 +5541 3419 0 2022-04-05 06:20:50.362292 3 0 +5540 3418 0 2022-04-04 23:50:14.501511 3 0 +5539 3417 0 2022-04-04 21:01:56.787207 3 0 +5538 3416 0 2022-04-04 07:52:43.888166 3 0 +5537 3415 0 2022-04-04 05:52:30.318452 3 0 +5536 3414 0 2022-04-04 02:24:33.411053 3 0 +5535 3413 0 2022-04-03 23:39:36.971387 3 0 +5534 3412 0 2022-04-03 22:35:29.631885 2022-04-03 23:35:10.211495 3 0 93016 +5533 3411 0 2022-04-03 12:12:25.039401 3 0 +5532 3410 0 2022-04-03 11:34:44.318895 2022-04-03 12:07:38.045463 3 0 51108 +5531 3409 0 2022-04-03 01:04:31.018465 3 0 +5530 3408 0 2022-04-02 22:06:59.947066 3 0 +5529 3407 0 2022-04-02 22:02:35.902923 3 0 +5528 3406 0 2022-04-02 20:20:48.677815 3 0 +5527 3405 0 2022-03-31 22:28:46.49349 2022-04-02 20:15:57.142003 3 0 4343494 +5526 3404 0 2022-03-31 20:58:16.829148 3 0 +5525 3403 0 2022-03-31 16:09:16.85582 3 0 +5524 3402 0 2022-03-31 15:52:26.639884 2022-03-31 16:05:55.946241 1 0 65507 +5523 3401 0 2022-03-31 15:35:49.833972 2022-03-31 15:48:54.999933 1 0 63637 +5522 3400 0 2022-03-30 19:19:20.538219 2022-03-31 15:31:46.906855 3 0 1885957 +5521 3399 0 2022-03-30 19:12:08.290787 3 0 +5520 3398 0 2022-03-30 16:19:26.578116 3 0 +5519 3397 0 2022-03-30 10:44:50.288264 2022-03-30 14:31:05.50987 3 0 332439 +5518 3396 0 2022-03-30 00:48:37.694284 2022-03-30 10:34:56.498887 3 0 920694 +5517 3395 0 2022-03-29 19:18:52.168097 3 0 +5516 3394 0 2022-03-29 17:06:26.997179 2022-03-29 18:13:38.392993 3 0 104638 +5515 3393 0 2022-03-28 13:46:48.779835 2022-03-29 12:42:58.627316 3 0 1810892 +5514 3392 0 2022-03-27 12:43:23.288926 2022-03-28 13:42:15.956139 3 0 2338588 +5513 3391 0 2022-03-26 12:24:14.380555 2022-03-27 12:38:36.713389 3 0 2276650 +5512 3390 0 2022-03-26 10:29:26.761703 3 0 +5511 3389 0 2022-03-24 09:22:53.7123 3 0 +5510 3388 0 2022-03-22 11:23:32.004519 2022-03-24 09:18:35.157848 3 0 3629917 +5509 3387 0 2022-03-22 09:47:58.443277 2022-03-22 11:12:02.103209 3 0 74740 +5508 3386 0 2022-03-21 18:48:13.835694 2022-03-22 09:42:58.476171 3 0 1360650 +5507 3385 0 2022-03-20 22:31:14.554748 2022-03-21 18:43:59.479017 3 0 1888246 +5506 3384 0 2022-03-20 22:23:29.208177 2022-03-20 22:27:16.319203 3 0 5001 +5505 3383 0 2022-03-20 21:25:34.794859 2022-03-20 22:15:33.378501 3 0 39000 +5504 3382 0 2022-03-20 21:12:18.016823 2022-03-20 21:15:23.234773 7 0 347 +5503 3381 0 2022-03-20 20:31:54.095684 7 0 +5502 3380 0 2022-03-20 18:39:23.980506 7 0 +5501 3379 0 2022-03-20 09:46:25.030031 2022-03-20 18:34:42.804795 3 0 854994 +5500 3378 0 2022-03-20 09:30:16.478524 2022-03-20 09:43:36.486666 1 0 66488 +5499 3377 0 2022-03-20 09:14:14.346165 2022-03-20 09:27:18.497224 1 0 64814 +5498 3376 0 2022-03-19 08:28:44.639216 2022-03-20 09:10:21.069739 3 0 2392086 +5497 3375 0 2022-03-18 12:50:16.107919 2022-03-19 08:22:12.833613 3 0 1864853 +5496 3374 0 2022-03-18 11:55:53.516794 2022-03-18 12:16:03.496996 3 0 31551 +5495 3373 0 2022-03-18 11:03:09.162381 2022-03-18 11:35:55.544227 3 0 51546 +5494 3372 0 2022-03-17 16:01:27.847915 2022-03-18 10:37:07.955837 3 0 1743433 +5493 3371 0 2022-03-16 17:32:05.586346 2022-03-17 15:57:45.289755 3 0 2105704 +5492 3370 0 2022-03-16 16:35:08.551662 2022-03-16 17:28:23.08533 7 0 12731 +5491 3369 0 2022-03-16 12:51:36.037056 2022-03-16 15:55:54.742705 3 0 122878 +5490 3368 0 2022-03-16 11:36:11.503736 3 0 +5489 3367 0 2022-03-16 04:16:30.092278 7 0 +5488 3366 0 2022-03-15 21:40:33.206283 2022-03-16 04:12:47.982314 3 0 608267 +5487 3365 0 2022-03-15 15:10:16.842909 3 0 +5486 3364 0 2022-03-15 01:23:37.888685 2022-03-15 15:06:53.497543 3 0 1379078 +5485 3363 0 2022-03-14 21:32:43.719622 7 0 +5484 3362 0 2022-03-14 04:36:14.426291 2022-03-14 21:27:46.143214 3 0 1576530 +5483 3361 0 2022-03-13 19:07:39.64641 3 0 +5482 3360 0 2022-03-13 12:00:27.479147 3 0 +5481 3359 0 2022-03-12 10:54:40.5755 2022-03-13 11:54:07.131376 3 0 2269219 +5480 3358 0 2022-03-12 10:37:55.752908 2022-03-12 10:51:19.509701 1 0 65285 +5479 3357 0 2022-03-12 10:20:37.249319 2022-03-12 10:33:53.685551 1 0 64771 +5478 3356 0 2022-03-12 09:11:32.700964 2022-03-12 10:17:27.688084 3 0 103174 +5477 3355 0 2022-03-11 11:08:50.666063 2022-03-12 08:57:25.66544 3 0 2061649 +5476 3354 0 2022-03-10 13:43:05.817047 2022-03-11 11:05:09.25745 3 0 1988650 +5475 3353 0 2022-03-10 10:04:56.602296 3 0 +5474 3352 0 2022-03-10 05:36:06.029188 2022-03-10 09:56:57.337839 3 0 408993 +5473 3351 0 2022-03-10 03:49:49.147711 3 0 +5472 3350 0 2022-03-09 14:06:29.418493 3 0 +5471 3349 0 2022-03-08 09:05:25.41036 2022-03-09 14:01:46.960161 3 0 1569443 +5470 3348 0 2022-03-07 01:24:15.365916 2022-03-08 09:01:04.010407 3 0 1687284 +469 3347 0 2022-03-07 01:07:58.362929 2022-03-07 01:21:14.242864 7 0 1759 +5468 3346 0 2022-03-06 13:22:16.252683 2022-03-07 01:04:10.223014 3 0 621922 +5467 3345 0 2022-03-06 13:04:22.033569 2022-03-06 13:19:06.051897 1 0 65405 +5466 3344 0 2022-03-06 12:47:07.800213 2022-03-06 13:01:21.436609 1 0 62884 +5465 3343 0 2022-03-06 11:16:35.59349 2022-03-06 12:42:54.547044 3 0 76384 +5464 3342 0 2022-03-06 10:59:39.774364 2022-03-06 11:13:18.326319 3 0 93 +5463 3341 0 2022-03-06 09:46:30.212583 2022-03-06 10:36:40.565881 7 0 347 +5462 3340 0 2022-03-06 05:02:42.137727 2022-03-06 09:41:02.674293 7 0 1928 +5461 3339 0 2022-03-06 04:29:14.022419 2022-03-06 04:59:21.363185 3 0 5340 +5460 3338 0 2022-03-06 01:28:22.467101 2022-03-06 04:26:01.873217 3 0 124683 +5459 3337 0 2022-03-05 23:40:14.478085 2022-03-06 01:22:55.713818 7 0 719 +5458 3336 0 2022-03-05 12:52:05.983091 2022-03-05 23:29:48.471141 3 0 562750 +5457 3335 0 2022-03-05 04:49:13.403091 3 0 +5456 3334 0 2022-03-05 01:03:51.338253 3 0 +5455 3333 0 2022-03-04 17:02:38.829136 3 0 +5454 3332 0 2022-03-04 06:23:33.255843 2022-03-04 14:53:29.843756 3 0 491666 +5453 3331 0 2022-03-03 12:36:42.714393 2022-03-04 06:20:25.435869 3 0 1074227 +5452 3330 0 2022-03-03 11:32:20.288333 2022-03-03 12:26:39.638097 3 0 54550 +5451 3329 0 2022-03-03 11:27:32.066462 2022-03-03 11:28:22.138009 3 0 474 +5450 3328 0 2022-03-03 01:05:43.489222 3 0 +5449 3327 0 2022-03-02 22:18:54.36786 2022-03-03 00:55:50.321471 3 0 158016 +5448 3326 0 2022-03-02 20:16:49.648502 3 0 +5447 3325 0 2022-03-01 20:27:37.830903 2022-03-02 20:11:21.661045 3 0 1439272 +5446 3324 0 2022-03-01 17:10:36.532883 2022-03-01 20:22:48.35449 7 0 27363 +5445 3323 0 2022-03-01 13:15:18.504937 2022-03-01 17:07:04.320533 3 0 347378 +5444 3322 0 2022-03-01 12:52:51.028106 2022-03-01 13:04:52.689273 3 0 19855 +5443 3321 0 2022-03-01 12:34:32.212647 2022-03-01 12:48:20.691881 3 0 22983 +5442 3320 0 2022-03-01 11:43:51.957331 3 0 +5441 3319 0 2022-02-28 18:47:08.467381 2022-03-01 11:35:53.278689 3 0 1596820 +5440 3318 0 2022-02-28 18:39:08.704909 2022-02-28 18:43:51.50691 7 0 4326 +5439 3317 0 2022-02-28 18:18:55.590756 7 0 +5438 3316 0 2022-02-27 23:17:20.689491 2022-02-28 18:13:34.894329 3 0 1950649 +5437 3315 0 2022-02-27 19:28:02.45998 2022-02-27 22:57:03.24586 3 0 355756 +5436 3314 0 2022-02-27 16:52:18.732583 2022-02-27 19:24:21.988926 7 0 149337 +5435 3313 0 2022-02-27 15:49:40.259436 7 0 +5434 3312 0 2022-02-27 14:10:48.982211 2022-02-27 15:44:51.413846 3 0 159526 +5433 3311 0 2022-02-27 13:54:59.97534 2022-02-27 14:07:59.915183 1 0 64201 +5432 3310 0 2022-02-27 13:38:51.02708 2022-02-27 13:51:58.881196 1 0 65002 +5431 3309 0 2022-02-27 07:07:37.434086 2022-02-27 13:35:26.531869 3 0 660777 +5430 3308 0 2022-02-26 14:47:43.582482 3 0 +5429 3307 0 2022-02-26 11:46:44.198281 2022-02-26 14:44:32.329151 7 0 57831 +5428 3306 0 2022-02-26 06:23:03.285873 2022-02-26 11:42:04.257399 3 0 340858 +5427 3305 1 2022-02-26 06:19:58.881978 3 0 +5426 3305 0 2022-02-26 06:08:18.887942 2022-02-26 06:18:07.372247 3 0 6306 +5425 3304 0 2022-02-25 23:05:29.680553 3 0 +5424 3303 0 2022-02-25 01:05:07.809589 2022-02-25 23:00:25.978422 7 0 161193 +5423 3302 0 2022-02-24 00:14:50.806458 7 0 +5422 3301 0 2022-02-23 17:10:37.357969 7 0 +5421 3300 0 2022-02-23 09:45:45.5367 7 0 +5420 3299 0 2022-02-22 20:54:47.180596 7 0 +5419 3298 0 2022-02-22 20:33:26.114035 2022-02-22 20:48:10.374337 1 0 65204 +5418 3297 0 2022-02-22 20:14:59.244016 2022-02-22 20:30:11.602667 1 0 67229 +5417 3296 0 2022-02-22 14:17:37.809761 7 0 +5416 3295 0 2022-02-22 09:52:49.541677 7 0 +5415 3294 0 2022-02-21 19:19:05.725845 7 0 +5414 3293 0 2022-02-21 18:37:13.502009 2022-02-21 19:14:09.141325 8 0 187120 +5413 3292 0 2022-02-21 18:05:10.074416 2022-02-21 18:32:49.217533 8 0 122752 +5412 3291 0 2022-02-21 06:35:30.26771 2022-02-21 16:20:17.862295 7 0 72840 +5411 3290 0 2022-02-21 04:27:37.553236 7 0 +5410 3289 0 2022-02-20 13:50:59.213227 7 0 +5409 3288 0 2022-02-19 14:55:13.572664 7 0 +5408 3287 0 2022-02-19 13:36:32.049289 2022-02-19 14:47:22.863687 7 0 9372 +5407 3286 0 2022-02-19 10:10:20.807958 7 0 +5406 3285 0 2022-02-19 09:42:04.976297 2022-02-19 09:58:33.97544 7 0 2159 +5405 3284 0 2022-02-18 17:37:54.092266 2022-02-19 09:36:25.599713 7 0 128890 +5404 3283 0 2022-02-18 17:30:34.87945 2022-02-18 17:33:45.663259 8 0 13205 +5403 3282 0 2022-02-17 17:32:04.75076 7 0 +5402 3281 0 2022-02-17 17:19:20.925247 2022-02-17 17:24:00.440689 7 0 5455 +5401 3280 0 2022-02-17 17:06:51.627747 2022-02-17 17:14:52.425906 1 0 41105 +5400 3279 0 2022-02-17 16:55:22.773681 2022-02-17 17:01:48.876234 1 0 34372 +5399 3278 0 2022-02-17 16:43:48.675548 2022-02-17 16:49:50.853043 1 0 32602 +5398 3277 0 2022-02-17 16:28:29.203413 2022-02-17 16:37:43.001002 1 0 50414 +5397 3276 0 2022-02-17 16:13:04.536727 2022-02-17 16:21:10.973775 1 0 35126 +5396 3275 0 2022-02-17 07:51:47.918281 2022-02-17 14:30:47.917708 7 0 49743 +5395 3274 0 2022-02-17 01:56:15.245881 7 0 +5394 3273 0 2022-02-16 19:38:57.408846 7 0 +5393 3272 0 2022-02-16 19:11:56.737338 2022-02-16 19:28:04.503608 1 0 936 +5392 3271 0 2022-02-16 18:45:03.466695 2022-02-16 19:05:58.457105 1 0 110855 +5391 3270 0 2022-02-16 18:22:55.552591 2022-02-16 18:35:33.606282 1 0 719 +5390 3269 0 2022-02-16 17:57:20.954144 2022-02-16 18:11:35.827339 1 0 793 +5389 3268 0 2022-02-16 10:26:13.820035 2022-02-16 16:48:13.951795 7 0 51261 +5388 3267 0 2022-02-15 19:49:57.106971 2022-02-16 10:22:08.576795 3 0 699239 +5387 3266 0 2022-02-15 19:37:06.203653 2022-02-15 19:44:59.697808 1 0 39015 +5386 3265 0 2022-02-15 19:21:50.362694 2022-02-15 19:29:42.110004 1 0 37523 +5385 3264 0 2022-02-15 18:42:29.306628 2022-02-15 19:11:37.35692 1 0 127949 +5384 3263 0 2022-02-15 16:19:40.379498 2022-02-15 17:13:04.159843 3 0 53637 +5383 3262 0 2022-02-15 16:09:54.559239 2022-02-15 16:16:07.053974 1 0 27331 +5382 3261 0 2022-02-15 16:01:04.490982 2022-02-15 16:07:10.33931 1 0 26948 +5381 3260 0 2022-02-15 15:52:36.800203 2022-02-15 15:58:19.330746 1 0 25135 +5380 3259 0 2022-02-15 15:32:15.96692 2022-02-15 15:47:02.993549 1 0 66850 +5379 3258 0 2022-02-15 15:14:57.270049 2022-02-15 15:29:01.89832 1 0 63524 +5378 3257 0 2022-02-14 20:05:25.680675 2022-02-15 15:10:14.118699 3 0 1153518 +5377 3256 0 2022-02-13 14:22:10.3959 2022-02-14 20:00:34.051643 3 0 1791806 +5376 3255 0 2022-02-12 22:32:13.845715 2022-02-13 14:17:32.71594 7 0 1181032 +5375 3254 0 2022-02-12 22:01:15.207818 2022-02-12 22:29:05.45573 1 0 122916 +5374 3253 0 2022-02-12 11:53:08.71182 2022-02-12 21:57:43.129838 7 0 80101 +5373 3252 0 2022-02-11 14:22:54.113309 2022-02-12 11:49:12.278616 3 0 2154243 +5372 3251 0 2022-02-11 14:04:24.055429 2022-02-11 14:18:56.517054 1 0 65585 +5371 3250 0 2022-02-10 16:41:20.940673 2022-02-11 13:59:53.99377 3 0 2267342 +5370 3249 0 2022-02-10 16:24:27.483097 3 0 +5369 3248 0 2022-02-10 15:40:48.95052 2022-02-10 16:07:01.716108 1 0 113777 +5368 3247 0 2022-02-09 20:37:57.394704 2022-02-10 15:36:33.3889 3 0 2145568 +5367 3246 0 2022-02-08 12:58:28.509442 2022-02-09 20:32:31.431338 3 0 3377380 +5366 3245 0 2022-02-08 12:41:12.470696 2022-02-08 12:54:57.317357 1 0 68284 +5365 3244 0 2022-02-08 12:25:12.968479 2022-02-08 12:38:06.096364 1 0 63417 +5364 3243 0 2022-02-07 01:18:11.399659 2022-02-08 12:21:46.254551 3 0 3881224 +5363 3242 0 2022-02-06 10:53:12.591354 3 0 +5362 3241 0 2022-02-05 09:38:37.69103 2022-02-06 10:49:25.285081 3 0 2729808 +5361 3240 0 2022-02-05 08:18:47.715617 2022-02-05 09:18:39.679347 3 0 107385 +5360 3239 0 2022-02-04 10:27:49.824362 3 0 +5359 3238 0 2022-02-04 09:48:23.773684 2022-02-04 10:22:12.092863 7 0 11104 +5358 3237 0 2022-02-03 19:40:46.552818 2022-02-04 09:44:12.761244 3 0 1525343 +5357 3236 0 2022-02-02 15:33:12.603664 2022-02-03 19:35:52.910712 3 0 3058636 +5356 3235 0 2022-02-02 15:18:29.063228 2022-02-02 15:22:16.437291 1 0 17915 +5355 3234 0 2022-02-02 14:59:22.215856 2022-02-02 15:05:43.589206 1 0 26644 +5354 3233 0 2022-02-01 17:53:49.035128 2022-02-02 14:55:24.73778 3 0 2279328 +5353 3232 0 2022-02-01 17:35:12.415159 2022-02-01 17:50:57.716842 1 0 78421 +5352 3231 0 2022-02-01 17:18:14.908535 2022-02-01 17:31:33.771715 1 0 65837 +5351 3230 0 2022-02-01 15:16:30.4655 2022-02-01 16:13:26.201213 7 0 62265 +5350 3229 0 2022-02-01 14:36:30.988475 2022-02-01 14:52:02.650836 7 0 2024 +5349 3228 0 2022-02-01 14:21:12.198022 2022-02-01 14:26:13.116041 7 0 597 +5348 3227 0 2022-02-01 14:12:03.019067 2022-02-01 14:15:09.326977 1 0 294 +5347 3226 0 2022-02-01 13:47:26.839586 2022-02-01 13:58:11.261634 1 0 1088 +5346 3225 0 2022-02-01 08:30:36.814042 2022-02-01 13:29:31.895847 7 0 296272 +5345 3224 0 2022-01-31 19:07:31.3804 2022-02-01 08:22:14.306405 3 0 1375182 +5344 3223 0 2022-01-30 20:20:42.743879 2022-01-31 19:01:45.731818 3 0 2356970 +5343 3222 0 2022-01-30 02:33:59.994465 3 0 +5342 3221 0 2022-01-29 21:16:48.509353 2022-01-30 02:28:29.974138 3 0 100484 +5341 3220 0 2022-01-29 13:50:00.103031 2022-01-29 21:11:02.204372 3 0 620000 +5340 3219 0 2022-01-29 10:08:55.205731 3 0 +5339 3218 0 2022-01-28 07:20:45.565225 2022-01-29 10:05:57.317503 3 0 2940461 +5338 3217 0 2022-01-27 20:40:52.662818 3 0 +5337 3216 0 2022-01-26 20:41:08.821543 2022-01-27 20:35:50.34893 3 0 2467195 +5336 3215 0 2022-01-26 19:03:45.632141 2022-01-26 20:35:58.183921 3 0 150735 +5335 3214 0 2022-01-26 18:31:51.851022 2022-01-26 19:00:07.687241 1 0 140881 +5334 3213 0 2022-01-26 18:12:20.929944 2022-01-26 18:25:49.542867 1 0 64110 +5333 3212 0 2022-01-26 17:56:40.648859 2022-01-26 18:09:35.804976 1 0 63861 +5332 3211 0 2022-01-26 14:00:07.323003 2022-01-26 17:51:03.665721 3 0 374965 +5331 3210 0 2022-01-26 05:42:46.019106 2022-01-26 13:53:41.047033 3 0 806107 +5330 3209 0 2022-01-25 18:08:33.109995 3 0 +5329 3208 0 2022-01-25 17:35:31.136227 2022-01-25 17:55:40.678481 1 0 2067 +5328 3207 0 2022-01-25 11:10:44.797642 2022-01-25 17:29:38.809101 3 0 639438 +5327 3206 0 2022-01-25 10:57:33.975709 2022-01-25 11:07:10.048724 7 0 9823 +5326 3205 0 2022-01-24 21:09:56.08166 2022-01-25 10:53:33.235331 3 0 1358858 +5325 3204 0 2022-01-23 20:35:13.525426 2022-01-24 21:05:14.574535 3 0 2397469 +5324 3203 0 2022-01-23 20:00:35.931079 2022-01-23 20:32:13.490368 1 0 143378 +5323 3202 0 2022-01-23 19:26:16.085477 2022-01-23 19:57:30.760103 1 0 141492 +5322 3201 0 2022-01-23 18:51:14.020053 2022-01-23 19:23:07.356106 1 0 144592 +5321 3200 0 2022-01-23 18:17:12.332769 2022-01-23 18:48:38.054379 1 0 142472 +5320 3199 0 2022-01-23 17:36:23.301075 2022-01-23 18:08:27.368287 1 0 145261 +5319 3198 0 2022-01-23 17:01:31.674763 2022-01-23 17:32:41.245584 1 0 140920 +5318 3197 0 2022-01-23 12:54:53.507969 2022-01-23 16:54:37.794104 3 0 232023 +5317 3196 0 2022-01-22 16:52:33.096914 2022-01-23 12:51:06.850743 3 0 1156124 +5316 3195 0 2022-01-21 17:43:21.788516 2022-01-22 16:48:50.978966 3 0 379181 +5315 3194 0 2022-01-21 17:25:51.124022 2022-01-21 17:40:08.381359 1 0 64006 +5314 3193 0 2022-01-21 17:07:47.054244 2022-01-21 17:22:19.374364 1 0 65183 +5313 3192 0 2022-01-20 17:02:09.125586 2022-01-21 17:03:32.277111 3 0 374945 +5312 3191 0 2022-01-19 23:05:26.214624 3 0 +5311 3190 0 2022-01-19 16:35:20.83361 3 0 +5310 3189 0 2022-01-19 06:14:52.771129 2022-01-19 16:30:27.165744 3 0 162650 +5309 3188 0 2022-01-18 20:07:40.700823 3 0 +5308 3187 0 2022-01-18 06:57:43.391766 3 0 +5307 3186 0 2022-01-17 21:15:53.536655 2022-01-18 06:53:08.664261 3 0 522463 +5306 3185 0 2022-01-17 20:59:26.401626 2022-01-17 21:13:31.77881 1 0 63295 +5305 3184 0 2022-01-17 20:42:09.865851 2022-01-17 20:56:51.010583 1 0 65762 +5304 3183 0 2022-01-16 21:49:06.271535 2022-01-17 20:33:30.436653 3 0 1315091 +5303 3182 0 2022-01-15 21:49:18.623715 2022-01-16 21:43:53.158687 3 0 1375078 +5302 3181 0 2022-01-14 22:07:42.701079 2022-01-15 21:44:10.178405 3 0 1363173 +5301 3180 0 2022-01-14 20:21:17.449095 2022-01-14 22:03:20.060948 3 0 98465 +5300 3179 0 2022-01-14 10:26:30.552756 3 0 +5299 3178 0 2022-01-13 21:55:43.841231 3 0 +5298 3177 0 2022-01-12 12:52:16.187742 3 0 +5297 3176 0 2022-01-12 04:02:16.665605 3 0 +5296 3175 0 2022-01-11 14:35:37.804989 3 0 +5295 3174 0 2022-01-11 14:17:58.835681 2022-01-11 14:32:58.54394 1 0 67281 +5294 3173 0 2022-01-11 14:00:37.039103 2022-01-11 14:15:00.618993 1 0 64418 +5293 3172 0 2022-01-11 06:43:44.751446 2022-01-11 13:57:17.252625 3 0 33651 +5292 3171 0 2022-01-10 07:09:47.406029 2022-01-11 06:40:26.02324 3 0 1331890 +5291 3170 0 2022-01-09 12:45:34.292021 3 0 +5290 3169 0 2022-01-09 10:23:34.457015 2022-01-09 12:36:54.767393 3 0 201643 +5289 3168 0 2022-01-09 06:41:22.262427 3 0 +5288 3167 0 2022-01-08 14:56:32.00481 3 0 +5287 3166 0 2022-01-08 14:39:18.390856 2022-01-08 14:53:22.367902 1 0 63051 +5286 3165 0 2022-01-08 14:21:55.496869 2022-01-08 14:36:12.52861 1 0 64294 +5285 3164 0 2022-01-08 06:23:05.195274 2022-01-08 14:12:51.789779 3 0 446048 +5284 3163 0 2022-01-07 15:25:09.362795 3 0 +5283 3162 0 2022-01-06 14:07:00.896701 2022-01-07 15:18:47.829573 3 0 1734999 +5282 3161 0 2022-01-05 05:31:44.319966 2022-01-06 14:03:04.649595 3 0 3294676 +5281 3160 0 2022-01-04 11:26:11.632151 2022-01-05 05:28:19.925279 3 0 1862158 +5280 3159 0 2022-01-04 10:38:26.813106 2022-01-04 11:22:54.478342 3 0 69480 +5279 3158 0 2022-01-04 09:54:39.481726 2022-01-04 10:34:44.630314 1 0 203330 +5278 3157 0 2022-01-04 09:36:25.717801 2022-01-04 09:49:32.56121 1 0 64547 +5277 3156 0 2022-01-04 09:20:14.652052 2022-01-04 09:33:13.152113 1 0 63543 +5276 3155 0 2022-01-02 13:41:41.644045 2022-01-04 09:08:55.942477 3 0 4345531 +5275 3154 0 2022-01-02 09:52:34.435063 2022-01-02 13:37:13.493789 3 0 381730 +5274 3153 0 2021-12-31 15:00:00.39747 2022-01-02 09:48:05.960263 3 0 4107246 +5273 3152 0 2021-12-31 14:23:57.317587 2021-12-31 14:30:33.85385 3 0 12316 +5272 3151 0 2021-12-31 13:34:01.03051 3 0 +5271 3150 0 2021-12-30 10:07:15.928288 2021-12-31 13:30:30.15899 3 0 2795043 +5270 3149 0 2021-12-29 09:50:52.162104 2021-12-30 10:00:44.439244 3 0 2463443 +5269 3148 0 2021-12-29 09:13:48.777012 2021-12-29 09:46:35.353867 1 0 163048 +5268 3147 0 2021-12-28 10:35:11.430369 2021-12-29 09:07:33.403466 3 0 2159125 +5267 3146 0 2021-12-28 10:15:09.766318 2021-12-28 10:31:52.750236 1 0 82756 +5266 3145 0 2021-12-28 09:54:30.225723 2021-12-28 10:10:24.400138 1 0 78380 +5265 3144 0 2021-12-27 06:11:40.732017 2021-12-28 09:49:21.339526 3 0 2817238 +5264 3143 0 2021-12-26 21:12:19.851986 2021-12-27 06:04:24.641103 3 0 533801 +5263 3142 0 2021-12-25 15:18:54.625896 2021-12-26 21:09:01.997828 3 0 3036637 +5262 3141 0 2021-12-25 14:55:03.474456 2021-12-25 15:15:33.551119 3 0 34313 +5261 3140 0 2021-12-24 14:29:17.189027 2021-12-25 14:49:38.234744 3 0 2506755 +5260 3139 0 2021-12-23 11:16:00.398427 2021-12-24 14:21:19.799231 3 0 2768714 +5259 3138 0 2021-12-23 10:59:35.349433 2021-12-23 11:12:54.815003 1 0 65640 +5258 3137 0 2021-12-23 10:42:34.663527 2021-12-23 10:55:37.482426 1 0 64020 +5257 3136 0 2021-12-22 11:31:52.412062 2021-12-23 10:39:19.556955 3 0 2356347 +5256 3135 0 2021-12-21 10:17:01.446248 2021-12-22 11:13:28.903422 3 0 2630767 +5255 3134 0 2021-12-21 09:46:30.040913 2021-12-21 10:13:59.923925 1 0 140878 +5254 3133 0 2021-12-21 09:27:34.200433 2021-12-21 09:41:04.425716 1 0 68545 +5253 3132 0 2021-12-21 09:11:39.847041 2021-12-21 09:24:25.609709 1 0 64477 +5252 3131 0 2021-12-20 08:48:07.123338 2021-12-21 09:08:36.002813 3 0 2732152 +5251 3130 0 2021-12-18 15:11:46.49961 2021-12-20 08:43:04.113865 3 0 4391420 +5250 3129 0 2021-12-17 16:46:40.908572 2021-12-18 15:08:18.43248 3 0 2412872 +5249 3128 0 2021-12-16 16:48:47.397675 2021-12-17 16:43:01.02263 3 0 2643013 +5248 3127 0 2021-12-15 15:11:15.175465 2021-12-16 16:45:15.750811 3 0 1867062 +5247 3126 0 2021-12-15 12:29:47.601476 2021-12-15 12:48:38.443241 1 0 84903 +5246 3125 0 2021-12-15 12:07:26.623484 2021-12-15 12:26:03.333616 1 0 83733 +5245 3124 0 2021-12-15 11:46:50.009859 2021-12-15 12:02:12.769143 1 0 69021 +5244 3123 0 2021-12-15 11:29:19.978943 2021-12-15 11:43:34.325515 1 0 63751 +5243 3122 0 2021-12-15 11:12:43.297691 2021-12-15 11:27:03.750816 1 0 64315 +5242 3121 0 2021-12-15 10:55:47.927592 2021-12-15 11:10:03.812222 1 0 64023 +5241 3120 0 2021-12-15 10:38:50.847081 2021-12-15 10:53:12.42878 1 0 64300 +5240 3119 0 2021-12-15 10:20:50.890575 2021-12-15 10:35:13.346865 1 0 64349 +5239 3118 0 2021-12-15 06:08:47.277627 2021-12-15 10:16:26.543819 3 0 64111 +5238 3117 0 2021-12-14 15:16:07.276377 2021-12-15 06:02:39.077751 3 0 1768837 +5237 3116 0 2021-12-13 15:22:59.118653 2021-12-14 15:11:59.945535 3 0 2853308 +5236 3115 0 2021-12-12 12:57:53.869576 2021-12-13 15:19:32.352256 3 0 2738064 +5235 3114 0 2021-12-12 12:41:47.370023 2021-12-12 12:54:39.046353 1 0 63398 +5234 3113 0 2021-12-12 12:26:16.73045 2021-12-12 12:39:14.360966 1 0 63979 +5233 3112 0 2021-12-12 12:10:21.505763 2021-12-12 12:23:21.718371 1 0 64181 +5232 3111 0 2021-12-12 11:53:42.352013 2021-12-12 12:06:43.358708 1 0 64034 +5231 3110 0 2021-12-12 11:36:43.97541 2021-12-12 11:49:47.529885 1 0 63951 +5230 3109 0 2021-12-12 11:20:40.030448 2021-12-12 11:33:56.869852 1 0 64938 +5229 3108 0 2021-12-11 10:56:55.572382 2021-12-12 11:17:19.355661 3 0 2314858 +5228 3107 0 2021-12-11 10:40:39.467155 2021-12-11 10:53:56.487897 1 0 65409 +5227 3106 0 2021-12-11 10:22:58.770462 2021-12-11 10:37:08.276259 1 0 69728 +5226 3105 0 2021-12-10 11:12:12.845407 2021-12-11 10:19:31.755131 3 0 2034283 +5225 3104 0 2021-12-10 10:50:23.539758 2021-12-10 11:09:05.235014 1 0 94140 +5224 3103 0 2021-12-10 10:26:10.612465 2021-12-10 10:46:49.263898 1 0 95796 +5223 3102 0 2021-12-09 10:38:43.992049 2021-12-10 10:22:46.749796 3 0 2296966 +5222 3101 0 2021-12-09 10:20:58.319661 2021-12-09 10:35:06.35434 1 0 69714 +5221 3100 0 2021-12-09 10:03:53.293039 2021-12-09 10:17:36.395248 1 0 67270 +5220 3099 0 2021-12-08 11:49:49.377014 2021-12-09 09:59:34.362902 3 0 2183309 +5219 3098 0 2021-12-08 11:26:49.728783 2021-12-08 11:45:43.815961 1 0 94376 +5218 3097 0 2021-12-08 11:03:45.307586 2021-12-08 11:22:31.00536 1 0 94223 +5217 3096 0 2021-12-07 13:27:06.821945 2021-12-08 10:58:29.614276 3 0 2123180 +5216 3095 0 2021-12-06 15:40:55.643937 2021-12-07 13:23:00.13442 3 0 2120655 +5215 3094 0 2021-12-06 06:54:14.708567 2021-12-06 14:06:44.619242 3 0 708276 +5214 3093 0 2021-12-05 15:44:58.374838 2021-12-06 06:47:45.778722 3 0 1494763 +5213 3092 0 2021-12-05 15:28:47.399427 2021-12-05 15:41:36.313612 1 0 63233 +5212 3091 0 2021-12-05 15:13:06.572467 2021-12-05 15:26:00.516935 1 0 63742 +5211 3090 0 2021-12-04 21:43:03.34742 2021-12-05 15:08:43.481794 3 0 1702295 +5210 3089 0 2021-12-04 12:59:55.889771 2021-12-04 21:38:03.684903 3 0 724143 +5209 3088 0 2021-12-04 12:43:38.397642 2021-12-04 12:56:56.338296 1 0 65532 +5208 3087 0 2021-12-04 12:22:21.933506 2021-12-04 12:35:37.028278 1 0 64896 +5207 3086 0 2021-12-03 17:21:10.237776 2021-12-04 12:17:05.897481 3 0 1849716 +5206 3085 0 2021-12-03 16:53:20.837686 2021-12-03 17:18:14.107411 1 0 123668 +5205 3084 0 2021-12-03 16:36:40.895918 2021-12-03 16:49:42.912288 1 0 63986 +5204 3083 0 2021-12-03 09:05:14.09138 2021-12-03 16:33:11.615467 3 0 696102 +5203 3082 0 2021-12-01 17:54:49.206791 2021-12-03 09:00:21.649296 3 0 3724614 +5202 3081 0 2021-12-01 16:09:44.662383 2021-12-01 17:49:18.568707 3 0 35054 +5201 3080 0 2021-12-01 15:52:47.974148 2021-12-01 16:07:16.042403 1 0 64930 +5200 3079 0 2021-12-01 15:35:37.765283 2021-12-01 15:49:41.527782 1 0 62994 +5199 3078 0 2021-12-01 11:25:52.652925 2021-12-01 15:32:02.263964 3 0 19795 +5198 3077 0 2021-12-01 11:07:12.330847 2021-12-01 11:22:48.643456 3 0 2427 +5197 3076 0 2021-12-01 09:42:29.649333 2021-12-01 09:50:24.007747 9 0 0 +5196 3075 0 2021-12-01 06:59:37.056164 2021-12-01 09:34:20.478573 3 0 1073 +5195 3074 0 2021-12-01 05:53:16.563018 2021-12-01 06:52:32.348212 3 0 410 +5194 3073 0 2021-11-30 13:23:03.466773 2021-12-01 05:49:16.710926 3 0 1600862 +5193 3072 0 2021-11-30 11:07:40.377855 3 0 +5192 3071 0 2021-11-30 10:51:12.21316 2021-11-30 11:04:20.166108 1 0 64155 +5191 3070 0 2021-11-30 10:34:53.61912 2021-11-30 10:48:01.590601 1 0 64278 +5190 3069 0 2021-11-29 09:48:03.761812 2021-11-30 10:26:31.832443 3 0 2442075 +5189 3068 0 2021-11-28 09:33:27.044022 2021-11-29 09:44:03.540641 3 0 2392454 +5188 3067 0 2021-11-27 09:55:14.862576 2021-11-28 09:30:10.968936 3 0 2371300 +5187 3066 0 2021-11-26 09:05:54.766724 2021-11-27 09:50:39.227221 3 0 2463061 +5186 3065 0 2021-11-25 09:52:18.479463 2021-11-26 09:01:14.81152 3 0 2273140 +5185 3064 0 2021-11-24 11:11:15.87505 2021-11-25 09:49:08.668969 3 0 2250982 +5184 3063 0 2021-11-23 13:23:29.234505 2021-11-24 11:07:53.65568 3 0 2118303 +5183 3062 0 2021-11-23 06:18:42.285644 2021-11-23 10:57:18.164079 3 0 455684 +5182 3061 0 2021-11-22 18:32:08.415219 2021-11-22 19:33:40.739961 3 0 84684 +5181 3060 0 2021-11-22 11:22:42.666215 2021-11-22 18:23:23.757642 3 0 708040 +5180 3059 0 2021-11-21 08:29:42.036169 2021-11-22 11:18:49.00116 3 0 2886182 +5179 3058 0 2021-11-20 15:44:15.293348 2021-11-21 08:25:26.123897 3 0 1846420 +5178 3057 0 2021-11-20 09:13:50.503815 2021-11-20 15:40:56.314147 3 0 685175 +5177 3056 0 2021-11-19 09:12:09.646419 2021-11-20 09:09:27.541848 3 0 2586806 +5176 3055 0 2021-11-18 10:27:18.828313 2021-11-19 09:09:11.356553 3 0 2312802 +5175 3054 0 2021-11-17 19:37:59.163631 2021-11-18 10:23:51.978951 3 0 1573646 +5173 3053 0 2021-11-17 11:08:10.216339 2021-11-17 19:07:54.822509 3 0 898978 +5172 3052 0 2021-11-15 08:26:43.815468 2021-11-16 07:07:10.904198 3 0 2461145 +5171 3051 0 2021-11-14 20:48:05.782777 2021-11-14 22:22:29.71476 3 0 407590 +5170 3050 0 2021-11-14 20:30:50.09691 2021-11-14 20:45:12.972335 1 0 63674 +5169 3049 0 2021-11-14 20:13:13.938523 2021-11-14 20:27:40.947361 1 0 63900 +5168 3048 0 2021-11-14 10:56:38.490824 2021-11-14 20:05:43.483062 3 0 2422112 +5167 3047 0 2021-11-14 09:29:22.522499 2021-11-14 10:50:57.773737 3 0 358077 +5166 3046 0 2021-11-13 12:09:33.795566 2021-11-13 12:41:38.915309 3 0 134755 +5165 3045 0 2021-11-13 09:24:32.632644 2021-11-13 10:00:53.519621 3 0 155602 +5164 3044 0 2021-11-12 17:53:10.043654 2021-11-12 23:31:58.750133 3 0 1547826 +5163 3043 0 2021-11-12 16:59:01.387183 2021-11-12 17:29:16.441817 3 0 125823 +5162 3042 0 2021-11-12 16:40:40.337412 3 0 +5161 3041 0 2021-11-12 16:34:12.169571 2021-11-12 16:35:41.410211 3 0 5217 +5160 3040 0 2021-11-12 16:14:29.669655 3 0 +5159 3039 0 2021-11-12 16:04:10.974132 3 0 +5158 3038 0 2021-11-12 15:56:20.971689 3 0 +5157 3037 0 2021-11-12 15:53:46.021336 3 0 +5156 3036 0 2021-11-12 15:51:04.786406 3 0 +5155 3035 0 2021-11-12 12:00:52.358699 3 0 +5154 3034 0 2021-11-12 10:44:21.323379 2021-11-12 11:36:32.949919 3 0 228274 +5153 3033 0 2021-11-12 10:12:17.859449 2021-11-12 10:38:18.609676 3 0 109951 +5152 3032 0 2021-11-11 17:26:27.542452 2021-11-11 18:00:57.14808 3 0 147833 +5151 3031 0 2021-11-11 16:06:07.86832 2021-11-11 17:15:22.901186 3 0 297663 +5150 3030 0 2021-11-11 10:44:56.495919 2021-11-11 10:51:06.218888 3 0 26211 +5149 3029 0 2021-11-11 10:37:39.516521 2021-11-11 10:39:52.024577 3 0 7835 +5148 3028 0 2021-11-11 10:25:47.481325 2021-11-11 10:30:59.919237 3 0 20960 +5146 3027 0 2021-11-10 15:18:57.250351 2021-11-11 04:28:33.249708 3 0 3275263 +5145 3026 0 2021-11-10 12:26:51.306971 2021-11-10 12:27:51.374794 3 0 2040 +5144 3025 0 2021-11-10 12:18:39.034311 2021-11-10 12:19:06.86496 3 0 449 +5143 3024 0 2021-11-10 12:05:50.433555 2021-11-10 12:14:06.429087 3 0 23346 +5142 3023 0 2021-11-08 04:50:11.296655 2021-11-08 08:23:20.758539 3 0 948836 +5141 3022 0 2021-11-04 06:56:29.167705 2021-11-04 07:56:16.862423 3 0 175297 +5140 3021 0 2021-11-03 19:45:40.129334 2021-11-04 06:53:53.6661 1 0 3005873 +5139 3020 0 2021-11-03 19:33:01.799565 2021-11-03 19:40:37.143595 1 0 32997 +5138 3019 2 2021-11-03 19:05:15.775993 1 0 +5137 3019 1 2021-11-03 18:59:12.525624 2021-11-03 19:01:08.364242 1 0 7440 +5136 3019 0 2021-11-03 17:23:02.744474 2021-11-03 17:29:02.478156 1 0 25895 +5135 3018 0 2021-11-03 12:06:49.910287 2021-11-03 16:56:27.428006 3 0 859859 +5134 3017 0 2021-11-03 11:30:37.170563 2021-11-03 12:04:41.121147 1 0 152258 +5133 3016 0 2021-11-03 10:23:05.236717 2021-11-03 10:42:11.728891 1 0 56526 +5132 3015 0 2021-11-03 09:59:40.307975 2021-11-03 10:08:03.807412 3 0 16022 +5131 3014 0 2021-11-03 09:33:28.462292 2021-11-03 09:56:29.326712 1 0 102459 +5130 3013 0 2021-11-03 09:04:52.475351 2021-11-03 09:14:44.600433 1 0 47631 +5129 3012 0 2021-11-03 08:47:49.53107 2021-11-03 08:52:29.727303 1 0 19868 +5128 3011 0 2021-11-03 08:37:08.325017 2021-11-03 08:43:46.918991 1 0 28 +5127 3010 0 2021-11-03 08:27:18.970833 1 0 +5126 3009 0 2021-11-03 08:01:52.11102 2021-11-03 08:06:52.361666 1 0 20264 +5125 3008 0 2021-11-03 05:51:54.378005 2021-11-03 05:56:27.845147 1 0 17998 +5124 3007 0 2021-11-02 20:35:44.972821 2021-11-02 20:40:36.681147 1 0 19796 +5123 3006 0 2021-11-02 20:33:05.656877 1 0 +5122 3005 0 2021-11-02 20:21:19.603981 2021-11-02 20:26:00.866844 1 0 19165 +5121 3004 0 2021-11-02 20:09:16.387746 2021-11-02 20:14:03.755669 1 0 19428 +5120 3003 1 2021-11-02 19:53:53.915279 1 0 +5119 3003 0 2021-11-02 19:14:01.892787 2021-11-02 19:16:08.76345 1 0 8432 +5118 3002 1 2021-11-02 18:53:56.41388 2021-11-02 18:56:18.174698 1 0 9559 +5117 3002 0 2021-11-02 18:47:25.465034 2021-11-02 18:49:07.482445 1 0 5592 +5116 3001 2 2021-11-02 18:38:46.253124 2021-11-02 18:41:14.482165 1 0 10064 +5115 3001 1 2021-11-02 18:32:48.04793 2021-11-02 18:35:39.668547 1 0 11463 +5114 3001 0 2021-11-02 18:09:24.953328 2021-11-02 18:11:47.033385 1 0 9424 +5113 3000 0 2021-11-02 12:19:26.561481 2021-11-02 12:38:43.02715 1 0 93408 +5112 2999 0 2021-11-02 11:47:59.803063 2021-11-02 12:07:50.91199 1 0 96745 +5111 2998 0 2021-11-02 11:37:14.328853 2021-11-02 11:42:58.461808 1 0 27153 +5110 2997 0 2021-11-02 11:07:12.872487 2021-11-02 11:15:57.465517 1 0 22081 +5109 2996 0 2021-11-02 10:43:23.862079 2021-11-02 10:49:28.226032 1 0 28900 +5108 2995 0 2021-11-02 10:08:39.419559 2021-11-02 10:13:55.453399 1 0 24766 +5107 2994 0 2021-11-02 09:47:54.700105 2021-11-02 09:54:08.155082 1 0 29792 +5106 2993 0 2021-11-02 09:27:37.547468 2021-11-02 09:33:15.525673 1 0 26568 +5105 2992 0 2021-11-02 08:29:15.163542 2021-11-02 08:34:29.024069 1 0 24494 +5104 2991 0 2021-11-02 08:18:44.308972 2021-11-02 08:23:52.805847 1 0 23997 +5103 2990 0 2021-11-02 07:53:17.287006 2021-11-02 08:00:08.270654 1 0 32678 +5102 2989 0 2021-11-02 07:42:22.832637 1 0 +5101 2988 0 2021-11-02 07:26:29.919175 2021-11-02 07:32:08.888122 1 0 26349 +5100 2987 1 2021-11-02 06:49:20.605411 2021-11-02 07:08:48.071174 1 0 93755 +5099 2987 0 2021-11-02 06:20:49.179239 2021-11-02 06:26:15.976342 1 0 25665 +5098 2986 0 2021-11-02 05:57:20.822383 2021-11-02 06:02:39.059407 1 0 25388 +5097 2985 0 2021-11-02 05:37:33.903496 2021-11-02 05:42:50.265214 1 0 24931 +5096 2984 0 2021-11-02 05:24:38.624243 2021-11-02 05:29:54.895809 1 0 24657 +5095 2983 0 2021-11-02 04:51:48.767661 2021-11-02 04:57:12.078646 1 0 25393 +5094 2982 0 2021-11-02 04:42:16.309941 2021-11-02 04:46:26.147508 1 0 19427 +5093 2981 0 2021-11-02 04:28:53.606924 2021-11-02 04:38:44.088292 1 0 47629 +5092 2980 1 2021-11-01 13:56:51.639029 2021-11-01 14:06:00.23364 1 0 43690 +5091 2980 0 2021-11-01 13:17:35.486656 2021-11-01 13:25:38.352695 1 0 38571 +5090 2979 0 2021-11-01 12:53:21.619354 2021-11-01 12:58:44.638152 1 0 25376 +5089 2978 0 2021-11-01 11:54:52.255594 2021-11-01 11:58:42.26171 1 0 17714 +5088 2977 0 2021-11-01 11:43:46.780076 2021-11-01 11:47:55.850132 1 0 19412 +5087 2976 0 2021-11-01 11:21:42.412301 2021-11-01 11:30:08.20248 1 0 40314 +5086 2975 0 2021-11-01 11:11:27.528173 2021-11-01 11:14:02.429783 1 0 11696 +5085 2974 0 2021-11-01 11:08:55.072342 1 0 +5084 2973 0 2021-11-01 11:02:08.953274 2021-11-01 11:03:31.276391 1 0 5029 +5083 2972 0 2021-11-01 10:58:46.231314 2021-11-01 10:59:26.913986 1 0 1933 +5082 2971 0 2021-11-01 10:43:56.751717 2021-11-01 10:48:46.033941 1 0 20208 +5081 2970 0 2021-11-01 10:40:21.189365 2021-11-01 10:41:19.494672 1 0 3550 +5080 2969 0 2021-11-01 10:31:37.04277 2021-11-01 10:34:06.818076 1 0 6704 +5079 2968 0 2021-11-01 10:28:02.078208 1 0 +5078 2967 0 2021-11-01 09:46:05.324895 2021-11-01 09:47:17.340171 1 0 2507 +5077 2966 0 2021-11-01 09:39:25.584184 2021-11-01 09:42:35.444728 1 0 7421 +5076 2965 0 2021-11-01 09:29:04.248808 2021-11-01 09:36:54.024139 3 0 32001 +5075 2964 0 2021-11-01 09:22:30.486557 2021-11-01 09:26:34.010256 1 0 17103 +5074 2963 0 2021-11-01 09:04:38.369539 2021-11-01 09:17:17.021891 1 0 55860 +5073 2962 0 2021-10-26 17:18:43.191338 2021-10-26 17:33:07.435745 1 0 63937 +5072 2961 0 2021-10-26 16:58:30.390849 2021-10-26 17:12:09.479664 1 0 64851 +5071 2960 0 2021-10-26 13:56:39.826415 2021-10-26 16:51:00.268245 3 0 727807 +5070 2959 0 2021-10-26 13:40:58.668103 3 0 +5069 2958 0 2021-10-26 09:52:20.321632 2021-10-26 12:21:05.618812 3 0 607931 +5068 2957 0 2021-10-26 09:01:36.810506 2021-10-26 09:48:00.909057 1 0 207809 +5067 2956 0 2021-10-25 08:30:58.969019 2021-10-25 09:24:42.587756 1 0 10276 +5066 2955 0 2021-10-25 08:21:49.676576 2021-10-25 08:28:39.816649 1 0 32567 +5065 2954 0 2021-10-25 08:18:20.21908 2021-10-25 08:19:21.835545 1 0 3623 +5064 2953 0 2021-10-25 08:11:26.821115 2021-10-25 08:15:41.758566 1 0 269 +5063 2952 0 2021-10-25 08:05:54.520971 2021-10-25 08:06:51.334421 1 0 162 +5062 2951 0 2021-10-25 07:55:45.39232 2021-10-25 08:01:54.270634 1 0 1099 +5061 2950 0 2021-10-25 07:49:20.763042 2021-10-25 07:52:34.556734 1 0 185 +5060 2949 0 2021-10-25 07:31:19.565629 2021-10-25 07:35:56.477829 1 0 21386 +5059 2948 0 2021-10-25 07:08:41.47495 2021-10-25 07:22:12.690692 1 0 64676 +5058 2947 0 2021-10-25 05:52:08.71077 2021-10-25 05:56:23.458031 1 0 18912 +5057 2946 0 2021-10-23 11:19:07.280084 2021-10-23 11:32:18.198121 1 0 63042 +5056 2945 0 2021-10-21 16:35:09.91748 2021-10-21 16:56:46.147846 1 0 102375 +5055 2944 0 2021-10-21 16:02:10.252497 2021-10-21 16:25:29.934017 1 0 111569 +5054 2943 0 2021-10-21 15:09:53.589194 2021-10-21 15:39:27.462493 1 0 143000 +5053 2942 0 2021-10-21 11:13:29.405648 2021-10-21 12:26:03.154968 1 0 364865 +5052 2941 0 2021-10-21 09:48:57.391424 2021-10-21 10:07:27.667778 1 0 84 +5051 2940 0 2021-10-19 08:54:56.258578 2021-10-19 08:59:00.592995 3 0 17 +5050 2939 0 2021-10-05 06:58:17.009522 2021-10-18 09:06:48.656001 3 0 98306 +5049 2938 0 2021-09-02 11:41:45.022138 2021-09-02 11:49:30.60979 3 0 23245 +5048 2937 0 2021-08-05 10:10:07.932913 2021-08-05 10:31:07.308639 1 0 101130 +5047 2936 0 2021-08-05 09:47:18.075397 2021-08-05 10:07:03.701402 1 0 95128 +5046 2935 0 2021-07-27 13:32:17.836473 2021-07-27 13:55:16.46632 1 0 112885 +5045 2934 0 2021-07-27 13:07:00.790964 2021-07-27 13:27:47.431649 1 0 101991 +5044 2933 0 2021-07-20 13:58:20.155069 2021-07-21 08:47:15.358992 3 0 63366 +5043 2932 0 2021-07-20 13:33:08.093023 2021-07-20 13:53:30.395658 1 0 95717 +5042 2931 0 2021-07-20 13:05:52.42123 2021-07-20 13:26:00.167192 1 0 93527 +5041 2930 0 2021-07-13 14:25:38.476891 2021-07-20 13:00:21.735062 3 0 555648 +5040 2929 0 2021-07-13 14:00:48.195951 2021-07-13 14:20:29.343573 1 0 93528 +5039 2928 0 2021-07-13 13:34:19.476854 2021-07-13 13:54:24.493958 1 0 93440 +5038 2927 0 2021-07-09 11:38:17.615425 2021-07-13 13:29:02.124714 3 0 317209 +5037 2926 0 2021-07-08 18:23:39.064689 2021-07-08 18:25:29.477461 3 0 8 +5036 2925 0 2021-07-08 18:04:09.040666 2021-07-08 18:12:43.829269 3 0 38 +5035 2924 0 2021-07-07 12:55:35.555174 2021-07-07 13:16:21.568843 1 0 101447 +5034 2923 0 2021-07-07 12:17:35.809099 2021-07-07 12:52:04.984763 1 0 167921 +5033 2922 0 2021-07-07 12:09:13.558499 2021-07-07 12:13:23.290112 1 0 18835 +5032 2921 0 2021-06-29 08:55:30.354065 2021-07-07 12:05:53.778588 3 0 608956 +5031 2920 0 2021-06-28 15:41:31.597757 2021-06-29 08:49:41.893234 3 0 54354 +5030 2919 0 2021-06-28 15:23:07.682318 2021-06-28 15:36:54.50911 1 0 66765 +5029 2918 0 2021-06-28 15:05:29.857649 2021-06-28 15:18:44.797361 1 0 63937 +5028 2917 0 2021-06-27 00:08:21.566154 2021-06-28 14:57:38.208847 3 0 124943 +5027 2916 0 2021-06-26 08:09:54.793106 2021-06-27 00:03:11.821436 3 0 1442125 +5026 2915 0 2021-06-25 22:25:27.046108 2021-06-26 08:05:22.450818 3 0 872235 +5025 2914 0 2021-06-25 16:56:34.117645 2021-06-25 22:19:28.663537 3 0 484600 +5024 2913 0 2021-06-25 09:26:47.035089 2021-06-25 16:52:02.001874 3 0 664419 +5023 2912 0 2021-06-24 22:26:52.600864 2021-06-25 09:17:36.560274 3 0 1027234 +5022 2911 0 2021-06-24 12:46:17.677529 2021-06-24 22:20:24.825436 3 0 852563 +5021 2910 0 2021-06-24 12:26:54.228834 2021-06-24 12:41:46.423291 1 0 71226 +5020 2909 0 2021-06-24 12:08:56.97955 2021-06-24 12:22:34.499525 1 0 63946 +5019 2908 0 2021-06-24 08:00:41.428513 2021-06-24 12:02:32.390337 3 0 347955 +5018 2907 0 2021-06-24 02:59:58.149812 2021-06-24 07:48:52.676776 3 0 414640 +5017 2906 0 2021-06-23 22:35:32.955912 2021-06-24 02:52:57.204878 3 0 362429 +5016 2905 0 2021-06-23 20:03:50.78686 2021-06-23 22:29:21.814752 3 0 200645 +5015 2904 0 2021-06-23 16:41:35.031512 2021-06-23 19:57:35.226187 3 0 264182 +5014 2903 0 2021-06-23 09:56:38.313475 2021-06-23 16:29:44.500143 3 0 287405 +5013 2902 0 2021-06-22 22:14:17.177507 2021-06-23 09:41:36.521009 3 0 1024460 +5012 2901 0 2021-06-22 08:48:35.894584 2021-06-22 22:09:03.221969 3 0 1039212 +5011 2900 0 2021-06-21 16:06:00.930845 2021-06-22 08:42:50.747093 3 0 1508177 +5010 2899 0 2021-06-21 14:38:34.788729 2021-06-21 16:01:48.02451 3 0 56165 +5009 2898 0 2021-06-21 13:46:02.704786 2021-06-21 14:29:19.484717 3 0 21136 +5008 2897 0 2021-06-21 08:46:47.692829 2021-06-21 13:40:49.633938 3 0 452255 +5007 2896 0 2021-06-21 08:10:31.828675 2021-06-21 08:31:51.828609 3 0 32663 +5006 2895 0 2021-06-21 00:19:10.565772 2021-06-21 08:03:17.272392 3 0 710686 +5005 2894 0 2021-06-20 16:04:35.809101 2021-06-21 00:03:58.638431 3 0 706603 +5004 2893 0 2021-06-19 15:39:42.986305 2021-06-20 16:00:43.161027 3 0 2177447 +5003 2892 0 2021-06-18 13:29:05.474552 2021-06-19 15:33:04.531379 3 0 2152292 +5002 2891 0 2021-06-18 10:40:36.498792 2021-06-18 13:25:23.912799 3 0 66829 +5001 2890 0 2021-06-18 09:08:55.885453 2021-06-18 10:36:04.853199 3 0 112075 +5000 2889 0 2021-06-17 17:59:47.685051 2021-06-18 09:03:18.56761 3 0 1412183 +4999 2888 0 2021-06-17 16:34:34.260022 3 0 +4998 2887 0 2021-06-17 15:23:35.838422 2021-06-17 16:26:03.379913 3 0 97911 +4997 2886 0 2021-06-17 14:09:15.918982 3 0 +4996 2885 0 2021-06-17 06:19:18.615615 2021-06-17 14:05:16.189983 3 0 637190 +4995 2884 0 2021-06-16 06:30:13.859461 2021-06-17 05:59:03.830509 3 0 1038309 +4994 2883 0 2021-06-16 01:29:57.432986 2021-06-16 06:22:40.11009 3 0 428399 +4993 2882 0 2021-06-15 22:37:47.755667 3 0 +4992 2881 0 2021-06-15 14:43:20.452817 2021-06-15 22:32:15.854268 3 0 728502 +4991 2880 0 2021-06-15 10:20:54.352853 2021-06-15 14:39:45.167078 3 0 410823 +4990 2879 0 2021-06-15 10:00:39.889542 2021-06-15 10:18:03.222153 1 0 81593 +4989 2878 0 2021-06-15 09:40:02.448603 2021-06-15 09:56:54.8717 1 0 79451 +4988 2877 0 2021-06-14 14:36:36.895588 2021-06-15 09:35:31.14574 3 0 1617990 +4987 2876 0 2021-06-14 11:16:40.070317 2021-06-14 14:27:58.762286 3 0 292222 +4986 2875 0 2021-06-14 03:59:00.091788 2021-06-14 11:09:59.057094 3 0 654598 +4985 2874 0 2021-06-13 11:52:29.105816 2021-06-14 03:46:53.403943 3 0 1505185 +4984 2873 0 2021-06-13 09:10:03.827878 2021-06-13 11:48:22.614899 3 0 143764 +4983 2872 0 2021-06-12 21:53:31.979217 2021-06-13 09:03:51.969612 3 0 1063911 +4982 2871 0 2021-06-12 13:48:12.959214 2021-06-12 21:46:13.824238 3 0 778547 +4981 2870 0 2021-06-12 11:17:07.891596 2021-06-12 13:43:41.782218 3 0 224932 +4980 2869 0 2021-06-12 08:31:25.012733 2021-06-12 11:06:52.697245 3 0 227322 +4979 2868 0 2021-06-12 01:18:48.722146 2021-06-12 08:25:18.606649 3 0 628828 +4978 2867 0 2021-06-11 23:34:14.690309 3 0 +4977 2866 0 2021-06-11 21:49:26.757913 3 0 +4976 2865 0 2021-06-11 19:47:45.268322 2021-06-11 21:44:13.941765 3 0 167039 +4975 2864 0 2021-06-11 15:43:27.509007 2021-06-11 19:41:57.474142 3 0 355032 +4974 2863 0 2021-06-11 12:22:30.4803 2021-06-11 15:39:10.413683 3 0 162152 +4973 2862 0 2021-06-10 20:38:14.827329 2021-06-11 12:17:42.486673 3 0 1116524 +4972 2861 0 2021-06-10 13:38:05.97282 2021-06-10 20:33:22.333669 3 0 695685 +4971 2860 0 2021-06-10 13:21:20.692094 2021-06-10 13:35:13.596588 1 0 64938 +4970 2859 0 2021-06-10 13:04:55.942548 2021-06-10 13:18:11.696566 1 0 63516 +4969 2858 0 2021-06-09 13:00:18.121431 2021-06-10 12:59:30.422197 3 0 804373 +4968 2857 0 2021-06-08 15:45:45.426157 2021-06-09 12:56:42.851729 3 0 241956 +4967 2856 0 2021-06-08 09:33:57.53166 2021-06-08 15:40:32.477005 3 0 504053 +4966 2855 0 2021-06-08 04:29:51.411451 2021-06-08 09:27:27.578469 3 0 237480 +4965 2854 0 2021-06-07 20:01:39.918223 2021-06-08 04:24:46.856198 3 0 774633 +4964 2853 0 2021-06-07 16:13:13.872108 2021-06-07 19:54:21.442962 3 0 362405 +4963 2852 0 2021-06-07 13:15:09.562192 2021-06-07 16:06:35.840102 3 0 268187 +4962 2851 0 2021-06-06 14:27:34.805216 2021-06-07 13:10:01.253715 3 0 2267381 +4961 2850 0 2021-06-06 08:05:29.485111 2021-06-06 14:21:58.619261 3 0 612660 +4960 2849 0 2021-06-06 06:18:10.846017 3 0 +4959 2848 0 2021-06-05 22:54:55.864371 2021-06-06 06:13:28.144476 3 0 576042 +4958 2847 0 2021-06-05 18:55:43.117604 2021-06-05 22:48:12.034245 3 0 344750 +4957 2846 0 2021-06-05 11:43:08.07501 2021-06-05 18:50:05.436859 3 0 546015 +4956 2845 0 2021-06-05 03:20:24.698774 2021-06-05 11:34:49.498697 3 0 317495 +4955 2844 0 2021-06-04 08:17:44.219185 2021-06-05 03:15:37.86277 3 0 925176 +4954 2843 0 2021-06-03 22:38:47.569937 2021-06-04 08:12:00.833745 3 0 906656 +4953 2842 0 2021-06-03 17:59:32.68324 2021-06-03 22:33:37.73005 3 0 393957 +4952 2841 0 2021-06-03 17:40:44.516074 2021-06-03 17:54:41.705594 1 0 65284 +4951 2840 0 2021-06-03 17:23:37.486559 2021-06-03 17:37:26.234663 1 0 64864 +4950 2839 0 2021-06-03 00:44:10.023293 2021-06-03 17:17:58.777014 3 0 1064417 +4949 2838 0 2021-06-02 23:01:29.732751 3 0 +4948 2837 0 2021-06-02 19:08:28.44411 2021-06-02 22:54:26.608812 3 0 354560 +4947 2836 0 2021-06-02 15:04:17.169988 2021-06-02 19:03:08.127894 3 0 365622 +4946 2835 0 2021-06-02 08:45:24.247677 2021-06-02 14:53:20.87585 3 0 582858 +4945 2834 0 2021-06-01 17:03:08.057285 2021-06-02 08:38:11.556668 3 0 1243490 +4944 2833 0 2021-05-31 18:51:10.082836 2021-06-01 16:57:37.901651 3 0 2110887 +4943 2832 0 2021-05-31 12:41:16.235489 2021-05-31 18:45:40.02109 3 0 276341 +4942 2831 0 2021-05-31 11:38:37.894392 2021-05-31 12:36:54.044817 3 0 84886 +4941 2830 0 2021-05-31 08:18:16.627215 2021-05-31 11:33:12.611247 3 0 311698 +4940 2829 0 2021-05-31 06:52:50.27933 2021-05-31 08:10:52.344898 3 0 119135 +4939 2828 0 2021-05-30 23:40:57.187491 2021-05-31 06:47:06.995769 3 0 634017 +4938 2827 0 2021-05-30 17:54:42.608404 2021-05-30 23:35:28.819021 3 0 500148 +4937 2826 0 2021-05-30 13:42:38.633088 2021-05-30 17:48:41.482459 3 0 347580 +4936 2825 0 2021-05-30 13:39:43.13619 3 0 +4935 2824 0 2021-05-30 10:05:59.671088 2021-05-30 13:28:00.970483 3 0 277313 +4934 2823 0 2021-05-30 06:30:37.617734 2021-05-30 09:57:24.521429 3 0 297596 +4933 2822 0 2021-05-30 03:25:06.280787 2021-05-30 06:23:24.499417 3 0 170528 +4932 2821 0 2021-05-29 23:38:05.931568 2021-05-30 03:20:37.470349 3 0 326706 +4931 2820 0 2021-05-29 20:47:26.58525 2021-05-29 23:31:54.193239 3 0 231021 +4930 2819 0 2021-05-29 16:55:09.372944 2021-05-29 20:41:32.290524 3 0 321354 +4929 2818 0 2021-05-29 13:27:38.814245 2021-05-29 16:50:47.013728 3 0 287439 +4928 2817 0 2021-05-29 09:39:47.580157 2021-05-29 13:21:30.546187 3 0 313963 +4927 2816 0 2021-05-29 06:53:42.218461 2021-05-29 09:33:02.931595 3 0 209570 +4926 2815 0 2021-05-29 03:34:24.337061 2021-05-29 06:47:34.92335 3 0 260831 +4925 2814 0 2021-05-29 00:27:06.881006 2021-05-29 03:29:05.917606 3 0 243157 +4924 2813 0 2021-05-28 21:02:25.673124 2021-05-29 00:21:58.973063 3 0 272473 +4923 2812 0 2021-05-28 17:34:00.248428 2021-05-28 20:54:38.744239 3 0 276716 +4922 2811 0 2021-05-28 14:30:09.225368 2021-05-28 17:18:35.405562 3 0 227784 +4921 2810 0 2021-05-28 14:11:34.193917 2021-05-28 14:25:04.098868 1 0 63511 +4920 2809 0 2021-05-28 13:54:57.843189 2021-05-28 14:08:33.974326 1 0 64089 +4919 2808 0 2021-05-28 11:13:27.892889 2021-05-28 13:50:18.00469 3 0 209622 +4918 2807 0 2021-05-28 08:21:05.370911 2021-05-28 11:05:56.377772 3 0 224367 +4917 2806 0 2021-05-28 07:01:51.641822 2021-05-28 08:14:52.203222 3 0 27724 +4916 2805 0 2021-05-28 05:43:55.521476 3 0 +4915 2804 0 2021-05-27 16:54:30.680378 2021-05-28 05:35:38.409649 3 0 1218081 +4914 2803 0 2021-05-27 10:02:39.420419 2021-05-27 16:50:49.982348 3 0 396266 +4913 2802 0 2021-05-27 08:42:12.616283 2021-05-27 09:56:45.964124 3 0 14511 +4912 2801 0 2021-05-26 20:15:27.222642 2021-05-27 08:38:14.920113 3 0 481195 +4911 2800 0 2021-05-26 13:05:42.692443 2021-05-26 20:10:00.617422 3 0 483302 +4910 2799 0 2021-05-26 09:04:04.537942 2021-05-26 12:59:28.575765 3 0 343964 +4909 2798 0 2021-05-26 04:00:07.850388 2021-05-26 08:55:57.569647 3 0 424450 +4908 2797 0 2021-05-25 21:47:04.313981 2021-05-26 03:54:09.007346 3 0 519589 +4907 2796 0 2021-05-25 16:27:36.768529 2021-05-25 21:40:25.731983 3 0 422445 +4906 2795 0 2021-05-25 15:21:18.937759 2021-05-25 16:17:43.072466 3 0 117900 +4905 2794 0 2021-05-25 13:14:09.578994 2021-05-25 15:17:54.541734 3 0 250562 +4904 2793 0 2021-05-25 12:08:15.931905 2021-05-25 13:06:00.252175 3 0 56267 +4903 2792 0 2021-05-25 10:01:06.35314 2021-05-25 12:02:20.350817 3 0 181298 +4902 2791 0 2021-05-25 04:41:48.948381 2021-05-25 09:55:31.521571 3 0 508638 +4901 2790 0 2021-05-24 18:42:50.916367 2021-05-25 04:25:49.198038 3 0 827318 +4900 2789 0 2021-05-24 16:49:21.708837 2021-05-24 18:37:41.296851 3 0 113769 +4899 2788 0 2021-05-24 14:38:15.566648 2021-05-24 16:36:02.172149 3 0 182171 +4898 2787 0 2021-05-23 15:17:52.780875 2021-05-24 14:30:39.356623 3 0 1976147 +4897 2786 0 2021-05-22 15:37:23.114033 2021-05-23 15:13:00.42356 3 0 2084177 +4896 2785 0 2021-05-21 16:51:47.307209 2021-05-22 15:31:22.307339 3 0 2252543 +4895 2784 0 2021-05-21 14:53:33.378208 2021-05-21 16:46:13.881869 3 0 190571 +4894 2783 0 2021-05-20 15:37:10.810072 2021-05-21 14:46:33.91198 3 0 2291021 +4893 2782 0 2021-05-20 11:59:41.31149 2021-05-20 15:33:25.458352 3 0 353324 +4892 2781 0 2021-05-20 04:52:53.227737 2021-05-20 11:54:35.52957 3 0 538885 +4891 2780 0 2021-05-19 18:29:44.634243 2021-05-20 04:46:16.393544 3 0 997635 +4890 2779 0 2021-05-19 15:11:56.541445 2021-05-19 18:23:38.285037 3 0 182440 +4889 2778 0 2021-05-19 14:55:13.091031 2021-05-19 15:09:11.950252 1 0 65149 +4888 2777 0 2021-05-19 14:38:38.778925 2021-05-19 14:52:26.242621 1 0 63969 +4887 2776 0 2021-05-19 14:10:15.725509 2021-05-19 14:35:38.42513 3 0 15719 +4886 2775 0 2021-05-19 14:03:03.352066 2021-05-19 14:05:33.68991 1 0 10254 +4885 2774 0 2021-05-19 06:24:26.056413 2021-05-19 13:58:22.16623 3 0 313119 +4884 2773 0 2021-05-18 21:34:20.620161 2021-05-19 06:06:18.95403 3 0 649828 +4883 2772 0 2021-05-18 13:44:12.23365 2021-05-18 21:31:00.548065 3 0 721954 +4882 2771 0 2021-05-17 11:49:17.435219 2021-05-18 13:40:01.996139 3 0 2499220 +4881 2770 0 2021-05-16 18:42:01.88348 2021-05-17 11:40:16.957566 3 0 1510751 +4880 2769 0 2021-05-16 05:20:50.670915 2021-05-16 18:36:39.750375 3 0 379340 +4879 2768 0 2021-05-15 23:22:29.626963 2021-05-16 05:11:46.284972 3 0 575413 +4878 2767 0 2021-05-15 12:53:13.53655 2021-05-15 23:16:03.148251 3 0 1022985 +4877 2766 0 2021-05-15 12:35:50.457249 2021-05-15 12:50:10.544721 1 0 67274 +4876 2765 0 2021-05-15 12:18:39.226032 2021-05-15 12:32:24.475113 1 0 64937 +4875 2764 0 2021-05-15 00:52:28.528708 2021-05-15 12:11:40.538814 3 0 994383 +4874 2763 0 2021-05-14 18:07:58.874192 2021-05-15 00:47:01.875095 3 0 557394 +4873 2762 0 2021-05-14 11:04:49.395358 2021-05-14 17:56:14.424003 3 0 486031 +4872 2761 0 2021-05-14 07:10:51.918029 2021-05-14 10:50:30.158447 3 0 274441 +4871 2760 0 2021-05-14 03:02:10.644826 2021-05-14 07:01:38.367524 3 0 302245 +4870 2759 0 2021-05-13 23:00:17.896971 2021-05-14 02:54:47.004544 3 0 288136 +4869 2758 0 2021-05-13 19:52:25.94526 2021-05-13 22:52:39.800871 3 0 219885 +4868 2757 0 2021-05-13 18:15:36.724353 3 0 +4867 2756 0 2021-05-13 13:52:25.281691 2021-05-13 18:02:46.629631 3 0 318749 +4866 2755 0 2021-05-13 09:59:25.149352 2021-05-13 13:46:39.952443 3 0 187272 +4865 2754 0 2021-05-13 05:39:31.356769 2021-05-13 09:53:33.288189 3 0 319561 +4864 2753 0 2021-05-13 03:37:20.007615 3 0 +4863 2752 0 2021-05-13 02:18:59.529996 2021-05-13 03:27:47.826678 3 0 39686 +4862 2751 0 2021-05-12 22:37:52.410824 2021-05-13 02:12:43.634402 3 0 220260 +4861 2750 0 2021-05-12 19:21:50.64047 2021-05-12 22:31:47.773218 3 0 220776 +4860 2749 0 2021-05-12 10:25:16.960079 2021-05-12 19:17:07.832689 3 0 262871 +4859 2748 0 2021-05-12 10:06:15.057368 2021-05-12 10:19:55.383067 1 0 63868 +4858 2747 0 2021-05-12 09:48:38.874937 2021-05-12 10:02:19.008391 1 0 63633 +4857 2746 0 2021-05-12 06:28:45.142392 2021-05-12 09:41:58.525497 3 0 31543 +4856 2745 0 2021-05-12 03:25:07.66906 2021-05-12 06:22:32.582674 3 0 223875 +4855 2744 0 2021-05-11 23:38:55.201978 2021-05-12 03:19:30.876912 3 0 272456 +4854 2743 0 2021-05-11 21:29:59.347537 2021-05-11 23:30:42.868408 3 0 149386 +4853 2742 0 2021-05-11 17:15:50.597526 2021-05-11 21:21:57.20617 3 0 307296 +4852 2741 0 2021-05-11 09:51:47.8636 2021-05-11 17:09:16.834594 3 0 263335 +4851 2740 0 2021-05-11 05:25:35.936304 2021-05-11 09:45:58.417571 3 0 228119 +4850 2739 0 2021-05-11 02:59:23.788009 2021-05-11 05:19:00.546426 3 0 161559 +4849 2738 0 2021-05-11 00:27:54.217993 2021-05-11 02:54:34.39054 3 0 167559 +4848 2737 0 2021-05-10 22:00:12.303581 2021-05-11 00:20:55.311187 3 0 160165 +4847 2736 0 2021-05-10 17:35:57.225827 2021-05-10 21:39:39.85702 3 0 319438 +4846 2735 0 2021-05-10 12:57:20.752947 2021-05-10 17:29:50.623937 3 0 372286 +4845 2734 0 2021-05-10 10:28:12.091206 2021-05-10 12:51:46.867666 3 0 167525 +4844 2733 0 2021-05-10 04:20:15.603158 2021-05-10 10:22:38.200798 3 0 497934 +4843 2732 0 2021-05-10 03:55:34.127666 3 0 +4842 2731 0 2021-05-09 22:57:24.617616 2021-05-10 03:40:25.713671 3 0 380384 +4841 2730 0 2021-05-09 16:45:33.868681 2021-05-09 22:50:42.488022 3 0 502435 +4840 2729 0 2021-05-09 10:59:59.158799 2021-05-09 16:40:09.446771 3 0 491664 +4839 2728 0 2021-05-08 22:52:40.27804 2021-05-09 10:53:15.089408 3 0 947289 +4838 2727 0 2021-05-08 13:05:37.706433 2021-05-08 22:45:48.349656 3 0 634191 +4837 2726 0 2021-05-07 22:37:25.922099 2021-05-08 12:59:21.935132 3 0 956929 +4836 2725 0 2021-05-07 13:25:17.352299 2021-05-07 22:30:37.430459 3 0 761400 +4835 2724 0 2021-05-07 05:22:47.287287 2021-05-07 13:19:19.251498 3 0 359464 +4834 2723 0 2021-05-06 23:11:54.70864 2021-05-07 05:16:23.312478 3 0 507922 +4833 2722 0 2021-05-06 18:56:34.909126 2021-05-06 23:05:26.504659 3 0 244290 +4832 2721 0 2021-05-06 15:57:32.21691 2021-05-06 18:42:27.702142 3 0 201819 +4831 2720 0 2021-05-06 12:37:04.322369 2021-05-06 15:39:39.81081 3 0 227359 +4830 2719 0 2021-05-06 09:41:29.737939 2021-05-06 12:30:00.276486 3 0 204558 +4829 2718 0 2021-05-06 05:27:13.259001 2021-05-06 09:36:58.705033 3 0 347138 +4828 2717 0 2021-05-05 22:50:17.804965 2021-05-06 05:21:00.524595 3 0 531583 +4827 2716 0 2021-05-05 20:48:36.799685 2021-05-05 22:41:30.86187 3 0 141972 +4826 2715 0 2021-05-05 17:50:26.570259 2021-05-05 20:43:25.278715 3 0 213951 +4825 2714 0 2021-05-05 16:26:41.523989 3 0 +4824 2713 0 2021-05-05 16:07:33.633665 2021-05-05 16:21:13.898811 1 0 63577 +4823 2712 0 2021-05-05 15:50:01.111539 2021-05-05 16:03:33.462715 1 0 63360 +4822 2711 0 2021-05-05 14:02:27.33606 2021-05-05 15:45:29.470034 3 0 147081 +4821 2710 0 2021-05-05 09:48:50.172982 2021-05-05 13:55:18.599789 3 0 351507 +4820 2709 0 2021-05-05 06:19:49.637427 2021-05-05 09:42:25.024857 3 0 294346 +4819 2708 0 2021-05-04 19:40:38.431589 2021-05-05 06:07:42.407176 3 0 943941 +4818 2707 0 2021-05-04 12:09:50.510979 2021-05-04 19:36:23.247906 3 0 737791 +4817 2706 0 2021-05-03 14:07:40.729038 2021-05-04 12:05:24.530852 3 0 2304780 +4816 2705 0 2021-05-02 09:06:41.121259 2021-05-03 14:03:53.940152 3 0 2974657 +4815 2704 0 2021-05-01 20:41:38.315688 2021-05-02 09:00:43.337034 3 0 1277663 +4814 2703 0 2021-05-01 20:20:22.996578 2021-05-01 20:26:54.817742 3 0 10005 +4813 2702 0 2021-05-01 20:11:07.35218 2021-05-01 20:17:59.282172 9 0 88504 +4812 2701 0 2021-05-01 19:36:37.071103 2021-05-01 20:07:30.815099 3 0 50835 +4811 2700 0 2021-05-01 18:53:58.576258 2021-05-01 19:33:07.758101 3 0 64978 +4810 2699 0 2021-05-01 16:19:50.346758 3 0 +4809 2698 0 2021-05-01 11:08:02.075202 2021-05-01 16:07:33.999342 3 0 453072 +4808 2697 0 2021-05-01 10:49:54.364759 2021-05-01 11:03:41.520325 1 0 63846 +4807 2696 0 2021-05-01 10:32:20.674908 2021-05-01 10:46:07.359619 1 0 63628 +4806 2695 0 2021-05-01 08:22:55.973699 2021-05-01 10:21:44.793279 3 0 176445 +4805 2694 0 2021-04-30 21:56:51.22126 2021-05-01 08:16:47.55319 3 0 947652 +4804 2693 0 2021-04-28 22:48:26.397676 2021-04-30 21:48:15.825783 3 0 4653235 +4803 2692 0 2021-04-28 17:19:34.250755 2021-04-28 22:44:32.938227 3 0 572983 +4802 2691 0 2021-04-28 16:01:16.127479 2021-04-28 17:13:47.991176 3 0 125194 +4801 2690 0 2021-04-28 15:42:52.896123 2021-04-28 15:56:43.346984 1 0 64098 +4800 2689 0 2021-04-28 15:23:50.839386 2021-04-28 15:39:06.007325 1 0 71253 +4799 2688 0 2021-04-26 16:50:40.249169 2021-04-28 15:20:09.73084 3 0 5463575 +4798 2687 0 2021-04-26 16:34:23.437312 2021-04-26 16:48:12.126644 1 0 63473 +4797 2686 0 2021-04-26 16:15:58.21541 2021-04-26 16:30:26.339493 1 0 66535 +4796 2685 0 2021-04-23 13:20:52.11917 2021-04-26 16:12:00.10761 3 0 8399856 +4795 2684 0 2021-04-23 13:03:53.186813 2021-04-23 13:17:52.759221 1 0 64200 +4794 2683 0 2021-04-23 12:46:04.912188 2021-04-23 12:59:48.489015 1 0 63653 +4793 2682 0 2021-04-23 03:14:36.050494 2021-04-23 12:41:58.927656 3 0 929240 +4792 2681 0 2021-04-22 12:49:59.396468 2021-04-23 03:02:49.176464 3 0 1434390 +4791 2680 0 2021-04-22 10:15:14.81515 2021-04-22 12:47:23.334451 4 0 2495 +4790 2679 0 2021-04-22 09:01:41.019046 2021-04-22 10:12:51.846985 5 0 1168 +4789 2678 0 2021-04-22 07:09:10.847449 2021-04-22 08:56:50.605262 3 0 21708 +4788 2677 0 2021-04-21 17:41:07.889108 2021-04-22 07:06:10.011143 3 0 1384292 +4787 2676 0 2021-04-21 17:02:17.4162 2021-04-21 17:37:42.641097 5 0 576 +4786 2675 0 2021-04-21 14:53:47.856136 2021-04-21 16:59:41.231344 5 0 2055 +4785 2674 0 2021-04-21 13:18:32.219263 2021-04-21 14:45:15.451359 5 0 2357 +4784 2673 0 2021-04-21 12:40:10.022791 2021-04-21 13:12:55.536262 5 0 1079 +4783 2672 0 2021-04-21 11:32:39.795119 2021-04-21 12:37:35.883305 5 0 1063 +4782 2671 0 2021-04-21 10:11:21.488949 2021-04-21 11:30:42.881339 5 0 4673 +4781 2670 0 2021-04-21 09:04:34.473044 2021-04-21 10:08:22.715456 4 0 1038 +4780 2669 0 2021-04-21 06:23:42.218168 2021-04-21 08:14:15.163154 3 0 5142 +4779 2668 0 2021-04-21 03:21:59.417858 2021-04-21 06:11:47.277447 3 0 199106 +4778 2667 0 2021-04-20 22:16:52.485363 2021-04-21 03:16:13.919082 3 0 407711 +4777 2666 0 2021-04-20 16:53:39.421584 2021-04-20 22:09:46.035917 3 0 427130 +4776 2665 0 2021-04-20 16:36:22.140276 2021-04-20 16:49:27.351437 1 0 64129 +4775 2664 0 2021-04-20 16:19:57.822185 2021-04-20 16:32:54.518265 1 0 63638 +4774 2663 0 2021-04-20 14:48:05.19786 2021-04-20 16:15:46.463347 3 0 113247 +4773 2662 0 2021-04-20 10:38:56.882871 2021-04-20 14:41:07.561419 3 0 319118 +4772 2661 0 2021-04-20 05:05:48.260039 2021-04-20 10:32:42.447262 3 0 462406 +4771 2660 0 2021-04-19 20:34:56.370428 2021-04-20 05:00:59.20281 3 0 723868 +4770 2659 0 2021-04-19 12:00:31.953795 2021-04-19 20:30:05.220162 3 0 771174 +4769 2658 0 2021-04-19 04:35:06.265763 2021-04-19 11:53:17.546955 3 0 618434 +4768 2657 0 2021-04-18 21:37:52.842837 2021-04-19 04:15:49.670662 3 0 543188 +4767 2656 0 2021-04-18 16:44:34.255981 2021-04-18 21:28:44.795353 3 0 356518 +4766 2655 0 2021-04-18 11:25:29.572675 2021-04-18 16:38:38.922354 3 0 431082 +4765 2654 0 2021-04-18 04:27:39.567444 2021-04-18 11:18:05.167371 3 0 567268 +4764 2653 0 2021-04-17 21:14:39.674599 2021-04-18 04:12:11.190872 3 0 593627 +4763 2652 0 2021-04-17 13:42:52.299407 2021-04-17 21:08:44.182106 3 0 636632 +4762 2651 0 2021-04-17 13:25:24.459995 2021-04-17 13:38:12.938591 1 0 63826 +4761 2650 0 2021-04-17 13:09:11.053706 2021-04-17 13:21:57.773608 1 0 63761 +4760 2649 0 2021-04-17 08:42:42.550456 2021-04-17 13:04:55.618043 3 0 370219 +4759 2648 0 2021-04-17 00:56:08.000696 2021-04-17 08:27:22.729617 3 0 559494 +4758 2647 0 2021-04-16 22:38:48.293771 2021-04-17 00:31:11.470453 3 0 139230 +4757 2646 0 2021-04-15 12:25:56.413209 2021-04-16 22:32:37.269055 3 0 3677227 +4756 2645 0 2021-04-15 12:09:37.622645 2021-04-15 12:22:44.964485 1 0 64903 +4755 2644 0 2021-04-15 11:52:39.902964 2021-04-15 12:05:44.9387 1 0 64534 +4754 2643 0 2021-04-13 16:52:56.996483 2021-04-15 11:46:20.29999 3 0 5003211 +4753 2642 0 2021-04-13 16:37:01.762688 2021-04-13 16:50:14.133308 1 0 65072 +4752 2641 0 2021-04-13 16:20:24.826523 2021-04-13 16:33:39.222278 1 0 65340 +4751 2640 0 2021-04-13 16:04:27.580132 2021-04-13 16:17:18.36268 1 0 64195 +4750 2639 0 2021-04-11 14:27:42.597147 2021-04-13 15:57:21.216971 3 0 5722780 +4749 2638 0 2021-04-11 14:07:59.681076 2021-04-11 14:21:38.792167 1 0 67454 +4748 2637 0 2021-04-11 13:51:45.882653 2021-04-11 14:04:41.132641 1 0 64070 +4747 2636 0 2021-04-09 15:42:27.038569 2021-04-11 13:47:36.476029 3 0 4483071 +4746 2635 0 2021-04-09 15:23:14.803663 2021-04-09 15:36:14.726436 1 0 64719 +4745 2634 0 2021-04-09 15:06:15.958503 2021-04-09 15:19:02.30964 1 0 63213 +4744 2633 0 2021-04-07 16:14:09.180934 2021-04-09 15:02:31.098356 3 0 5120755 +4743 2632 0 2021-04-07 15:54:44.992458 2021-04-07 16:08:09.816422 1 0 66289 +4742 2631 0 2021-04-07 15:38:01.883615 2021-04-07 15:51:17.976134 1 0 65783 +4741 2630 0 2021-04-07 09:40:14.663043 2021-04-07 15:34:08.226735 3 0 593282 +4740 2629 0 2021-04-07 08:35:12.567146 2021-04-07 09:36:26.818956 3 0 82409 +4739 2628 0 2021-04-06 20:58:47.216045 2021-04-07 08:31:09.362118 3 0 1352643 +4738 2627 0 2021-04-06 18:10:02.873203 2021-04-06 20:54:16.197339 3 0 247609 +4737 2626 0 2021-04-06 15:09:32.483886 2021-04-06 18:05:29.309425 3 0 294947 +4736 2625 0 2021-04-06 14:27:17.798428 2021-04-06 15:04:04.798135 3 0 68331 +4735 2624 0 2021-04-05 16:00:28.392756 2021-04-06 14:24:05.264459 3 0 2619922 +4734 2623 0 2021-04-05 15:44:25.525984 2021-04-05 15:57:37.771556 1 0 65418 +4733 2622 0 2021-04-05 15:28:32.772744 2021-04-05 15:41:37.093394 1 0 65230 +4732 2621 0 2021-04-05 10:17:13.790695 2021-04-05 15:25:10.774018 3 0 683300 +4731 2620 0 2021-04-04 04:06:16.996475 2021-04-05 10:10:48.72835 3 0 3433713 +4730 2619 0 2021-04-04 01:44:21.028678 2021-04-04 03:55:17.868597 3 0 267148 +4729 2618 0 2021-04-03 14:09:42.171147 2021-04-04 01:39:43.287582 3 0 1266934 +4728 2617 0 2021-04-03 13:53:44.840248 2021-04-03 14:06:41.83418 1 0 63591 +4727 2616 0 2021-04-03 13:37:24.021157 2021-04-03 13:50:43.885823 1 0 64541 +4726 2615 0 2021-04-03 13:33:56.990292 2021-04-03 13:34:18.64834 1 0 475 +4725 2614 0 2021-04-02 04:53:31.306346 2021-04-03 13:29:53.66886 3 0 3740686 +4724 2613 0 2021-04-02 02:02:35.663925 2021-04-02 04:49:42.950447 3 0 272380 +4723 2612 0 2021-04-01 12:28:09.650363 2021-04-02 01:53:54.115947 3 0 1542259 +4722 2611 0 2021-03-30 08:52:39.617485 2021-04-01 12:24:25.536563 3 0 6026688 +4721 2610 0 2021-03-29 22:33:42.088401 2021-03-30 08:50:06.575921 3 0 1156503 +4720 2609 0 2021-03-29 09:54:51.334551 2021-03-29 22:29:05.320886 3 0 1357140 +4719 2608 0 2021-03-29 06:35:42.379353 2021-03-29 09:48:26.159446 3 0 272754 +4718 2607 0 2021-03-29 04:59:57.496158 3 0 +4717 2606 0 2021-03-29 02:29:26.369717 3 0 +4716 2605 0 2021-03-28 13:56:00.97306 2021-03-29 02:26:01.515227 3 0 350439 +4715 2604 0 2021-03-27 14:44:53.391356 2021-03-28 13:51:49.884818 3 0 2660207 +4714 2603 0 2021-03-27 14:27:22.185757 2021-03-27 14:41:18.015527 1 0 69012 +4713 2602 0 2021-03-27 14:09:43.807415 2021-03-27 14:23:34.705592 1 0 68320 +4712 2601 0 2021-03-26 14:18:45.419652 2021-03-27 14:01:49.153719 3 0 2869116 +4711 2600 0 2021-03-26 10:32:55.460597 2021-03-26 14:15:01.815928 3 0 516615 +4710 2599 0 2021-03-24 22:00:03.849361 2021-03-26 10:29:15.58278 3 0 4309799 +4709 2598 0 2021-03-24 02:17:57.760702 2021-03-24 21:49:06.579316 3 0 2260623 +4708 2597 0 2021-03-23 18:21:59.589889 2021-03-24 02:13:12.948585 3 0 583002 +4707 2596 0 2021-03-23 17:11:45.133665 2021-03-23 18:14:38.645779 3 0 66131 +4706 2595 0 2021-03-23 13:58:20.822812 2021-03-23 16:24:23.707287 4 0 2415 +4705 2594 0 2021-03-23 09:57:49.389937 2021-03-23 12:48:06.426427 4 0 2798 +4704 2593 0 2021-03-23 00:49:25.873858 2021-03-23 08:17:21.402008 3 0 243042 +4703 2592 0 2021-03-22 18:45:06.857209 2021-03-23 00:43:27.913884 3 0 647608 +4702 2591 0 2021-03-22 13:08:25.789182 2021-03-22 18:32:31.694357 3 0 162486 +4701 2590 0 2021-03-21 12:16:45.873507 2021-03-22 13:04:34.589015 3 0 3472519 +4700 2589 0 2021-03-20 14:43:53.426588 2021-03-21 12:09:31.018652 3 0 2949183 +4699 2588 0 2021-03-20 14:26:31.511768 2021-03-20 14:39:42.151083 1 0 65519 +4698 2587 0 2021-03-20 14:07:56.589133 2021-03-20 14:20:58.349346 1 0 64871 +4697 2586 0 2021-03-19 13:38:25.542618 2021-03-20 14:03:26.482119 3 0 3342276 +4696 2585 0 2021-03-18 11:20:07.37415 2021-03-19 13:34:50.733064 3 0 710339 +4695 2584 0 2021-03-17 08:57:33.356725 2021-03-18 11:15:16.291806 3 0 3005974 +4694 2583 0 2021-03-17 06:31:00.069115 2021-03-17 08:54:04.997982 3 0 222022 +4693 2582 0 2021-03-15 22:40:33.108038 2021-03-17 06:25:36.646076 3 0 3119146 +4692 2581 0 2021-03-15 22:00:20.051548 2021-03-15 22:36:55.180569 3 0 85561 +4691 2580 0 2021-03-15 18:37:06.791616 2021-03-15 21:56:41.883071 3 0 207271 +4690 2579 0 2021-03-15 18:06:10.887452 2021-03-15 18:32:11.04121 3 0 22526 +4689 2578 0 2021-03-15 09:34:31.545098 2021-03-15 18:02:33.852978 3 0 695346 +4688 2577 0 2021-03-13 16:06:37.692864 2021-03-15 09:30:55.64234 3 0 4658560 +4687 2576 0 2021-03-13 14:30:13.505123 3 0 +4686 2575 0 2021-03-13 14:14:13.792117 2021-03-13 14:27:26.361462 1 0 64060 +4685 2574 0 2021-03-13 13:58:06.129614 2021-03-13 14:10:54.727659 1 0 63877 +4684 2573 0 2021-03-12 17:11:14.529334 2021-03-13 13:52:01.267134 3 0 2594097 +4683 2572 0 2021-03-12 15:30:01.674945 2021-03-12 17:07:49.654462 3 0 83136 +4682 2571 0 2021-03-11 23:59:46.206147 2021-03-12 15:24:50.254917 3 0 1644998 +4681 2570 0 2021-03-11 16:56:03.155477 2021-03-11 23:56:08.893191 3 0 713876 +4680 2569 0 2021-03-11 14:10:14.272114 2021-03-11 16:51:13.97781 3 0 284777 +4679 2568 0 2021-03-11 11:33:08.801241 2021-03-11 13:58:53.259636 3 0 188637 +4678 2567 0 2021-03-11 09:54:42.231875 2021-03-11 11:29:23.442384 3 0 122636 +4677 2566 0 2021-03-11 06:07:47.059223 2021-03-11 09:48:57.86809 3 0 344923 +4676 2565 0 2021-03-10 23:25:33.022083 2021-03-11 06:02:03.482914 3 0 669004 +4675 2564 0 2021-03-10 20:07:05.900203 2021-03-10 23:18:41.027861 3 0 289236 +4674 2563 0 2021-03-10 16:51:31.383897 2021-03-10 20:01:26.545519 3 0 275452 +4673 2562 0 2021-03-10 14:07:51.363964 2021-03-10 16:44:58.653533 3 0 209584 +4672 2561 0 2021-03-10 12:41:53.215916 3 0 +4671 2560 0 2021-03-10 09:13:56.669173 2021-03-10 12:36:59.269588 3 0 168294 +4670 2559 0 2021-03-10 06:09:51.028132 2021-03-10 09:07:59.351096 3 0 140169 +4669 2558 0 2021-03-10 02:59:45.341472 2021-03-10 06:03:15.097475 3 0 141965 +4668 2557 0 2021-03-09 22:40:09.715013 2021-03-10 02:51:13.820931 3 0 311670 +4667 2556 0 2021-03-09 11:48:34.047054 2021-03-09 22:33:58.679586 3 0 1032989 +4666 2555 0 2021-03-08 21:24:52.879166 2021-03-09 11:45:48.532949 3 0 1802573 +4665 2554 0 2021-03-08 18:46:07.404696 2021-03-08 21:20:54.716792 3 0 286309 +4664 2553 0 2021-03-08 07:49:31.135661 2021-03-08 18:39:56.055073 3 0 803513 +4663 2552 0 2021-03-07 13:43:56.92049 2021-03-08 07:46:21.751822 3 0 2003743 +4662 2551 0 2021-03-06 13:25:51.796387 2021-03-07 13:35:02.364619 3 0 3191393 +4661 2550 0 2021-03-06 13:08:22.655416 2021-03-06 13:22:39.165118 1 0 65050 +4660 2549 0 2021-03-06 12:50:13.448884 2021-03-06 13:04:41.797899 1 0 65925 +4659 2548 0 2021-03-05 17:31:17.921161 2021-03-06 12:45:07.140972 3 0 2623305 +4658 2547 0 2021-03-05 16:27:20.322156 2021-03-05 17:26:48.908357 3 0 116427 +4657 2546 0 2021-03-05 14:20:30.083625 2021-03-05 16:19:05.685787 3 0 168888 +4656 2545 0 2021-03-05 11:08:42.326096 2021-03-05 14:16:24.513939 3 0 385788 +4655 2544 0 2021-03-05 08:08:20.909048 2021-03-05 11:04:02.402725 3 0 299062 +4654 2543 0 2021-03-04 16:32:48.666168 2021-03-05 08:04:34.295047 3 0 2059449 +4653 2542 0 2021-03-04 15:11:24.701708 2021-03-04 16:28:25.635475 3 0 109343 +4652 2541 0 2021-03-03 22:20:43.761577 2021-03-04 15:05:34.758565 3 0 2168286 +4651 2540 0 2021-03-03 20:43:35.053569 2021-03-03 22:17:44.165804 3 0 183131 +4650 2539 0 2021-03-03 16:59:40.015784 2021-03-03 20:31:42.166144 3 0 291839 +4649 2538 0 2021-03-03 13:38:57.132672 2021-03-03 16:54:41.747655 3 0 272641 +4648 2537 0 2021-03-02 15:54:40.822648 2021-03-03 13:33:30.915835 3 0 2912043 +4647 2536 0 2021-02-28 21:49:35.542049 2021-03-02 15:50:48.19155 3 0 5642610 +4646 2535 0 2021-02-28 16:43:44.400544 2021-02-28 21:46:07.775023 3 0 587689 +4645 2534 0 2021-02-28 13:22:50.225359 2021-02-28 16:37:31.989996 3 0 275140 +4644 2533 0 2021-02-28 09:38:55.006504 2021-02-28 13:16:06.958197 3 0 312226 +4643 2532 0 2021-02-28 06:05:04.838351 2021-02-28 09:32:13.715414 3 0 292664 +4642 2531 0 2021-02-28 05:21:41.452009 2021-02-28 06:01:30.136941 3 0 55171 +4641 2530 0 2021-02-28 02:48:42.259442 3 0 +4640 2529 0 2021-02-28 02:33:05.990877 2021-02-28 02:45:00.201395 3 0 8593 +4639 2528 0 2021-02-27 22:47:23.206994 2021-02-28 02:14:45.426218 3 0 287275 +4638 2527 0 2021-02-27 19:58:31.690636 2021-02-27 22:41:31.353599 3 0 215642 +4637 2526 0 2021-02-27 17:54:59.809756 2021-02-27 19:52:10.870518 3 0 137277 +4636 2525 0 2021-02-27 13:42:37.764032 2021-02-27 17:45:36.554304 3 0 332365 +4635 2524 0 2021-02-27 13:21:46.772208 2021-02-27 13:36:35.787777 1 0 63486 +4634 2523 0 2021-02-27 13:02:07.629505 2021-02-27 13:17:39.602734 1 0 66577 +4633 2522 0 2021-02-27 06:26:32.694904 2021-02-27 12:57:08.678365 3 0 809098 +4632 2521 0 2021-02-26 23:36:02.697095 2021-02-27 06:22:28.613126 3 0 908636 +4631 2520 0 2021-02-26 20:45:55.810703 2021-02-26 23:28:30.251403 3 0 119242 +4630 2519 0 2021-02-26 18:00:03.00428 2021-02-26 20:36:34.24731 3 0 110988 +4629 2518 0 2021-02-26 17:42:01.886887 2021-02-26 17:56:45.153702 9 0 6366 +4628 2517 0 2021-02-26 16:52:07.767417 2021-02-26 17:38:39.46701 3 0 32250 +4627 2516 0 2021-02-26 16:22:21.867578 2021-02-26 16:46:31.54591 3 0 17301 +4626 2515 0 2021-02-26 12:26:15.453797 2021-02-26 16:15:02.286265 3 0 386512 +4625 2514 0 2021-02-26 09:47:58.486496 2021-02-26 12:21:12.073767 3 0 200999 +4624 2513 0 2021-02-26 07:04:24.134593 2021-02-26 09:42:02.929534 3 0 383727 +4623 2512 0 2021-02-25 22:44:02.740925 2021-02-26 07:00:20.898255 3 0 655285 +4622 2511 0 2021-02-25 21:27:35.696841 2021-02-25 22:39:01.564904 3 0 89714 +4621 2510 0 2021-02-25 17:58:17.324281 2021-02-25 21:24:02.219737 3 0 492745 +4620 2509 0 2021-02-25 11:04:54.387571 2021-02-25 17:54:59.072846 3 0 614233 +4619 2508 0 2021-02-24 19:09:30.338682 2021-02-25 11:01:26.557018 3 0 1859759 +4618 2507 0 2021-02-24 16:24:12.900139 2021-02-24 19:04:35.570371 3 0 182022 +4617 2506 0 2021-02-24 15:38:35.718131 2021-02-24 16:20:42.825612 3 0 62216 +4616 2505 0 2021-02-24 13:41:29.621004 3 0 +4615 2504 0 2021-02-23 17:11:54.469534 2021-02-24 13:37:47.486966 3 0 1079576 +4614 2503 0 2021-02-23 16:01:34.046756 2021-02-23 17:08:58.667813 3 0 51529 +4613 2502 0 2021-02-23 06:25:56.193151 2021-02-23 15:56:55.83565 3 0 506767 +4612 2501 0 2021-02-22 12:57:38.130499 2021-02-23 06:22:40.907432 3 0 2282396 +4611 2500 0 2021-02-22 10:48:59.154239 2021-02-22 12:54:18.303629 3 0 258107 +4610 2499 0 2021-02-21 17:10:01.682566 2021-02-21 17:15:50.116494 3 0 12238 +4609 2498 0 2021-02-21 16:49:22.380809 2021-02-21 17:04:30.727055 3 0 33503 +4608 2497 0 2021-02-21 16:33:37.194888 2021-02-21 16:46:04.672418 9 0 0 +4607 2496 0 2021-02-21 15:28:44.924343 2021-02-21 16:29:14.415049 3 0 80058 +4606 2495 0 2021-02-21 10:05:52.825624 2021-02-21 15:20:19.061569 3 0 443876 +4605 2494 0 2021-02-20 12:32:14.047035 2021-02-21 10:02:20.925698 3 0 1757369 +4604 2493 0 2021-02-20 12:13:48.553607 2021-02-20 12:29:01.217994 1 0 70984 +4603 2492 0 2021-02-20 11:52:59.775878 2021-02-20 12:09:54.309508 1 0 78503 +4602 2491 0 2021-02-20 11:35:10.394892 2021-02-20 11:49:06.786628 1 0 64292 +4601 2490 0 2021-02-19 04:55:43.325175 3 0 +4600 2489 0 2021-02-19 04:27:08.123827 2021-02-19 04:42:38.233235 3 0 29944 +4599 2488 0 2021-02-18 21:34:07.993314 2021-02-19 04:21:48.601829 3 0 799584 +4598 2487 0 2021-02-18 17:59:17.254512 2021-02-18 21:21:42.267859 3 0 384275 +4597 2486 0 2021-02-18 11:11:52.503127 2021-02-18 17:47:31.181624 3 0 786372 +4596 2485 0 2021-02-18 05:15:47.963842 2021-02-18 10:58:21.630112 3 0 712204 +4595 2484 0 2021-02-17 22:57:58.389859 2021-02-18 05:12:30.186242 3 0 725126 +4594 2483 0 2021-02-16 18:56:07.733485 2021-02-17 22:50:09.077397 3 0 3216251 +4593 2482 0 2021-02-16 16:41:47.064002 2021-02-16 18:43:02.703145 3 0 230108 +4592 2481 0 2021-02-16 05:24:57.499486 2021-02-16 16:36:02.994546 3 0 1270782 +4591 2480 0 2021-02-15 19:47:05.788206 2021-02-16 05:20:49.87009 3 0 1080979 +4590 2479 0 2021-02-15 16:23:42.9748 2021-02-15 19:39:40.324258 3 0 366453 +4589 2478 0 2021-02-15 15:50:12.755694 2021-02-15 16:15:22.591768 3 0 47277 +4588 2477 0 2021-02-15 15:44:29.35981 2021-02-15 15:46:57.160794 3 0 822 +4587 2476 0 2021-02-15 15:17:07.117715 2021-02-15 15:34:02.390299 3 0 33488 +4586 2475 1 2021-02-15 15:05:21.988114 3 0 +4585 2475 0 2021-02-15 13:32:46.379124 2021-02-15 14:55:49.779714 3 0 155353 +4584 2474 0 2021-02-15 12:25:29.826843 2021-02-15 13:28:36.906589 3 0 112036 +4583 2473 0 2021-02-15 11:59:35.930176 3 0 +4582 2472 0 2021-02-15 11:45:17.912718 3 0 +4581 2471 0 2021-02-13 16:54:32.371527 2021-02-15 09:07:38.692531 3 0 4626114 +4580 2470 0 2021-02-12 18:18:02.707789 2021-02-13 16:48:44.845303 3 0 2850849 +4579 2469 0 2021-02-12 18:00:45.387038 2021-02-12 18:14:24.959743 1 0 63494 +4578 2468 0 2021-02-12 17:43:25.685996 2021-02-12 17:57:07.394926 1 0 63564 +4577 2467 0 2021-02-12 17:25:57.879394 2021-02-12 17:39:39.930976 1 0 64018 +4576 2466 0 2021-02-12 14:48:08.073439 2021-02-12 17:21:52.791228 3 0 340966 +4575 2465 0 2021-02-12 14:10:33.258099 2021-02-12 14:33:52.12086 3 0 49071 +4574 2464 0 2021-02-12 13:16:16.654033 2021-02-12 13:52:56.01749 3 0 80215 +4573 2463 0 2021-02-12 11:42:33.448498 2021-02-12 13:09:56.588632 3 0 194199 +4572 2462 0 2021-02-12 03:07:50.244911 2021-02-12 11:09:46.666663 3 0 1140000 +4571 2461 0 2021-02-12 01:44:57.746266 3 0 +4570 2460 0 2021-02-11 20:37:17.174353 2021-02-12 01:41:54.386346 3 0 662067 +4569 2459 0 2021-02-11 19:25:25.249615 2021-02-11 20:26:33.019516 3 0 119235 +4568 2458 0 2021-02-11 17:35:23.739413 2021-02-11 19:15:39.767317 3 0 213863 +4567 2457 0 2021-02-11 12:37:45.512686 2021-02-11 17:25:23.754565 3 0 627468 +4566 2456 0 2021-02-11 11:07:49.649774 2021-02-11 12:34:31.775169 3 0 126981 +4565 2455 0 2021-02-11 07:22:14.233559 2021-02-11 11:03:47.935952 3 0 380408 +4564 2454 0 2021-02-10 04:27:19.718829 2021-02-11 07:15:57.125301 3 0 3320308 +4563 2453 0 2021-02-08 11:40:36.550469 2021-02-10 03:55:52.74654 3 0 4615979 +4562 2452 0 2021-02-08 11:24:20.75205 2021-02-08 11:37:55.230442 1 0 63231 +4561 2451 0 2021-02-08 11:05:18.162638 2021-02-08 11:20:37.438388 1 0 68649 +4560 2450 0 2021-02-07 23:46:34.113857 2021-02-08 11:01:11.488507 3 0 1283281 +4559 2449 0 2021-02-07 16:00:17.807627 2021-02-07 23:29:37.241463 3 0 826792 +4558 2448 0 2021-02-07 02:14:48.493962 2021-02-07 15:52:14.752535 3 0 1370167 +4557 2447 0 2021-02-06 23:14:36.50984 2021-02-07 01:52:17.404237 3 0 310416 +4556 2446 0 2021-02-06 17:01:30.321618 2021-02-06 23:08:00.563097 3 0 429404 +4555 2445 0 2021-02-06 16:20:35.379499 2021-02-06 16:57:27.521319 3 0 27943 +4554 2444 0 2021-02-04 06:29:56.227596 2021-02-06 16:15:52.124071 3 0 1401684 +4553 2443 0 2021-02-03 20:43:21.795715 2021-02-04 06:25:55.89306 3 0 327415 +4552 2442 0 2021-02-03 12:20:57.263003 2021-02-03 20:40:09.518614 3 0 274256 +4551 2441 0 2021-02-03 11:42:42.549064 2021-02-03 11:56:33.072129 1 0 63833 +4550 2440 0 2021-02-03 11:25:57.9741 2021-02-03 11:39:39.601655 1 0 63650 +4549 2439 0 2021-02-03 05:27:49.756167 2021-02-03 11:22:18.656158 3 0 197991 +4548 2438 0 2021-02-03 01:55:32.770711 2021-02-03 05:21:15.01975 3 0 362674 +4547 2437 0 2021-01-30 23:43:34.749174 2021-02-03 01:49:45.328011 3 0 7897977 +4546 2436 0 2021-01-30 20:40:32.355173 2021-01-30 23:35:56.22725 3 0 317258 +4545 2435 0 2021-01-30 15:47:26.961188 2021-01-30 20:35:52.735886 3 0 537192 +4544 2434 0 2021-01-29 11:38:56.484262 2021-01-30 15:43:50.286527 3 0 3031066 +4543 2433 0 2021-01-29 11:21:59.160491 2021-01-29 11:35:49.516415 1 0 64446 +4542 2432 0 2021-01-29 11:03:52.848444 2021-01-29 11:18:13.97298 1 0 64382 +4541 2431 0 2021-01-28 01:54:45.601487 2021-01-29 10:58:58.497313 3 0 3539281 +4540 2430 0 2021-01-27 09:39:33.448563 2021-01-28 01:47:25.269022 3 0 1611859 +4539 2429 0 2021-01-27 06:16:38.790332 2021-01-27 09:29:28.248706 3 0 335522 +4538 2428 0 2021-01-24 18:55:09.939294 2021-01-27 06:07:09.367833 3 0 6637048 +4537 2427 0 2021-01-24 18:38:40.271298 2021-01-24 18:52:11.411676 1 0 63413 +4536 2426 0 2021-01-24 18:21:50.947692 2021-01-24 18:35:32.672724 1 0 63490 +4535 2425 0 2021-01-24 11:59:41.499208 2021-01-24 18:18:39.351551 3 0 721255 +4534 2424 0 2021-01-23 15:40:00.221433 2021-01-24 11:50:37.213845 3 0 2319258 +4533 2423 0 2021-01-21 15:55:11.264095 2021-01-23 15:27:08.673008 3 0 5139053 +4532 2422 0 2021-01-21 06:24:43.217148 2021-01-21 15:47:57.709075 3 0 327181 +4531 2421 0 2021-01-20 14:12:42.014665 2021-01-21 06:15:02.695212 3 0 1429859 +4530 2420 0 2021-01-20 13:51:47.867331 2021-01-20 14:05:39.082842 1 0 63825 +4529 2419 0 2021-01-20 13:29:59.190934 2021-01-20 13:43:42.508459 1 0 64422 +4528 2418 0 2021-01-20 13:10:12.918114 2021-01-20 13:24:28.771708 1 0 67287 +4527 2417 0 2021-01-20 12:52:26.978298 2021-01-20 13:06:19.071252 1 0 65312 +4526 2416 0 2021-01-20 12:35:16.386996 2021-01-20 12:48:43.035721 1 0 63455 +4525 2415 0 2021-01-20 12:17:01.422117 2021-01-20 12:30:33.522719 1 0 63493 +4524 2414 0 2021-01-20 11:59:26.932632 2021-01-20 12:13:05.578168 1 0 64133 +4523 2413 0 2021-01-20 02:35:31.333621 2021-01-20 11:55:32.610282 3 0 488308 +4522 2412 0 2021-01-19 08:50:32.238653 2021-01-20 02:29:24.641693 3 0 1867541 +4521 2411 0 2021-01-18 18:41:47.397772 2021-01-19 08:15:12.715712 3 0 1443602 +4520 2410 0 2021-01-18 11:22:06.09819 2021-01-18 18:21:39.419944 3 0 749865 +4519 2409 0 2021-01-18 11:16:07.456735 3 0 +4518 2408 0 2021-01-18 11:02:00.925369 2021-01-18 11:03:06.726477 3 0 1296 +4517 2407 0 2021-01-18 10:42:51.432945 2021-01-18 10:43:33.206664 3 0 633 +4516 2406 0 2021-01-18 10:31:58.471859 3 0 +4515 2405 0 2021-01-18 10:29:32.845028 3 0 +4514 2404 0 2021-01-18 10:17:43.603456 3 0 +4513 2403 0 2021-01-18 09:47:55.246359 3 0 +4512 2402 0 2021-01-18 09:28:24.284581 3 0 +4511 2401 0 2021-01-18 08:31:31.71258 2021-01-18 09:22:48.826035 3 0 167459 +4510 2400 0 2021-01-18 07:46:08.028204 3 0 +4509 2399 0 2021-01-18 07:33:26.856594 3 0 +4508 2398 0 2021-01-17 14:33:34.837378 2021-01-18 07:30:21.395422 3 0 1847201 +4507 2397 0 2021-01-17 03:35:47.309736 2021-01-17 14:20:34.982269 3 0 1236241 +4506 2396 0 2021-01-16 14:17:25.591333 2021-01-17 03:22:28.103505 3 0 1516015 +4505 2395 0 2021-01-16 14:01:25.625424 2021-01-16 14:15:10.788395 1 0 63795 +4504 2394 0 2021-01-16 13:44:50.532503 2021-01-16 13:58:22.334185 1 0 63405 +4503 2393 0 2021-01-15 16:08:01.154374 2021-01-16 13:41:49.981664 3 0 2509062 +4502 2392 0 2021-01-15 16:05:36.827603 9 0 +4501 2391 0 2021-01-13 18:57:09.738377 2021-01-15 16:03:11.957199 3 0 4870739 +4500 2390 0 2021-01-13 13:54:09.855422 2021-01-13 18:53:53.418016 3 0 122008 +4499 2389 0 2021-01-13 13:35:40.886012 2021-01-13 13:49:08.655719 1 0 63223 +4498 2388 0 2021-01-13 13:15:54.703031 2021-01-13 13:29:32.662401 1 0 64206 +4497 2387 0 2021-01-13 12:58:17.938052 2021-01-13 13:11:58.085228 1 0 64171 +4496 2386 0 2021-01-13 12:39:34.784685 1 0 +4495 2385 0 2021-01-13 12:22:33.559817 2021-01-13 12:36:10.025888 1 0 63734 +4494 2384 0 2021-01-13 12:04:10.900623 2021-01-13 12:17:56.081421 1 0 64908 +4493 2383 0 2021-01-13 11:54:13.554321 3 0 +4492 2382 0 2021-01-13 11:51:06.079839 3 0 +4491 2381 0 2021-01-13 06:21:21.844347 2021-01-13 11:47:44.35561 3 0 97399 +4490 2380 0 2021-01-12 13:22:19.005782 2021-01-13 06:18:19.03692 3 0 1876506 +4489 2379 0 2021-01-12 13:18:54.859974 2021-01-12 13:19:49.982895 3 0 3227 +4488 2378 0 2021-01-10 16:24:17.981732 2021-01-12 13:06:48.350142 3 0 4439285 +4487 2377 0 2021-01-10 16:08:08.912244 2021-01-10 16:21:44.574098 1 0 63394 +4486 2376 0 2021-01-10 15:51:42.804207 2021-01-10 16:05:16.715965 1 0 63388 +4485 2375 0 2021-01-09 12:00:38.994124 2021-01-10 15:48:33.757052 3 0 2043406 +4484 2374 0 2021-01-08 06:58:07.619819 2021-01-09 11:48:47.356635 3 0 2122879 +4483 2373 0 2021-01-08 06:11:57.784527 2021-01-08 06:42:56.14337 3 0 37190 +4482 2372 0 2021-01-08 02:47:58.945059 2021-01-08 05:58:05.890998 3 0 226376 +4481 2371 0 2021-01-07 13:01:56.416922 2021-01-08 02:44:13.800271 3 0 739048 +4480 2370 0 2021-01-06 21:27:02.320137 2021-01-07 12:57:11.306446 3 0 681030 +4479 2369 0 2021-01-06 14:21:06.100466 2021-01-06 21:21:15.084339 3 0 428189 +4478 2368 0 2021-01-05 12:42:21.42947 2021-01-06 13:34:40.575782 3 0 1868422 +4477 2367 0 2021-01-05 12:24:49.90451 2021-01-05 12:38:42.120479 1 0 64763 +4476 2366 0 2021-01-05 12:06:56.229435 2021-01-05 12:21:11.631722 1 0 66590 +4475 2365 0 2021-01-04 17:28:06.505699 2021-01-05 12:02:26.125312 3 0 1399341 +4474 2364 0 2021-01-03 18:27:19.704845 2021-01-04 17:22:44.447407 3 0 1683307 +4473 2363 0 2021-01-02 17:30:45.357987 2021-01-03 18:19:06.767133 3 0 1805472 +4472 2362 0 2020-12-31 11:30:47.157139 2021-01-02 17:26:53.026523 3 0 4042627 +4471 2361 0 2020-12-31 11:27:43.877721 2020-12-31 11:28:09.208141 1 0 891 +4470 2360 0 2020-12-31 11:10:18.014964 2020-12-31 11:24:23.310112 1 0 65843 +4469 2359 0 2020-12-31 10:53:15.061696 2020-12-31 11:06:54.841589 1 0 63673 +4468 2358 0 2020-12-31 02:56:55.640315 2020-12-31 10:50:24.795544 3 0 592235 +4467 2357 0 2020-12-30 22:52:30.005159 2020-12-31 02:54:47.254477 3 0 137515 +4466 2356 0 2020-12-30 06:59:48.986497 2020-12-30 22:49:25.469108 3 0 1130831 +4465 2355 0 2020-12-28 12:52:43.545213 2020-12-30 06:57:18.2489 3 0 3145772 +4464 2354 0 2020-12-28 12:33:49.360242 2020-12-28 12:48:05.149311 1 0 66556 +4463 2353 0 2020-12-28 12:17:06.759999 2020-12-28 12:30:48.654297 1 0 64516 +4462 2352 0 2020-12-26 21:10:09.358567 2020-12-28 11:57:30.698794 3 0 2845766 +4461 2351 0 2020-12-26 15:01:12.852439 2020-12-26 21:07:35.676613 3 0 136362 +4460 2350 0 2020-12-26 14:44:30.513276 2020-12-26 14:58:22.331406 1 0 65023 +4459 2349 0 2020-12-26 14:27:31.969346 2020-12-26 14:41:05.627941 1 0 63290 +4458 2348 0 2020-12-25 14:22:12.114345 2020-12-26 14:22:10.78214 3 0 109473 +4457 2347 0 2020-12-24 16:32:14.079324 2020-12-25 14:19:21.501676 3 0 1074984 +4456 2346 0 2020-12-24 09:45:53.437993 2020-12-24 16:23:38.008526 3 0 485872 +4455 2345 0 2020-12-23 13:14:57.266219 2020-12-24 09:36:52.393184 3 0 1525964 +4454 2344 0 2020-12-23 12:57:57.001928 2020-12-23 13:11:54.404965 1 0 65237 +4453 2343 0 2020-12-23 12:40:49.761298 2020-12-23 12:54:40.392691 1 0 65154 +4452 2342 0 2020-12-23 07:45:38.431795 2020-12-23 12:37:32.085257 3 0 347867 +4451 2341 0 2020-12-21 14:40:07.536038 2020-12-23 07:42:07.133649 3 0 2990526 +4450 2340 0 2020-12-21 14:22:59.127403 2020-12-21 14:36:40.275276 1 0 63365 +4449 2339 0 2020-12-21 14:03:13.577034 2020-12-21 14:19:49.768106 1 0 77668 +4448 2338 0 2020-12-21 10:37:41.874338 2020-12-21 13:59:28.979903 3 0 132314 +4447 2337 0 2020-12-21 10:34:54.505395 9 0 +4446 2336 0 2020-12-21 10:28:05.820815 9 0 +4445 2335 0 2020-12-21 10:24:18.748328 9 0 +4444 2334 0 2020-12-21 10:14:49.326262 9 0 +4443 2333 0 2020-12-19 18:57:04.180006 2020-12-21 09:44:49.219328 3 0 1069603 +4442 2332 0 2020-12-19 15:43:36.259864 2020-12-19 18:52:47.870528 3 0 10949 +4441 2331 0 2020-12-19 15:26:14.976434 2020-12-19 15:39:50.817706 1 0 63542 +4440 2330 0 2020-12-19 15:07:52.966378 2020-12-19 15:21:53.620899 1 0 65730 +4439 2329 0 2020-12-19 11:47:57.089695 2020-12-19 15:04:41.900043 3 0 11385 +4438 2328 0 2020-12-18 20:46:07.93258 2020-12-18 20:50:28.687599 3 0 20 +4437 2327 0 2020-12-18 20:14:46.135227 2020-12-18 20:20:26.538242 3 0 26 +4436 2326 0 2020-12-18 19:50:42.221935 2020-12-18 19:53:51.807281 3 0 26 +4435 2325 0 2020-12-18 19:40:51.721565 2020-12-18 19:42:16.87432 3 0 6 +4434 2324 0 2020-12-18 19:36:36.602699 3 0 +4433 2323 0 2020-12-18 19:34:31.750938 3 0 +4432 2322 0 2020-12-18 19:31:47.351033 3 0 +4431 2321 0 2020-12-18 19:30:11.017826 3 0 +4430 2320 0 2020-12-18 19:15:43.074859 3 0 +4429 2319 0 2020-12-18 19:12:08.027349 2020-12-18 19:12:45.266066 1 0 0 +4428 2318 0 2020-12-18 19:04:49.306023 3 0 +4427 2317 0 2020-12-18 19:01:59.713478 3 0 +4426 2316 0 2020-12-18 19:00:31.091019 3 0 +4425 2315 0 2020-12-18 18:55:59.520295 3 0 +4424 2314 0 2020-12-18 18:47:45.471463 3 0 +4423 2313 0 2020-12-18 18:39:44.509875 3 0 +4422 2312 0 2020-12-18 18:19:16.170348 3 0 +4421 2311 0 2020-12-18 17:37:53.568615 3 0 +4420 2310 0 2020-12-18 17:28:44.205359 3 0 +4419 2309 0 2020-12-18 16:40:02.221292 3 0 +4418 2308 0 2020-12-18 16:13:06.886131 3 0 +4417 2307 0 2020-12-18 16:08:30.165766 3 0 +4416 2306 0 2020-12-18 11:17:07.530202 2020-12-18 11:18:18.912326 1 0 4 +4415 2305 0 2020-12-18 01:57:53.09496 9 0 +4414 2304 0 2020-12-18 01:43:31.943243 3 0 +4413 2303 0 2020-12-18 01:30:55.883136 2020-12-18 01:31:41.553425 4 0 4 +4412 2302 0 2020-12-18 01:00:14.79713 3 0 +4411 2301 0 2020-12-18 00:52:58.410039 3 0 +4410 2300 0 2020-12-17 21:04:15.98853 3 0 +4409 2299 0 2020-12-17 20:31:51.109321 3 0 +4408 2298 0 2020-12-17 20:25:55.581672 3 0 +4407 2297 0 2020-12-17 20:21:13.619943 3 0 +4406 2296 0 2020-12-17 20:16:55.858228 3 0 +4405 2295 0 2020-12-16 08:51:30.020962 2020-12-17 19:33:26.659199 3 0 1155268 +4404 2294 0 2020-12-15 13:22:59.646273 2020-12-16 08:47:11.566782 3 0 627372 +4403 2293 0 2020-12-15 13:06:17.959356 2020-12-15 13:19:56.381653 1 0 63796 +4402 2292 0 2020-12-15 12:48:35.30853 2020-12-15 13:02:44.508425 1 0 66136 +4401 2291 0 2020-12-13 01:10:52.853748 2020-12-15 12:44:30.381283 3 0 2070301 +4400 2290 0 2020-12-12 10:07:18.35949 2020-12-13 01:05:13.057355 3 0 513862 +4399 2289 0 2020-12-11 13:40:53.454324 2020-12-12 10:01:50.271877 3 0 700927 +4398 2288 0 2020-12-11 09:45:46.721833 2020-12-11 13:37:41.408748 3 0 96209 +4397 2287 0 2020-12-11 09:27:29.918474 2020-12-11 09:41:51.781706 1 0 65920 +4396 2286 0 2020-12-11 09:08:29.792676 2020-12-11 09:23:48.55313 1 0 71183 +4395 2285 0 2020-12-10 09:48:56.707802 2020-12-11 09:04:35.623175 3 0 707413 +4394 2284 0 2020-12-10 09:30:42.269236 2020-12-10 09:45:45.69521 1 0 70373 +4393 2283 0 2020-12-10 09:12:45.516826 2020-12-10 09:26:56.591495 1 0 65955 +4392 2282 0 2020-12-10 01:08:24.3994 2020-12-10 09:07:14.409625 3 0 308131 +4391 2281 0 2020-12-09 01:12:06.441769 2020-12-10 01:05:19.819398 3 0 920559 +4390 2280 0 2020-12-08 11:54:03.966893 2020-12-09 01:09:04.8209 3 0 451177 +4389 2279 0 2020-12-08 11:36:50.02295 2020-12-08 11:51:18.488695 1 0 66743 +4388 2278 0 2020-12-08 11:19:18.046021 2020-12-08 11:33:03.50226 1 0 64660 +4387 2277 0 2020-12-07 18:48:08.602179 2020-12-08 09:25:23.516798 4 0 48586 +4386 2276 0 2020-12-06 21:14:51.798396 2020-12-07 18:45:03.473922 4 0 71876 +4385 2275 0 2020-12-05 21:45:21.848318 2020-12-06 21:12:19.412673 4 0 79674 +4384 2274 0 2020-12-05 08:13:33.840275 2020-12-05 21:42:43.495669 4 0 76219 +4383 2273 0 2020-12-04 09:13:35.703351 2020-12-05 08:09:39.660483 4 0 76188 +4382 2272 0 2020-12-03 12:03:54.705105 2020-12-04 09:10:38.2719 4 0 68536 +4381 2271 0 2020-12-02 12:03:33.167408 2020-12-03 11:10:07.36794 4 0 67785 +4380 2270 0 2020-12-01 19:28:24.633705 2020-12-02 12:00:01.445379 4 0 47606 +4379 2269 0 2020-12-01 08:20:38.916362 2020-12-01 18:34:03.714449 4 0 32107 +4378 2268 0 2020-11-30 19:03:18.364808 2020-12-01 08:16:14.136314 4 0 41234 +4377 2267 0 2020-11-30 07:54:50.261508 2020-11-30 18:11:48.196275 4 0 37228 +4376 2266 0 2020-11-29 19:06:56.937324 2020-11-30 07:51:08.169935 4 0 57746 +4375 2265 0 2020-11-29 10:41:44.812333 2020-11-29 18:15:10.981897 4 0 28902 +4374 2264 0 2020-11-28 20:07:01.242478 2020-11-29 10:38:12.584475 4 0 53576 +4373 2263 0 2020-11-28 11:45:21.836234 2020-11-28 18:21:32.296889 4 0 39998 +4372 2262 0 2020-11-28 07:04:23.168773 2020-11-28 11:13:08.940571 4 0 25517 +4371 2261 0 2020-11-27 18:53:16.859218 2020-11-28 06:52:49.561649 4 0 99426 +4370 2260 0 2020-11-27 11:24:52.958502 2020-11-27 18:17:01.518546 4 0 48659 +4369 2259 0 2020-11-26 22:17:17.826899 2020-11-27 10:36:39.596591 4 0 57480 +4368 2258 0 2020-11-26 13:58:15.187965 2020-11-26 21:36:57.807891 4 0 61491 +4367 2257 0 2020-11-25 22:38:43.409198 2020-11-26 13:29:52.160759 4 0 73868 +4366 2256 0 2020-11-25 17:09:14.353539 2020-11-25 22:22:57.694473 4 0 42675 +4365 2255 0 2020-11-25 09:35:11.097957 2020-11-25 16:34:25.072768 4 0 49652 +4364 2254 0 2020-11-24 21:32:20.651936 2020-11-25 08:49:13.365301 4 0 90846 +4363 2253 0 2020-11-24 16:25:54.811969 2020-11-24 20:35:46.018866 4 0 33475 +4362 2252 0 2020-11-24 09:25:57.476017 2020-11-24 15:38:30.810695 4 0 50316 +4361 2251 0 2020-11-23 21:11:44.328866 2020-11-24 08:54:42.217988 4 0 36502 +4360 2250 0 2020-11-23 16:37:49.405282 2020-11-23 20:30:10.767849 4 0 31152 +4359 2249 0 2020-11-23 11:22:13.397523 2020-11-23 16:00:26.098798 4 0 37222 +4358 2248 0 2020-11-22 23:19:55.282295 2020-11-23 10:13:47.382829 4 0 53063 +4357 2247 0 2020-11-22 21:20:06.21667 2020-11-22 23:14:28.144575 4 0 11687 +4356 2246 0 2020-11-22 18:52:35.324301 2020-11-22 21:16:19.365789 4 0 5450 +4355 2245 0 2020-11-22 17:41:34.145039 2020-11-22 18:17:53.623487 3 0 20847 +4354 2244 0 2020-11-22 17:23:13.747823 2020-11-22 17:37:12.849786 1 0 65804 +4353 2243 0 2020-11-22 17:07:04.287945 2020-11-22 17:20:40.075933 1 0 63998 +4352 2242 0 2020-11-22 10:39:08.240403 2020-11-22 16:59:45.855492 4 0 33956 +4351 2241 0 2020-11-22 00:07:53.950983 2020-11-22 09:35:04.748204 4 0 75893 +4350 2240 0 2020-11-21 18:07:40.553388 2020-11-22 00:03:55.751761 4 0 36960 +4349 2239 0 2020-11-21 12:56:14.391549 2020-11-21 17:30:11.170405 4 0 27783 +4348 2238 0 2020-11-21 08:09:39.098038 2020-11-21 12:22:50.329235 4 0 24783 +4347 2237 0 2020-11-20 21:44:35.18241 2020-11-21 08:05:24.517248 4 0 13381 +4346 2236 0 2020-11-20 19:20:32.370257 2020-11-20 21:42:42.670504 4 0 2644 +4345 2235 0 2020-11-20 16:46:12.792901 2020-11-20 17:52:01.318755 3 0 37370 +4344 2234 0 2020-11-20 08:41:37.138971 2020-11-20 16:43:20.616063 4 0 54151 +4343 2233 0 2020-11-19 21:45:10.013456 2020-11-20 07:45:24.799981 4 0 48533 +4342 2232 0 2020-11-19 17:12:56.396469 2020-11-19 21:02:37.384628 4 0 29253 +4341 2231 0 2020-11-19 13:58:38.192235 2020-11-19 16:58:34.952519 4 0 24164 +4340 2230 0 2020-11-19 09:40:00.992015 2020-11-19 13:27:07.859223 4 0 30435 +4339 2229 0 2020-11-19 06:22:35.080813 2020-11-19 09:03:23.184089 4 0 21595 +4338 2228 0 2020-11-18 20:17:29.98062 2020-11-19 06:14:16.780388 4 0 80328 +4337 2227 0 2020-11-18 11:52:34.920109 2020-11-18 19:28:16.642037 4 0 33223 +4336 2226 0 2020-11-17 20:01:34.372762 2020-11-18 09:51:46.796259 4 0 44585 +4335 2225 0 2020-11-17 13:52:17.045018 2020-11-17 19:21:26.992691 4 0 19704 +4334 2224 0 2020-11-17 09:26:26.323451 2020-11-17 13:01:51.199023 4 0 28751 +4333 2223 0 2020-11-16 20:16:05.687616 2020-11-17 08:45:32.893194 4 0 78987 +4332 2222 0 2020-11-16 15:53:09.137225 2020-11-16 19:22:37.875074 4 0 20550 +4331 2221 0 2020-11-16 14:24:23.93572 4 0 +4330 2220 0 2020-11-16 14:05:21.145291 2020-11-16 14:20:31.309301 4 0 894 +4329 2219 0 2020-11-16 11:45:33.455164 2020-11-16 13:48:49.875821 4 0 2745 +4328 2218 0 2020-11-15 19:19:40.924661 2020-11-16 09:09:01.204995 3 0 33489 +4327 2217 0 2020-11-15 18:56:05.390001 2020-11-15 19:09:58.408512 1 0 64072 +4326 2216 0 2020-11-15 18:36:26.62882 2020-11-15 18:52:09.073315 1 0 72900 +4325 2215 0 2020-11-15 18:12:15.513739 2020-11-15 18:25:56.972421 1 0 65562 +4324 2214 0 2020-11-15 17:53:22.00955 2020-11-15 18:08:39.471351 1 0 73158 +4323 2213 0 2020-11-15 13:41:23.461634 2020-11-15 17:39:11.146063 3 0 9444 +4322 2212 0 2020-11-14 21:02:49.785923 4 0 +4321 2211 0 2020-11-14 20:41:37.432716 2020-11-14 20:55:28.255146 1 0 64268 +4320 2210 0 2020-11-14 20:23:51.979189 2020-11-14 20:37:33.326781 1 0 64945 +4319 2209 0 2020-11-14 19:57:10.089504 2020-11-14 20:14:08.596556 1 0 80319 +4318 2208 0 2020-11-14 19:40:17.897762 2020-11-14 19:54:05.667464 1 0 65172 +4317 2207 0 2020-11-13 21:01:14.435793 2020-11-14 19:36:01.270594 4 0 108711 +4316 2206 0 2020-11-13 20:41:22.899669 2020-11-13 20:55:06.688269 1 0 65415 +4315 2205 0 2020-11-13 20:24:35.986017 2020-11-13 20:38:13.853237 1 0 65115 +4314 2204 0 2020-11-13 20:21:15.323777 2020-11-13 20:21:30.195447 1 0 251 +4313 2203 0 2020-11-13 19:59:26.497111 2020-11-13 20:13:08.891889 1 0 64642 +4312 2202 0 2020-11-13 19:41:43.231608 2020-11-13 19:55:49.805343 1 0 66457 +4311 2201 0 2020-11-13 19:36:10.639715 2020-11-13 19:36:50.641758 1 0 1825 +4310 2200 0 2020-11-12 13:09:58.790045 2020-11-13 19:32:47.611511 4 0 145261 +4309 2199 0 2020-11-11 05:55:56.892848 2020-11-12 08:55:56.287473 4 0 128157 +4308 2198 0 2020-11-10 18:31:40.073189 2020-11-11 05:46:24.177317 4 0 11263 +4307 2197 0 2020-11-10 17:10:01.126165 2020-11-10 17:24:18.970275 1 0 67285 +4306 2196 0 2020-11-10 16:51:53.604148 2020-11-10 17:05:51.356316 1 0 64832 +4305 2195 0 2020-11-10 16:29:41.294922 2020-11-10 16:43:41.630701 1 0 65176 +4304 2194 0 2020-11-10 16:01:26.208487 2020-11-10 16:15:14.213049 1 0 64084 +4303 2193 0 2020-11-09 19:25:12.584856 2020-11-10 15:56:45.133349 3 0 248794 +4302 2192 0 2020-11-09 19:01:59.145769 2020-11-09 19:16:40.104956 1 0 67853 +4301 2191 0 2020-11-09 18:42:13.20269 2020-11-09 18:57:08.113958 1 0 69788 +4300 2190 0 2020-11-09 18:17:25.678322 2020-11-09 18:31:09.005551 1 0 64039 +4299 2189 0 2020-11-09 18:00:25.707933 2020-11-09 18:14:08.007813 1 0 63437 +4298 2188 0 2020-11-09 09:11:21.603268 2020-11-09 17:57:04.59627 3 0 121432 +4297 2187 0 2020-11-08 20:55:38.53919 2020-11-09 08:44:45.530351 3 0 162733 +4296 2186 0 2020-11-08 20:33:29.754099 2020-11-08 20:47:49.069887 1 0 67080 +4295 2185 0 2020-11-08 20:15:59.508938 2020-11-08 20:29:54.841076 1 0 64165 +4294 2184 0 2020-11-08 19:53:51.352969 2020-11-08 20:08:12.28076 1 0 66389 +4293 2183 0 2020-11-08 19:35:57.505816 2020-11-08 19:50:36.087332 1 0 68566 +4292 2182 0 2020-11-07 17:23:45.039017 2020-11-08 19:32:09.470971 3 0 365701 +4291 2181 0 2020-11-07 17:01:36.742573 2020-11-07 17:15:24.814555 1 0 64294 +4290 2180 0 2020-11-07 16:43:46.45961 2020-11-07 16:57:33.045387 1 0 64275 +4289 2179 0 2020-11-07 16:20:34.112129 2020-11-07 16:34:04.341195 1 0 63398 +4288 2178 0 2020-11-07 16:04:23.263093 2020-11-07 16:17:53.652273 1 0 63433 +4287 2177 0 2020-11-07 12:48:09.413392 2020-11-07 16:00:32.563216 3 0 44960 +4286 2176 0 2020-11-06 20:15:39.752318 2020-11-07 12:45:22.262365 3 0 242429 +4285 2175 0 2020-11-06 19:53:57.375569 2020-11-06 20:07:56.963419 1 0 64866 +4284 2174 0 2020-11-06 19:27:52.193061 2020-11-06 19:41:30.595524 1 0 63861 +4283 2173 0 2020-11-06 19:05:20.632339 2020-11-06 19:19:05.238924 1 0 63415 +4282 2172 0 2020-11-06 18:48:00.979934 2020-11-06 19:01:32.229322 1 0 63513 +4281 2171 0 2020-11-05 21:45:38.989115 2020-11-06 18:43:04.144246 3 0 300578 +4280 2170 0 2020-11-05 21:25:11.403206 2020-11-05 21:39:04.783593 1 0 64986 +4279 2169 0 2020-11-05 21:07:16.712552 2020-11-05 21:21:01.162429 1 0 64601 +4278 2168 0 2020-11-05 20:45:57.464869 2020-11-05 20:59:52.219055 1 0 65147 +4277 2167 0 2020-11-05 20:27:42.046453 2020-11-05 20:41:39.490444 1 0 65398 +4276 2166 0 2020-11-04 21:25:19.805093 2020-11-05 20:22:39.521066 3 0 308476 +4275 2165 0 2020-11-04 21:03:09.442579 2020-11-04 21:17:27.516092 1 0 66588 +4274 2164 0 2020-11-04 20:44:59.424942 2020-11-04 20:58:39.159145 1 0 63898 +4273 2163 0 2020-11-04 20:19:53.900752 2020-11-04 20:34:30.938901 1 0 67563 +4272 2162 0 2020-11-04 20:01:58.155244 2020-11-04 20:15:46.990289 1 0 64655 +4271 2161 0 2020-11-03 19:44:47.855926 2020-11-04 19:57:48.648515 3 0 597972 +4270 2160 0 2020-11-03 19:17:59.132814 2020-11-03 19:32:47.433163 1 0 69272 +4269 2159 0 2020-11-03 18:57:57.034936 2020-11-03 19:13:01.874198 1 0 70265 +4268 2158 0 2020-11-03 18:33:05.432382 2020-11-03 18:47:59.778998 1 0 69523 +4267 2157 0 2020-11-03 17:41:08.289644 2020-11-03 18:28:12.272563 1 0 222438 +4266 2156 0 2020-11-02 19:52:02.651839 2020-11-03 17:37:23.564587 3 0 531626 +4265 2155 0 2020-11-02 19:30:11.698944 2020-11-02 19:44:15.259188 1 0 65787 +4264 2154 0 2020-11-02 19:12:09.290747 2020-11-02 19:26:09.702996 1 0 65645 +4263 2153 0 2020-11-02 18:48:54.425128 2020-11-02 19:03:44.722311 1 0 67947 +4262 2152 0 2020-11-02 18:29:44.250736 2020-11-02 18:43:45.935133 1 0 65246 +4261 2151 0 2020-11-01 17:48:02.245698 2020-11-02 18:24:37.226393 3 0 589882 +4260 2150 0 2020-11-01 17:22:44.334677 2020-11-01 17:37:49.866372 1 0 70004 +4259 2149 0 2020-11-01 16:55:37.669678 2020-11-01 17:09:49.118353 1 0 66216 +4258 2148 0 2020-11-01 16:33:48.986215 2020-11-01 16:47:48.543992 1 0 65023 +4257 2147 0 2020-11-01 16:15:36.029324 2020-11-01 16:29:42.997054 1 0 65762 +4256 2146 0 2020-10-31 17:25:23.300787 2020-11-01 16:11:35.897334 3 0 580336 +4255 2145 0 2020-10-31 17:04:49.625586 2020-10-31 17:18:51.719475 1 0 64686 +4254 2144 0 2020-10-31 16:47:57.319864 2020-10-31 17:01:42.147346 1 0 64155 +4253 2143 0 2020-10-31 16:24:14.838274 2020-10-31 16:40:05.496111 1 0 73744 +4252 2142 0 2020-10-31 16:06:25.470097 2020-10-31 16:20:45.94721 1 0 66789 +4251 2141 0 2020-10-30 17:25:01.998592 2020-10-31 16:02:15.271135 3 0 503444 +4250 2140 0 2020-10-30 17:03:40.98055 2020-10-30 17:18:19.804261 1 0 68430 +4249 2139 0 2020-10-30 16:45:16.900032 2020-10-30 16:59:23.487368 1 0 65666 +4248 2138 0 2020-10-30 16:21:13.735054 2020-10-30 16:35:22.23357 1 0 66164 +4247 2137 0 2020-10-30 16:04:24.201287 2020-10-30 16:18:08.45598 1 0 63450 +4246 2136 0 2020-10-29 14:04:49.237485 2020-10-30 16:00:24.562503 3 0 443776 +4245 2135 0 2020-10-28 15:57:40.196572 2020-10-29 11:06:42.852617 3 0 481987 +4244 2134 0 2020-10-28 13:50:09.42541 2020-10-28 14:03:50.258033 1 0 64742 +4243 2133 0 2020-10-28 13:32:59.647153 2020-10-28 13:46:28.917528 1 0 63847 +4242 2132 0 2020-10-28 13:07:04.832839 2020-10-28 13:23:50.387777 1 0 78923 +4241 2131 0 2020-10-28 12:50:44.883972 2020-10-28 13:04:17.850865 1 0 63483 +4240 2130 0 2020-10-28 12:27:17.732119 2020-10-28 12:40:30.588148 1 0 61912 +4239 2129 0 2020-10-28 12:09:09.604151 2020-10-28 12:23:55.191732 1 0 69253 +4238 2128 0 2020-10-28 07:27:32.616037 2020-10-28 08:30:27.613089 3 0 22681 +4237 2127 0 2020-10-28 06:02:28.966175 2020-10-28 06:08:23.54122 3 0 2095 +4236 2126 0 2020-10-27 17:02:17.652138 2020-10-27 17:08:52.610098 3 0 2103 +4235 2125 0 2020-10-27 16:39:27.88679 2020-10-27 16:42:42.782272 3 0 1203 +4234 2124 0 2020-10-27 15:24:38.100156 2020-10-27 15:38:00.05983 1 0 62976 +4233 2123 0 2020-10-27 15:06:56.386543 2020-10-27 15:20:35.080168 1 0 64034 +4232 2122 0 2020-10-27 15:04:05.92441 2020-10-27 15:04:40.946832 1 0 1681 +4231 2121 0 2020-10-27 14:41:15.91575 2020-10-27 14:54:56.541815 1 0 64577 +4230 2120 0 2020-10-27 14:23:36.100705 2020-10-27 14:37:00.821417 1 0 63030 +4229 2119 0 2020-10-26 15:03:53.843794 2020-10-26 16:05:35.810568 1 0 283 +4228 2118 0 2020-10-21 11:26:26.748607 2020-10-21 11:29:16.398134 9 0 0 +4227 2117 0 2020-10-19 13:33:28.161327 3 0 +4226 2116 0 2020-10-11 16:41:52.813684 2020-10-11 16:55:48.679589 1 0 65050 +4225 2115 0 2020-10-11 16:24:25.920891 2020-10-11 16:38:16.379855 1 0 64431 +4224 2114 0 2020-10-11 16:00:10.332276 2020-10-11 16:14:27.474898 1 0 65656 +4223 2113 0 2020-10-11 15:43:07.164836 2020-10-11 15:57:05.452246 1 0 65294 +4222 2112 0 2020-10-10 22:36:24.736616 2020-10-11 15:39:25.57292 3 0 412462 +4221 2111 0 2020-10-10 22:15:13.354215 2020-10-10 22:29:02.919771 1 0 64850 +4220 2110 0 2020-10-10 21:58:30.631835 2020-10-10 22:12:07.528476 1 0 63475 +4219 2109 0 2020-10-10 21:37:01.741569 2020-10-10 21:50:45.909669 1 0 63558 +4218 2108 0 2020-10-10 21:19:36.070799 2020-10-10 21:33:38.163398 1 0 65431 +4217 2107 0 2020-10-10 17:11:08.125657 2020-10-10 21:16:07.064237 3 0 97337 +4216 2106 0 2020-10-09 21:18:01.83584 2020-10-10 17:00:04.449138 3 0 427043 +4215 2105 0 2020-10-09 20:53:07.081252 2020-10-09 21:09:07.425384 1 0 74670 +4214 2104 0 2020-10-09 20:35:22.592364 2020-10-09 20:49:28.7539 1 0 65962 +4213 2103 0 2020-10-09 20:16:08.079257 2020-10-09 20:29:38.989646 1 0 63514 +4212 2102 0 2020-10-09 19:59:26.618974 2020-10-09 20:13:00.892003 1 0 64120 +4211 2101 0 2020-10-08 21:09:54.913525 2020-10-09 19:52:43.31379 3 0 557743 +4210 2100 0 2020-10-08 20:48:36.311943 2020-10-08 21:02:04.545332 1 0 63526 +4209 2099 0 2020-10-08 20:31:29.133126 2020-10-08 20:45:07.917802 1 0 64167 +4208 2098 0 2020-10-08 20:09:43.364367 2020-10-08 20:23:44.738225 1 0 65937 +4207 2097 0 2020-10-08 19:51:56.05394 2020-10-08 20:06:07.137348 1 0 66802 +4206 2096 0 2020-10-08 09:33:19.074164 2020-10-08 19:48:12.090306 3 0 246778 +4205 2095 0 2020-10-08 08:50:38.975661 2020-10-08 08:53:13.979436 3 0 852 +4204 2094 0 2020-10-08 08:24:02.399248 2020-10-08 08:26:44.663948 3 0 932 +4203 2093 0 2020-10-06 17:58:41.229592 2020-10-08 07:42:32.149931 3 0 909230 +4202 2092 0 2020-10-06 17:38:29.218725 2020-10-06 17:52:01.771908 1 0 63881 +4201 2091 0 2020-10-06 17:21:46.258785 2020-10-06 17:35:22.746 1 0 63853 +4200 2090 0 2020-10-06 17:00:04.909294 2020-10-06 17:13:52.060715 1 0 64163 +4199 2089 0 2020-10-06 16:43:22.055491 2020-10-06 16:56:48.997709 1 0 63428 +4198 2088 0 2020-10-05 21:32:24.760618 2020-10-06 16:38:37.099501 3 0 458493 +4197 2087 0 2020-10-03 17:34:28.832327 2020-10-05 20:56:56.339303 3 0 1247232 +4196 2086 0 2020-10-03 17:12:53.113037 2020-10-03 17:26:43.612714 1 0 65278 +4195 2085 0 2020-10-03 16:55:52.921112 2020-10-03 17:09:32.814249 1 0 64362 +4194 2084 0 2020-10-03 16:33:42.872052 2020-10-03 16:48:11.486717 1 0 67884 +4193 2083 0 2020-10-03 16:13:53.47659 2020-10-03 16:30:24.435891 1 0 75000 +4192 2082 0 2020-10-01 22:43:04.524383 2020-10-03 16:08:44.27112 3 0 1003264 +4191 2081 0 2020-10-01 22:20:45.942539 2020-10-01 22:34:45.656825 1 0 65755 +4190 2080 0 2020-10-01 22:01:58.589089 2020-10-01 22:16:20.018779 1 0 65415 +4189 2079 0 2020-10-01 21:39:59.506858 2020-10-01 21:53:38.459007 1 0 64327 +4188 2078 0 2020-10-01 21:22:42.366433 2020-10-01 21:36:18.691711 1 0 63945 +4187 2077 0 2020-09-29 21:38:50.104639 2020-10-01 21:17:46.884234 3 0 1151886 +4186 2076 0 2020-09-29 21:16:20.183405 2020-09-29 21:30:09.860916 1 0 64602 +4185 2075 0 2020-09-29 20:57:35.829138 2020-09-29 21:11:48.166738 1 0 66861 +4184 2074 0 2020-09-29 20:33:04.553275 2020-09-29 20:46:37.508486 1 0 63670 +4183 2073 0 2020-09-29 20:15:46.036569 2020-09-29 20:29:13.400961 1 0 63340 +4182 2072 0 2020-09-27 22:42:02.713126 2020-09-29 20:09:31.464675 3 0 1093837 +4181 2071 0 2020-09-27 22:21:23.740821 2020-09-27 22:34:51.427276 1 0 63140 +4180 2070 0 2020-09-27 22:04:05.965895 2020-09-27 22:18:12.407503 1 0 66835 +4179 2069 0 2020-09-27 21:43:41.697345 2020-09-27 21:57:20.659279 1 0 63504 +4178 2068 0 2020-09-27 21:26:58.774949 2020-09-27 21:40:36.611388 1 0 64049 +4177 2067 0 2020-09-25 19:42:27.532969 2020-09-27 21:20:48.88042 3 0 1212120 +4176 2066 0 2020-09-25 19:21:22.750489 2020-09-25 19:36:08.457291 1 0 66608 +4175 2065 0 2020-09-25 19:02:22.215936 2020-09-25 19:17:16.875812 1 0 69872 +4174 2064 0 2020-09-25 18:40:06.359754 2020-09-25 18:53:44.908658 1 0 64047 +4173 2063 0 2020-09-25 18:21:46.730621 2020-09-25 18:35:50.777059 1 0 64889 +4172 2062 0 2020-09-25 11:56:38.603697 2020-09-25 18:18:15.610861 3 0 152378 +4171 2061 0 2020-09-25 02:29:45.956181 2020-09-25 03:41:28.049529 3 0 28481 +4170 2060 0 2020-09-23 20:58:39.983572 2020-09-25 02:26:05.53997 3 0 706345 +4169 2059 0 2020-09-23 20:38:24.758743 2020-09-23 20:52:26.833681 1 0 65790 +4168 2058 0 2020-09-23 20:22:01.884325 2020-09-23 20:35:23.304329 1 0 63155 +4167 2057 0 2020-09-23 20:01:33.610868 2020-09-23 20:14:59.010033 1 0 63467 +4166 2056 0 2020-09-23 19:43:34.750336 2020-09-23 19:58:02.090189 1 0 67820 +4165 2055 0 2020-09-23 12:56:08.461165 2020-09-23 19:39:10.342275 3 0 85756 +4164 2054 0 2020-09-22 14:39:36.229725 2020-09-23 12:40:15.865613 3 0 390515 +4163 2053 0 2020-09-21 17:55:04.130531 2020-09-22 14:36:35.32513 3 0 442006 +4162 2052 0 2020-09-21 12:23:46.752443 2020-09-21 17:49:13.997486 3 0 131721 +4161 2051 0 2020-09-21 12:04:43.331813 2020-09-21 12:18:17.666733 1 0 63597 +4160 2050 0 2020-09-21 11:48:14.801881 2020-09-21 12:02:07.582076 1 0 64601 +4159 2049 0 2020-09-21 11:27:54.070579 2020-09-21 11:41:31.76607 1 0 64029 +4158 2048 0 2020-09-21 11:10:03.17751 2020-09-21 11:24:08.61646 1 0 65752 +4157 2047 0 2020-09-19 13:52:22.070724 2020-09-21 11:06:36.669307 3 0 814662 +4156 2046 0 2020-09-19 13:30:29.661786 2020-09-19 13:44:34.309906 1 0 65763 +4155 2045 0 2020-09-19 13:12:33.804797 2020-09-19 13:26:10.431921 1 0 63302 +4154 2044 0 2020-09-19 12:51:24.787577 2020-09-19 13:05:05.595281 1 0 63901 +4153 2043 0 2020-09-19 12:34:16.780953 2020-09-19 12:48:14.231221 1 0 65185 +4152 2042 0 2020-09-18 17:09:54.076036 2020-09-19 12:30:16.959189 3 0 394482 +4151 2041 0 2020-09-18 03:05:47.147425 2020-09-18 17:04:25.795212 3 0 334527 +4150 2040 0 2020-09-16 12:47:31.582324 2020-09-18 03:00:52.428384 3 0 1010770 +4149 2039 0 2020-09-16 12:27:42.073159 2020-09-16 12:41:27.343275 1 0 64469 +4148 2038 0 2020-09-16 12:10:52.934579 2020-09-16 12:24:36.819199 1 0 63015 +4147 2037 0 2020-09-16 11:47:56.981644 2020-09-16 12:03:27.877846 1 0 72564 +4146 2036 0 2020-09-16 11:31:25.435924 2020-09-16 11:44:58.02501 1 0 63636 +4145 2035 0 2020-09-15 12:48:52.072283 2020-09-16 11:27:22.8203 3 0 315196 +4144 2034 0 2020-09-14 12:34:45.858959 2020-09-15 10:06:09.055463 3 0 278162 +4143 2033 0 2020-09-14 12:11:24.794735 2020-09-14 12:25:25.139126 1 0 64206 +4142 2032 0 2020-09-14 11:54:58.517535 2020-09-14 12:08:24.955012 1 0 63252 +4141 2031 0 2020-09-14 11:33:05.07062 2020-09-14 11:47:51.419131 1 0 69301 +4140 2030 0 2020-09-14 11:13:20.241184 2020-09-14 11:27:37.481584 1 0 67176 +4139 2029 0 2020-09-12 17:08:14.209059 2020-09-14 08:25:33.921553 3 0 508943 +4138 2028 0 2020-09-12 16:48:44.046254 2020-09-12 17:02:16.778283 1 0 63754 +4137 2027 0 2020-09-12 16:30:59.438449 2020-09-12 16:45:19.154916 1 0 66855 +4136 2026 0 2020-09-12 16:09:29.376685 2020-09-12 16:23:20.090461 1 0 63552 +4135 2025 0 2020-09-12 15:50:35.727975 2020-09-12 16:04:24.248898 1 0 64010 +4134 2024 0 2020-09-11 10:16:21.001462 2020-09-12 15:43:32.934853 3 0 380174 +4133 2023 0 2020-09-07 19:43:14.890227 2020-09-09 15:04:04.32509 3 0 561751 +4132 2022 0 2020-09-07 19:22:35.434835 2020-09-07 19:36:15.413564 1 0 64531 +4131 2021 0 2020-09-07 19:05:01.028011 2020-09-07 19:18:49.784024 1 0 65683 +4130 2020 0 2020-09-07 18:42:18.600765 2020-09-07 18:55:55.444051 1 0 63537 +4129 2019 0 2020-09-07 18:23:08.245413 2020-09-07 18:37:19.35849 1 0 65338 +4128 2018 0 2020-09-05 19:00:03.93844 2020-09-07 18:16:07.823434 3 0 613603 +4127 2017 0 2020-09-05 18:39:41.174442 2020-09-05 18:53:26.686977 1 0 64689 +4126 2016 0 2020-09-05 18:22:44.716862 2020-09-05 18:36:26.687662 1 0 64107 +4125 2015 0 2020-09-05 18:00:26.970207 2020-09-05 18:14:15.892732 1 0 64541 +4124 2014 0 2020-09-05 17:42:44.790709 2020-09-05 17:56:26.347423 1 0 64684 +4123 2013 0 2020-09-04 15:51:18.144845 2020-09-05 17:39:03.613119 3 0 332753 +4122 2012 0 2020-09-03 19:52:00.20548 2020-09-04 15:48:04.834154 3 0 258177 +4121 2011 0 2020-09-03 19:31:21.967919 2020-09-03 19:44:56.946676 1 0 63683 +4120 2010 0 2020-09-03 19:14:51.014051 2020-09-03 19:28:28.552459 1 0 63959 +4119 2009 0 2020-09-03 18:53:07.959244 2020-09-03 19:07:08.37973 1 0 65840 +4118 2008 0 2020-09-03 18:35:52.430673 2020-09-03 18:49:36.992094 1 0 64505 +4117 2007 0 2020-09-03 16:10:15.131275 2020-09-03 18:32:03.505006 3 0 30513 +4116 2006 0 2020-09-01 16:35:40.399253 2020-09-03 14:29:45.886639 3 0 625502 +4115 2005 0 2020-09-01 16:12:08.489174 2020-09-01 16:25:44.085404 1 0 63813 +4114 2004 0 2020-09-01 15:52:54.769637 2020-09-01 16:08:01.762895 1 0 69073 +4113 2003 0 2020-09-01 15:29:40.000604 2020-09-01 15:43:50.486692 1 0 65781 +4112 2002 0 2020-09-01 15:11:54.87824 2020-09-01 15:26:05.887439 1 0 65525 +4111 2001 0 2020-08-30 15:42:36.94226 2020-09-01 15:08:14.923645 3 0 616067 +4110 2000 0 2020-08-30 15:21:01.332965 2020-08-30 15:35:22.171906 1 0 67575 +4109 1999 0 2020-08-30 15:03:08.939442 2020-08-30 15:16:40.255111 1 0 63590 +4108 1998 0 2020-08-30 14:39:34.032646 2020-08-30 14:54:15.0103 1 0 68517 +4107 1997 0 2020-08-30 14:22:06.247342 2020-08-30 14:36:12.175008 1 0 66123 +4106 1996 0 2020-08-28 20:38:18.639628 2020-08-30 14:16:50.642377 3 0 539922 +4105 1995 0 2020-08-28 20:16:24.961841 2020-08-28 20:31:08.95884 1 0 68903 +4104 1994 0 2020-08-28 19:58:12.136822 2020-08-28 20:12:45.487781 1 0 68720 +4103 1993 0 2020-08-28 19:36:21.855703 2020-08-28 19:50:32.53926 1 0 66232 +4102 1992 0 2020-08-28 19:17:36.506487 2020-08-28 19:33:02.666675 1 0 72358 +4101 1991 0 2020-08-26 19:21:01.103986 2020-08-28 19:13:20.095335 3 0 619707 +4100 1990 0 2020-08-26 19:00:54.640251 2020-08-26 19:14:27.845706 1 0 64031 +4099 1989 0 2020-08-26 18:43:55.903718 2020-08-26 18:57:46.149775 1 0 65222 +4098 1988 0 2020-08-26 18:22:11.982363 2020-08-26 18:36:01.003865 1 0 64598 +4097 1987 0 2020-08-26 18:03:02.123775 2020-08-26 18:17:27.655415 1 0 67687 +4096 1986 0 2020-08-26 16:39:29.409283 2020-08-26 17:47:07.654035 3 0 13608 +4095 1985 0 2020-08-24 12:44:41.973102 2020-08-25 15:09:08.449503 3 0 340953 +4094 1984 0 2020-08-24 12:26:12.310833 2020-08-24 12:39:44.771225 1 0 63047 +4093 1983 0 2020-08-24 12:09:03.190309 2020-08-24 12:23:07.727812 1 0 63497 +4092 1982 0 2020-08-24 11:31:46.933028 2020-08-24 11:46:35.062503 1 0 69400 +4091 1981 0 2020-08-24 11:04:53.431355 2020-08-24 11:18:49.764079 1 0 65781 +4090 1980 0 2020-08-22 22:12:09.210134 2020-08-24 10:58:51.379661 3 0 474550 +4089 1979 0 2020-08-22 15:13:08.937595 2020-08-22 15:27:02.477647 1 0 65247 +4088 1978 0 2020-08-22 14:55:30.752575 2020-08-22 15:09:32.79994 1 0 65885 +4087 1977 0 2020-08-22 14:31:27.899385 2020-08-22 14:45:37.055485 1 0 65134 +4086 1976 0 2020-08-22 14:13:37.078744 2020-08-22 14:27:36.584901 1 0 65713 +4085 1975 0 2020-08-20 19:21:23.576741 2020-08-22 14:07:57.734966 3 0 554292 +4084 1974 0 2020-08-20 18:59:16.356951 2020-08-20 19:13:43.151109 1 0 68306 +4083 1973 0 2020-08-20 18:42:26.62787 2020-08-20 18:56:01.882726 1 0 63659 +4082 1972 0 2020-08-20 18:25:12.785659 2020-08-20 18:39:30.377744 1 0 66921 +4081 1971 0 2020-08-20 18:07:54.202686 2020-08-20 18:21:50.390248 1 0 64417 +4080 1970 0 2020-08-20 17:50:24.414706 2020-08-20 18:04:06.794665 1 0 64369 +4079 1969 0 2020-08-20 17:27:48.637372 2020-08-20 17:42:34.214319 1 0 68675 +4078 1968 0 2020-08-20 17:06:19.635926 2020-08-20 17:20:33.851652 1 0 66464 +4077 1967 0 2020-08-20 16:48:16.32694 2020-08-20 17:02:18.426473 1 0 65876 +4076 1966 0 2020-08-20 16:30:35.768563 2020-08-20 16:44:09.786168 1 0 63998 +4075 1965 0 2020-08-20 16:12:56.590906 2020-08-20 16:26:30.572836 1 0 63926 +4074 1964 0 2020-08-20 15:55:34.51189 2020-08-20 16:09:22.734277 1 0 64319 +4073 1963 0 2020-08-20 15:36:45.83786 2020-08-20 15:50:39.071914 1 0 64714 +4072 1962 0 2020-08-20 15:19:23.714105 2020-08-20 15:33:08.582068 1 0 63822 +4071 1961 0 2020-08-20 15:01:45.892416 2020-08-20 15:15:28.360141 1 0 64180 +4070 1960 0 2020-08-19 12:44:54.814353 2020-08-20 14:53:53.139772 3 0 428393 +4069 1959 0 2020-08-19 12:32:27.245854 2020-08-19 12:42:06.300569 3 0 8027 +4068 1958 0 2020-08-19 12:27:39.050318 3 0 +4067 1957 0 2020-08-19 12:11:32.725876 2020-08-19 12:15:40.346599 3 0 3253 +4066 1956 0 2020-08-19 11:58:01.612603 2020-08-19 12:05:00.84159 3 0 5788 +4065 1955 0 2020-08-19 11:33:28.169566 2020-08-19 11:39:24.236482 3 0 4945 +4064 1954 0 2020-08-19 11:12:45.721459 2020-08-19 11:19:04.571972 3 0 5261 +4063 1953 0 2020-08-19 10:43:37.252975 2020-08-19 10:52:34.108447 3 0 7460 +4062 1952 0 2020-08-19 10:24:46.726095 2020-08-19 10:34:27.594841 3 0 8320 +4061 1951 0 2020-08-19 09:55:31.92141 2020-08-19 10:12:59.443608 3 0 15224 +4060 1950 0 2020-08-19 09:49:00.390065 2020-08-19 09:49:33.014419 3 0 330 +4059 1949 0 2020-08-18 19:48:41.876478 2020-08-18 20:02:29.116087 1 0 65401 +4058 1948 0 2020-08-18 19:31:33.882416 2020-08-18 19:45:08.338644 1 0 64074 +4057 1947 0 2020-08-18 19:07:23.48412 2020-08-18 19:21:57.545196 1 0 69328 +4056 1946 0 2020-08-18 18:46:50.13872 2020-08-18 19:00:48.911196 1 0 64405 +4055 1945 0 2020-08-18 18:29:01.10579 2020-08-18 18:43:02.588776 1 0 64913 +4054 1944 0 2020-08-18 18:09:26.679761 2020-08-18 18:24:36.0553 1 0 70870 +4053 1943 0 2020-08-18 17:51:56.487359 2020-08-18 18:06:09.564899 1 0 66069 +4052 1942 0 2020-08-18 17:33:34.948543 2020-08-18 17:48:15.056932 1 0 68122 +4051 1941 0 2020-08-17 15:56:41.355074 2020-08-17 16:03:42.991151 3 0 5929 +4050 1940 0 2020-08-17 15:36:51.988979 2020-08-17 15:42:23.634072 3 0 4661 +4049 1939 0 2020-08-17 15:26:34.311201 2020-08-17 15:30:51.421942 3 0 3469 +4048 1938 0 2020-08-17 14:49:27.714692 2020-08-17 14:53:39.405341 3 0 3442 +4047 1937 0 2020-08-16 12:53:55.118378 2020-08-16 13:07:53.912198 1 0 64716 +4046 1936 0 2020-08-16 12:34:30.24697 2020-08-16 12:48:59.313659 1 0 66940 +4045 1935 0 2020-08-16 12:10:34.431486 2020-08-16 12:25:06.316327 1 0 67931 +4044 1934 0 2020-08-16 11:52:24.030307 2020-08-16 12:06:48.669546 1 0 67018 +4043 1933 0 2020-08-14 12:49:19.666028 2020-08-14 13:03:26.196035 1 0 65808 +4042 1932 0 2020-08-14 12:30:02.431861 2020-08-14 12:44:51.507299 1 0 65028 +4041 1931 0 2020-08-14 12:06:03.703608 2020-08-14 12:20:02.324707 1 0 65186 +4040 1930 0 2020-08-14 11:47:13.828508 2020-08-14 12:01:27.791073 1 0 66270 +4039 1929 0 2020-08-12 15:15:12.835307 2020-08-12 15:28:40.948457 1 0 63478 +4038 1928 0 2020-08-12 14:57:13.961749 2020-08-12 15:11:02.115635 1 0 65855 +4037 1927 0 2020-08-12 14:35:51.611623 2020-08-12 14:49:26.022736 1 0 64294 +4036 1926 0 2020-08-12 14:18:03.373572 2020-08-12 14:31:53.047695 1 0 65307 +4035 1925 0 2020-08-12 12:36:12.547863 2020-08-12 12:49:30.724289 3 0 11406 +4034 1924 0 2020-08-12 12:24:44.387752 2020-08-12 12:33:24.032315 3 0 7470 +4033 1923 0 2020-08-12 11:53:17.64457 2020-08-12 11:58:58.91352 3 0 4772 +4032 1922 0 2020-08-12 11:38:20.352556 2020-08-12 11:46:02.013003 3 0 6416 +4031 1921 0 2020-08-12 11:11:33.452431 2020-08-12 11:28:29.411168 3 0 14655 +4030 1920 0 2020-08-12 11:00:18.590385 2020-08-12 11:02:49.100227 1 0 11049 +4029 1919 0 2020-08-12 10:43:12.744717 2020-08-12 10:56:49.81442 1 0 63423 +4028 1918 0 2020-08-12 09:39:31.90076 2020-08-12 09:54:38.470974 3 0 13244 +4027 1917 0 2020-08-10 08:40:29.313065 2020-08-10 08:53:53.665727 1 0 63593 +4026 1916 0 2020-08-10 08:21:46.059741 2020-08-10 08:35:12.542174 1 0 64219 +4025 1915 0 2020-08-10 08:00:31.609567 2020-08-10 08:14:04.415734 1 0 64154 +4024 1914 0 2020-08-10 07:41:52.521822 2020-08-10 07:56:27.690982 1 0 68869 +4023 1913 0 2020-08-08 11:41:37.452869 2020-08-08 11:55:49.397221 1 0 67260 +4022 1912 0 2020-08-08 11:22:57.57937 2020-08-08 11:37:22.48118 1 0 67904 +4021 1911 0 2020-08-08 10:57:43.611928 2020-08-08 11:11:48.664286 1 0 66404 +4020 1910 0 2020-08-08 10:39:31.758562 2020-08-08 10:53:34.073536 1 0 65319 +4019 1909 0 2020-08-07 18:30:14.64217 3 0 +4018 1908 0 2020-08-07 18:22:18.326542 3 0 +4017 1907 0 2020-08-07 18:04:17.571011 2020-08-07 18:15:25.738785 3 0 9600 +4016 1906 0 2020-08-07 17:54:04.580942 2020-08-07 18:00:45.587926 3 0 3186 +4015 1905 0 2020-08-07 17:49:10.741863 3 0 +4014 1904 0 2020-08-07 17:40:54.968725 3 0 +4013 1903 0 2020-08-07 17:35:25.879826 3 0 +4012 1902 0 2020-08-07 17:28:36.506776 3 0 +4011 1901 0 2020-08-07 09:12:07.016665 2020-08-07 09:18:37.103232 3 0 5459 +4010 1900 0 2020-08-07 08:34:20.596278 2020-08-07 08:35:25.648809 3 0 566 +4009 1899 0 2020-08-07 08:31:24.450361 2020-08-07 08:31:50.289211 3 0 216 +4008 1898 0 2020-08-06 18:31:01.534726 2020-08-06 18:45:58.595143 1 0 70851 +4007 1897 0 2020-08-06 18:12:30.502417 2020-08-06 18:26:17.531697 1 0 65458 +4006 1896 0 2020-08-06 17:49:55.746154 2020-08-06 18:03:15.371935 1 0 63219 +4005 1895 0 2020-08-06 17:31:04.534259 2020-08-06 17:44:45.187034 1 0 64266 +4004 1894 0 2020-08-06 16:02:13.807557 2020-08-06 16:08:44.962874 3 0 5407 +4003 1893 0 2020-08-06 15:58:19.83461 3 0 +4002 1892 0 2020-08-06 15:50:32.157382 3 0 +4001 1891 0 2020-08-04 17:13:32.420033 2020-08-04 17:30:00.209756 3 0 631 +4000 1890 0 2020-08-04 16:45:02.61727 2020-08-04 17:03:20.307982 3 0 670 +3999 1889 0 2020-08-04 16:37:22.296797 2020-08-04 16:41:45.921477 3 0 156 +3998 1888 0 2020-08-04 16:25:11.538894 3 0 +3997 1887 0 2020-08-04 12:01:25.977138 2020-08-04 12:25:29.633156 3 0 1070 +3996 1886 0 2020-08-04 10:11:10.966805 2020-08-04 10:25:16.128381 1 0 65151 +3995 1885 0 2020-08-04 09:52:43.833899 2020-08-04 10:07:04.410094 1 0 66895 +3994 1884 0 2020-08-04 09:28:23.010976 2020-08-04 09:42:54.820442 1 0 66933 +3993 1883 0 2020-08-04 09:09:11.927609 2020-08-04 09:23:47.518093 1 0 67522 +3992 1882 0 2020-08-03 13:53:46.490541 2020-08-03 16:11:04.797012 3 0 5673 +3991 1881 0 2020-08-03 12:31:58.286184 2020-08-03 12:45:20.833576 3 0 554 +3990 1880 0 2020-08-03 12:19:01.914557 2020-08-03 12:28:29.620155 3 0 377 +3989 1879 0 2020-08-03 11:52:50.506547 2020-08-03 12:15:55.468842 3 0 1020 +3988 1878 0 2020-08-03 11:44:26.95661 2020-08-03 11:45:12.072397 3 0 10 +3987 1877 0 2020-08-03 11:02:24.130802 2020-08-03 11:40:35.31795 3 0 1673 +3986 1876 0 2020-08-02 16:13:56.263681 2020-08-02 16:29:10.091603 1 0 70645 +3985 1875 0 2020-08-02 15:55:46.243194 2020-08-02 16:09:42.243805 1 0 64512 +3984 1874 0 2020-08-02 15:33:55.077368 2020-08-02 15:47:43.007485 1 0 63734 +3983 1873 0 2020-08-02 15:15:36.378763 2020-08-02 15:29:39.325803 1 0 64684 +3982 1872 0 2020-07-31 17:51:16.412119 2020-07-31 18:05:19.993393 1 0 64174 +3981 1871 0 2020-07-31 17:33:02.780361 2020-07-31 17:47:08.296826 1 0 65019 +3980 1870 0 2020-07-31 17:05:29.42018 2020-07-31 17:19:56.774551 1 0 66277 +3979 1869 0 2020-07-31 16:46:44.491222 2020-07-31 17:01:04.872572 1 0 66073 +3978 1868 0 2020-07-31 12:37:28.640369 2020-07-31 12:47:01.971321 3 0 392 +3977 1867 0 2020-07-31 12:13:25.694035 2020-07-31 12:34:00.156425 3 0 890 +3976 1866 0 2020-07-31 11:53:14.558265 2020-07-31 12:05:07.421229 3 0 516 +3975 1865 0 2020-07-31 11:29:12.335921 2020-07-31 11:45:36.141692 3 0 739 +3974 1864 0 2020-07-30 11:23:44.134561 2020-07-31 11:23:48.031852 3 0 56597 +3973 1863 0 2020-07-30 11:10:41.620312 3 0 +3972 1862 0 2020-07-29 13:03:10.479019 2020-07-30 11:04:30.461607 3 0 51736 +3971 1861 0 2020-07-29 10:57:36.485766 2020-07-29 11:12:39.061073 1 0 70917 +3970 1860 0 2020-07-29 10:38:39.254167 2020-07-29 10:52:46.606818 1 0 66567 +3969 1859 0 2020-07-29 09:39:06.284067 2020-07-29 09:55:42.743801 1 0 75000 +3968 1858 0 2020-07-29 09:20:34.496879 2020-07-29 09:34:20.142957 1 0 64962 +3967 1857 0 2020-07-27 10:07:54.694848 2020-07-27 10:22:00.579351 1 0 66455 +3966 1856 0 2020-07-27 09:47:33.992962 2020-07-27 10:01:28.875723 1 0 65855 +3965 1855 0 2020-07-27 09:24:38.911671 2020-07-27 09:38:28.52808 1 0 65084 +3964 1854 0 2020-07-27 09:06:25.127319 2020-07-27 09:20:12.222196 1 0 65282 +3963 1853 0 2020-07-25 12:47:58.362426 2020-07-25 13:02:07.947774 1 0 66319 +3962 1852 0 2020-07-25 12:27:50.028459 2020-07-25 12:43:01.396535 1 0 71918 +3961 1851 0 2020-07-25 12:04:48.825849 2020-07-25 12:18:28.985959 1 0 64344 +3960 1850 0 2020-07-25 11:44:59.504618 2020-07-25 11:58:32.707517 1 0 63524 +3959 1849 0 2020-07-23 13:42:00.41754 2020-07-23 13:55:50.018 1 0 65041 +3958 1848 0 2020-07-23 13:22:34.959139 2020-07-23 13:36:34.104352 1 0 66295 +3957 1847 0 2020-07-23 13:00:34.658427 2020-07-23 13:14:25.535638 1 0 64870 +3956 1846 0 2020-07-23 12:42:06.279387 2020-07-23 12:55:43.346851 1 0 64142 +3955 1845 0 2020-07-21 10:05:39.789089 2020-07-21 10:19:58.028929 1 0 66927 +3954 1844 0 2020-07-21 09:48:31.227596 2020-07-21 10:02:12.466148 1 0 64312 +3953 1843 0 2020-07-21 09:25:58.858681 2020-07-21 09:40:08.651896 1 0 66711 +3952 1842 0 2020-07-21 09:06:52.588303 2020-07-21 09:21:10.59941 1 0 67076 +3951 1841 0 2020-07-20 10:09:13.27233 2020-07-20 10:23:02.646819 1 0 64821 +3950 1840 0 2020-07-20 09:51:32.704443 2020-07-20 10:05:28.243595 1 0 65807 +3949 1839 0 2020-07-20 09:26:55.36594 2020-07-20 09:41:30.805422 1 0 67822 +3948 1838 0 2020-07-20 09:08:50.903265 2020-07-20 09:23:08.61303 1 0 67467 +3947 1837 0 2020-07-19 13:08:24.535648 2020-07-19 13:22:46.047393 1 0 67549 +3946 1836 0 2020-07-19 12:49:18.623174 2020-07-19 13:03:45.745592 1 0 67934 +3945 1835 0 2020-07-19 12:23:38.24507 2020-07-19 12:37:53.210276 1 0 67267 +3944 1834 0 2020-07-19 12:03:47.469296 2020-07-19 12:18:06.554266 1 0 67817 +3943 1833 0 2020-07-18 16:16:53.212364 2020-07-18 16:31:12.894058 1 0 66926 +3942 1832 0 2020-07-18 15:57:15.388331 2020-07-18 16:12:39.571441 1 0 71823 +3941 1831 0 2020-07-18 15:53:31.918992 2020-07-18 15:54:05.013702 1 0 1614 +3940 1830 0 2020-07-18 15:30:44.744407 2020-07-18 15:45:51.151144 1 0 71296 +3939 1829 0 2020-07-18 15:11:36.772516 2020-07-18 15:26:09.286114 1 0 68282 +3938 1828 0 2020-07-17 08:45:20.051206 2020-07-17 08:59:50.487175 1 0 68394 +3937 1827 0 2020-07-17 08:26:46.848702 2020-07-17 08:41:07.246955 1 0 67788 +3936 1826 0 2020-07-17 08:03:59.113013 2020-07-17 08:18:37.415241 1 0 68763 +3935 1825 0 2020-07-17 07:45:18.872082 2020-07-17 08:00:13.424608 1 0 70463 +3934 1824 0 2020-07-16 10:52:19.445981 2020-07-16 11:07:35.596152 1 0 72420 +3933 1823 0 2020-07-16 10:32:46.942488 2020-07-16 10:47:25.082283 1 0 69206 +3932 1822 0 2020-07-16 10:25:43.547872 2020-07-16 10:27:21.280696 1 0 6920 +3931 1821 0 2020-07-16 10:00:59.340751 2020-07-16 10:15:58.108182 1 0 70775 +3930 1820 0 2020-07-16 09:42:01.502775 2020-07-16 09:56:47.573863 1 0 69880 +3929 1819 0 2020-07-15 12:30:59.169359 2020-07-15 12:45:16.726256 1 0 67654 +3928 1818 0 2020-07-15 12:12:57.775869 2020-07-15 12:27:49.035265 1 0 70453 +3927 1817 0 2020-07-15 11:48:11.586382 2020-07-15 12:02:50.5449 1 0 69165 +3926 1816 0 2020-07-15 11:29:11.217986 2020-07-15 11:44:09.059704 1 0 70642 +3925 1815 0 2020-07-15 11:16:43.481999 1 0 +3924 1814 0 2020-06-22 13:01:52.537991 1 0 +3923 1813 0 2020-06-22 12:43:58.601144 2020-06-22 12:55:18.933699 1 0 52 +3922 1812 0 2020-06-22 12:37:19.944419 1 0 +3921 1811 0 2020-06-22 12:33:59.361091 2020-06-22 12:34:45.255612 1 0 4 +3920 1810 0 2020-06-22 12:25:40.328566 2020-06-22 12:27:21.359014 1 0 8 +3919 1809 0 2020-06-21 20:11:39.19139 2020-06-22 12:07:47.465897 1 0 4412 +3918 1808 0 2020-06-21 19:35:28.377728 2020-06-21 19:36:14.810219 1 0 2 +3917 1807 0 2020-06-21 16:56:31.488029 2020-06-21 17:00:23.119277 1 0 16 +3916 1806 0 2020-06-21 16:51:40.932891 1 0 +3915 1805 0 2020-06-21 16:47:39.709177 1 0 +3914 1804 0 2020-06-21 16:26:27.910282 1 0 +3913 1803 0 2020-06-21 16:16:35.845911 1 0 +3912 1802 0 2020-06-17 13:22:44.063208 2020-06-17 13:36:15.532937 1 0 63932 +3911 1801 0 2020-06-17 13:03:00.746695 2020-06-17 13:16:45.714046 1 0 65194 +3910 1800 0 2020-06-17 11:27:11.330059 2020-06-17 11:40:51.21502 1 0 64700 +3909 1799 0 2020-06-17 11:06:39.940836 2020-06-17 11:21:35.064381 1 0 70916 +3908 1798 0 2020-06-17 10:39:37.240018 2020-06-17 10:54:31.963523 1 0 70981 +3907 1797 0 2020-06-17 10:20:34.617465 2020-06-17 10:35:30.17999 1 0 70721 +3906 1796 0 2020-06-15 10:17:01.379304 2020-06-15 10:31:55.622887 1 0 70669 +3905 1795 0 2020-06-15 09:52:54.820224 2020-06-15 10:12:27.848211 1 0 93708 +3904 1794 0 2020-06-15 09:25:14.955174 2020-06-15 09:41:46.882419 1 0 78354 +3903 1793 0 2020-06-15 09:05:42.693353 2020-06-15 09:20:34.582512 1 0 70813 +3902 1792 0 2020-06-13 10:33:01.411899 2020-06-13 10:47:59.831891 1 0 70869 +3901 1791 0 2020-06-13 10:13:28.377684 2020-06-13 10:28:35.847711 1 0 70990 +3900 1790 0 2020-06-13 09:48:16.346683 2020-06-13 10:03:15.624323 1 0 70578 +3899 1789 0 2020-06-13 09:28:44.724433 2020-06-13 09:43:40.06076 1 0 71208 +3898 1788 0 2020-06-11 17:21:44.928475 2020-06-11 17:36:36.600338 1 0 70384 +3897 1787 1 2020-06-11 17:17:17.195871 2020-06-11 17:19:09.075691 1 0 7881 +3896 1787 0 2020-06-11 17:00:11.445822 2020-06-11 17:15:13.282643 1 0 70645 +3895 1786 0 2020-06-11 16:30:05.519694 2020-06-11 16:45:05.217007 1 0 70941 +3894 1785 0 2020-06-11 16:12:12.628777 2020-06-11 16:27:19.091348 1 0 71061 +3893 1784 0 2020-06-11 15:47:36.553902 2020-06-11 16:02:36.619918 1 0 70669 +3892 1783 0 2020-06-11 15:28:10.013281 2020-06-11 15:43:02.476259 1 0 70807 +3891 1782 0 2020-06-09 11:43:26.457163 2020-06-09 11:58:22.97268 1 0 70339 +3890 1781 0 2020-06-09 11:23:48.403975 2020-06-09 11:38:46.632612 1 0 70893 +3889 1780 0 2020-06-09 10:59:20.186928 2020-06-09 11:14:14.698677 1 0 70742 +3888 1779 0 2020-06-09 10:39:48.185249 2020-06-09 10:54:48.384752 1 0 70801 +3887 1778 0 2020-06-07 16:10:12.939876 2020-06-07 16:25:06.517386 1 0 70556 +3886 1777 0 2020-06-07 15:50:23.222588 2020-06-07 16:05:29.758589 1 0 71132 +3885 1776 0 2020-06-07 15:26:04.086826 2020-06-07 15:41:13.548733 1 0 70612 +3884 1775 0 2020-06-07 15:06:27.668636 2020-06-07 15:21:46.835644 1 0 72760 +3883 1774 0 2020-06-05 14:25:16.57069 2020-06-05 14:40:29.249195 1 0 71022 +3882 1773 0 2020-06-05 14:06:21.60228 2020-06-05 14:21:18.429943 1 0 70723 +3881 1772 0 2020-06-05 13:43:06.998182 2020-06-05 13:58:04.474586 1 0 70792 +3880 1771 0 2020-06-05 13:24:16.242683 2020-06-05 13:39:16.374795 1 0 70795 +3879 1770 0 2020-06-05 11:06:40.858927 2020-06-05 11:25:56.219157 1 0 91484 +3878 1769 0 2020-06-03 20:19:54.699988 2020-06-03 20:35:12.353886 1 0 72768 +3877 1768 0 2020-06-03 19:57:41.255205 2020-06-03 20:12:38.300502 1 0 70767 +3876 1767 0 2020-06-03 19:30:00.456401 2020-06-03 19:45:26.08153 1 0 72552 +3875 1766 0 2020-06-03 19:06:50.874564 2020-06-03 19:22:13.131427 1 0 72591 +3874 1765 0 2020-06-03 14:27:56.897888 2020-06-03 17:39:34.602111 0 0 16419 +3873 1764 0 2020-06-03 11:47:05.084453 2020-06-03 13:42:00.064907 0 0 558773 +3872 1763 0 2020-06-01 09:36:21.023363 2020-06-01 09:51:15.318971 1 0 70704 +3871 1762 0 2020-06-01 09:16:58.5571 2020-06-01 09:31:46.010103 1 0 70785 +3870 1761 0 2020-06-01 08:52:53.697623 2020-06-01 09:07:45.689372 1 0 70676 +3869 1760 0 2020-06-01 08:33:41.069835 2020-06-01 08:48:36.982336 1 0 71255 +3868 1759 0 2020-05-30 14:13:43.793284 2020-05-30 14:28:48.701219 1 0 71018 +3867 1758 0 2020-05-30 13:53:29.71574 2020-05-30 14:08:32.857132 1 0 71384 +3866 1757 0 2020-05-30 13:28:52.946842 2020-05-30 13:43:55.685279 1 0 71340 +3865 1756 0 2020-05-30 13:09:31.527677 2020-05-30 13:24:23.446554 1 0 70773 +3864 1755 0 2020-05-28 15:22:44.441 2020-05-28 15:37:45.027912 1 0 71171 +3863 1754 0 2020-05-28 15:03:15.212849 2020-05-28 15:18:14.610201 1 0 71543 +3862 1753 0 2020-05-28 14:39:00.317515 2020-05-28 14:54:02.047495 1 0 71006 +3861 1752 0 2020-05-28 14:18:56.081624 2020-05-28 14:33:49.800049 1 0 70630 +3860 1751 0 2020-05-26 16:37:44.211119 2020-05-26 16:52:38.973226 1 0 70802 +3859 1750 0 2020-05-26 16:18:29.082144 2020-05-26 16:33:20.048111 1 0 70804 +3858 1749 0 2020-05-26 15:52:17.112911 2020-05-26 16:07:25.006698 1 0 72054 +3857 1748 0 2020-05-26 15:32:35.105752 2020-05-26 15:47:43.061073 1 0 72483 +3856 1747 0 2020-05-24 14:44:57.413186 2020-05-24 15:00:08.424149 1 0 71986 +3855 1746 0 2020-05-24 14:22:01.64648 2020-05-24 14:37:08.756362 1 0 71743 +3854 1745 0 2020-05-24 13:45:03.879407 2020-05-24 14:08:02.68887 1 0 109886 +3853 1744 0 2020-05-24 13:24:49.721981 2020-05-24 13:39:53.584007 1 0 71284 +3852 1743 0 2020-05-22 13:14:07.243385 2020-05-22 13:29:29.734254 1 0 73341 +3851 1742 0 2020-05-22 12:55:09.369466 2020-05-22 13:10:06.936773 1 0 71248 +3850 1741 0 2020-05-22 12:30:09.010061 2020-05-22 12:45:10.740999 1 0 71052 +3849 1740 0 2020-05-22 12:09:50.555047 2020-05-22 12:24:55.523631 1 0 71370 +3848 1739 0 2020-05-20 11:49:51.4169 2020-05-20 12:04:56.086543 1 0 70963 +3847 1738 0 2020-05-20 11:30:33.221853 2020-05-20 11:45:34.061913 1 0 71365 +3846 1737 0 2020-05-20 11:04:59.460284 2020-05-20 11:20:04.884755 1 0 71189 +3845 1736 0 2020-05-20 10:43:09.063361 2020-05-20 10:58:09.342789 1 0 71094 +3844 1735 0 2020-05-18 16:02:38.907879 2020-05-18 16:17:40.17061 1 0 71399 +3843 1734 0 2020-05-18 15:39:15.772504 2020-05-18 15:54:25.140191 1 0 71662 +3842 1733 0 2020-05-18 14:47:05.790874 2020-05-18 15:02:44.530312 1 0 73847 +3841 1732 0 2020-05-18 14:15:23.200895 2020-05-18 14:40:29.874766 1 0 119302 +3840 1731 0 2020-05-16 17:38:51.183273 2020-05-16 17:54:04.157951 1 0 72307 +3839 1730 0 2020-05-16 17:18:06.151201 2020-05-16 17:34:35.838324 1 0 78094 +3838 1729 0 2020-05-16 16:52:51.956804 2020-05-16 17:08:14.532772 1 0 71501 +3837 1728 0 2020-05-16 16:28:26.185045 2020-05-16 16:44:10.875637 1 0 74057 +3836 1727 0 2020-05-14 17:29:54.022633 2020-05-14 17:47:34.652718 1 0 83466 +3835 1726 0 2020-05-14 17:08:26.13351 2020-05-14 17:24:58.823689 1 0 77908 +3834 1725 0 2020-05-14 16:29:48.738054 2020-05-14 16:49:57.810519 1 0 94907 +3833 1724 0 2020-05-14 16:08:17.448799 2020-05-14 16:24:03.78608 1 0 72587 +3832 1723 0 2020-05-12 21:17:12.4191 2020-05-13 11:25:01.210391 4 0 96215 +3831 1722 0 2020-05-12 20:09:43.454443 2020-05-12 21:09:05.474938 1 0 282640 +3830 1721 0 2020-05-12 19:46:17.64917 2020-05-12 20:03:05.547843 1 0 79365 +3829 1720 0 2020-05-12 19:17:05.108558 2020-05-12 19:35:04.296057 1 0 85420 +3828 1719 0 2020-05-12 18:53:37.19681 2020-05-12 19:09:06.570438 1 0 73072 +3827 1718 0 2020-05-10 19:14:07.548924 2020-05-12 18:39:01.306912 4 0 268197 +3826 1717 0 2020-05-10 18:41:15.608765 2020-05-10 18:58:49.77483 1 0 82709 +3825 1716 0 2020-05-10 18:01:22.886026 2020-05-10 18:22:16.844468 1 0 99147 +3824 1715 0 2020-05-10 17:30:47.132902 2020-05-10 17:46:25.287135 1 0 73498 +3823 1714 0 2020-05-10 17:06:11.713684 2020-05-10 17:23:09.915288 1 0 80513 +3822 1713 0 2020-05-09 18:51:41.35947 2020-05-10 16:50:36.263119 4 0 111041 +3821 1712 0 2020-05-08 21:32:25.270295 4 0 +3820 1711 0 2020-05-08 21:04:18.451041 2020-05-08 21:20:51.218989 1 0 78430 +3819 1710 0 2020-05-08 20:33:36.744333 2020-05-08 20:56:33.31172 1 0 108612 +3818 1709 0 2020-05-08 20:10:21.613678 2020-05-08 20:25:35.524134 1 0 72390 +3817 1708 0 2020-05-08 19:49:33.941596 2020-05-08 20:04:42.028571 1 0 72022 +3816 1707 0 2020-05-08 19:44:36.472673 2020-05-08 19:46:01.170133 1 0 5679 +3815 1706 0 2020-05-08 06:46:57.444533 2020-05-08 18:39:21.755561 4 0 82678 +3814 1705 0 2020-05-08 06:40:50.803024 4 0 +3813 1704 0 2020-05-07 22:26:24.817302 2020-05-08 06:29:46.420276 4 0 59777 +3812 1703 0 2020-05-07 22:04:35.411225 2020-05-07 22:21:12.369975 1 0 78134 +3811 1702 0 2020-05-07 21:48:25.057856 2020-05-07 22:02:11.949172 1 0 65025 +3810 1701 0 2020-05-07 00:24:24.460208 2020-05-07 04:27:58.38721 4 0 29061 +3809 1700 0 2020-05-06 23:59:44.137562 2020-05-07 00:16:10.811256 1 0 79310 +3808 1699 0 2020-05-06 23:34:35.478914 2020-05-06 23:56:46.006945 1 0 108382 +3807 1698 0 2020-05-04 23:14:43.223661 2020-05-06 20:45:55.240926 4 0 211865 +3806 1697 0 2020-05-04 22:34:14.978527 2020-05-04 23:00:17.203224 1 0 123797 +3805 1696 0 2020-05-04 21:24:40.907456 2020-05-04 22:26:05.530737 1 0 294097 +3804 1695 0 2020-05-04 21:02:02.859183 2020-05-04 21:18:54.357295 1 0 79752 +3803 1694 0 2020-05-04 20:26:43.323005 2020-05-04 20:57:38.873749 1 0 145033 +3802 1693 0 2020-05-03 22:08:43.854003 2020-05-04 18:11:55.14171 4 0 125532 +3801 1692 0 2020-05-03 21:30:29.865204 2020-05-03 21:57:08.90533 1 0 129490 +3800 1691 0 2020-05-03 21:07:01.193323 2020-05-03 21:25:07.53083 1 0 87852 +3799 1690 0 2020-05-03 20:36:38.942929 2020-05-03 20:53:36.617337 1 0 81706 +3798 1689 0 2020-05-03 20:04:13.427566 2020-05-03 20:29:20.596743 1 0 122733 +3797 1688 0 2020-05-03 19:40:48.886991 2020-05-03 19:58:41.247356 1 0 87143 +3796 1687 0 2020-05-02 18:07:41.92395 2020-05-03 19:28:25.269124 4 0 121260 +3795 1686 0 2020-05-02 17:38:50.608436 2020-05-02 17:54:08.310112 1 0 74290 +3794 1685 0 2020-05-02 17:18:18.176397 2020-05-02 17:33:33.869274 1 0 74014 +3793 1684 0 2020-05-02 16:50:23.764964 2020-05-02 17:07:15.837126 1 0 82160 +3792 1683 0 2020-05-02 16:28:46.191917 2020-05-02 16:44:08.316144 1 0 74211 +3791 1682 0 2020-05-01 23:06:44.675656 2020-05-02 16:15:22.90841 4 0 86709 +3790 1681 0 2020-05-01 20:01:10.740611 2020-05-01 20:18:59.856223 1 0 86756 +3789 1680 0 2020-05-01 19:37:54.232528 2020-05-01 19:52:36.264366 1 0 71117 +3788 1679 0 2020-05-01 19:06:33.532392 2020-05-01 19:24:20.085182 1 0 86003 +3787 1678 0 2020-05-01 18:37:38.033193 2020-05-01 18:53:49.763773 1 0 79365 +3786 1677 0 2020-05-01 02:06:29.801362 2020-05-01 11:11:12.170535 4 0 64744 +3785 1676 0 2020-04-30 19:33:50.48947 2020-05-01 02:03:54.410557 4 0 33467 +3784 1675 0 2020-04-30 16:41:25.676232 2020-04-30 19:29:13.720087 4 0 14739 +3783 1674 0 2020-04-30 14:40:34.272824 2020-04-30 14:58:02.771351 1 0 88178 +3782 1673 0 2020-04-30 14:23:37.921469 2020-04-30 14:37:49.266131 1 0 71274 +3781 1672 0 2020-04-30 13:32:43.413444 2020-04-30 13:49:01.709336 1 0 83985 +3780 1671 0 2020-04-30 13:15:53.734821 2020-04-30 13:29:35.966688 1 0 71687 +3779 1670 0 2020-04-29 19:00:51.27706 2020-04-29 19:54:33.616358 4 0 6150 +3778 1669 0 2020-04-29 15:30:16.636543 2020-04-29 15:45:32.46769 1 0 79335 +3777 1668 0 2020-04-29 15:11:42.690316 2020-04-29 15:25:12.174733 1 0 70197 +3776 1667 0 2020-04-29 14:46:05.451949 2020-04-29 15:00:21.672762 1 0 73776 +3775 1666 0 2020-04-29 14:23:08.210025 2020-04-29 14:38:05.864745 1 0 77675 +3774 1665 0 2020-04-29 12:09:24.829665 2020-04-29 14:13:33.76668 4 0 11254 +3773 1664 0 2020-04-29 04:45:03.850034 2020-04-29 05:18:40.48527 1 0 170185 +3772 1663 0 2020-04-29 04:32:43.102352 2020-04-29 04:37:43.608767 1 0 24447 +3771 1662 0 2020-04-27 18:29:26.07283 2020-04-27 20:40:08.486889 4 0 17591 +3770 1661 0 2020-04-27 14:11:48.004268 2020-04-27 16:41:43.148809 4 0 21076 +3769 1660 0 2020-04-27 13:10:22.870388 2020-04-27 13:25:06.486993 1 0 74129 +3768 1659 0 2020-04-27 12:50:38.421271 2020-04-27 13:05:26.038085 1 0 74840 +3767 1658 0 2020-04-27 12:24:59.795172 2020-04-27 12:39:29.081908 1 0 72948 +3766 1657 0 2020-04-27 12:04:00.483046 2020-04-27 12:19:03.169194 1 0 75905 +3765 1656 0 2020-04-23 15:13:32.728592 2020-04-23 15:15:34.900825 1 0 10 +3764 1655 0 2020-04-23 15:04:14.69341 2020-04-23 15:06:36.285204 1 0 10 +3763 1654 0 2020-04-21 16:03:41.212148 1 0 +3762 1653 0 2020-04-21 15:42:48.917941 1 0 +3761 1652 0 2020-03-20 14:38:36.352437 2020-03-20 16:51:59.548026 4 0 17878 +3760 1651 0 2020-03-20 12:47:10.1393 2020-03-20 14:34:20.113909 4 0 14218 +3759 1650 0 2020-03-20 08:26:28.832298 2020-03-20 11:43:21.399273 4 0 27519 +3758 1649 0 2020-03-20 06:29:28.001736 2020-03-20 08:21:07.692894 4 0 14828 +3757 1648 0 2020-03-20 04:27:36.898951 2020-03-20 06:25:41.898497 4 0 15735 +3756 1647 0 2020-03-20 02:31:03.396281 2020-03-20 04:24:56.747334 4 0 15296 +3755 1646 0 2020-03-20 00:21:46.710013 2020-03-20 02:26:36.168568 4 0 16765 +3754 1645 0 2020-03-19 21:58:30.69521 2020-03-20 00:16:32.166759 4 0 18579 +3753 1644 1 2020-03-19 20:59:11.820958 4 0 +3752 1644 0 2020-03-19 18:19:51.860772 2020-03-19 20:22:45.045964 4 0 16444 +3751 1643 0 2020-03-19 15:25:50.485082 2020-03-19 18:09:32.664241 4 0 22209 +3750 1642 1 2020-03-19 14:44:39.204874 4 0 +3749 1642 0 2020-03-19 12:38:18.944724 2020-03-19 14:42:22.404672 4 0 16647 +3748 1641 0 2020-03-19 09:35:44.101468 2020-03-19 11:29:42.175265 4 0 15275 +3747 1640 0 2020-03-19 07:56:43.83247 2020-03-19 09:32:44.130343 4 0 12895 +3746 1639 0 2020-03-19 06:15:01.871268 2020-03-19 07:54:12.347234 4 0 13256 +3745 1638 0 2020-03-19 03:51:08.822405 2020-03-19 06:05:00.241864 4 0 17984 +3744 1637 0 2020-03-19 01:21:49.366537 2020-03-19 03:31:31.048134 4 0 17436 +3743 1636 0 2020-03-18 22:13:34.782175 2020-03-19 01:13:14.198194 4 0 24695 +3742 1635 0 2020-03-18 19:00:36.740347 2020-03-18 22:02:59.375153 4 0 28333 +3741 1634 0 2020-03-17 15:39:56.541039 2020-03-18 16:08:32.941759 3 0 2584240 +3740 1633 0 2020-03-17 15:17:23.933132 2020-03-17 15:35:29.397843 1 0 83853 +3739 1632 0 2020-03-17 14:56:00.578228 2020-03-17 15:13:47.166782 1 0 82009 +3738 1631 0 2020-03-17 13:56:09.691756 2020-03-17 14:13:15.028244 1 0 78585 +3737 1630 0 2020-03-17 13:35:14.118094 2020-03-17 13:52:29.821644 1 0 79965 +3736 1629 0 2020-03-17 11:43:21.351135 2020-03-17 13:25:27.056182 3 0 170473 +3735 1628 0 2020-03-17 07:15:03.370147 2020-03-17 11:36:49.012098 3 0 505433 +3734 1627 0 2020-03-16 17:48:03.484251 2020-03-17 07:03:42.9413 3 0 1478497 +3733 1626 0 2020-03-16 15:59:27.793886 2020-03-16 16:29:52.133452 3 0 50412 +3732 1625 0 2020-03-15 14:50:01.772321 2020-03-16 15:56:26.208939 3 0 2576075 +3731 1624 0 2020-03-14 11:14:03.05823 2020-03-15 14:47:07.990141 3 0 2764055 +3730 1623 0 2020-03-13 11:55:50.571386 2020-03-14 11:07:59.57506 3 0 2699496 +3729 1622 0 2020-03-13 10:59:39.033234 2020-03-13 11:16:52.444779 1 0 80518 +3728 1621 0 2020-03-13 10:36:18.380261 2020-03-13 10:52:55.719628 1 0 78210 +3727 1620 0 2020-03-13 01:48:51.79187 2020-03-13 10:23:30.089108 3 0 824596 +3726 1619 0 2020-03-11 22:45:56.596417 2020-03-13 01:45:02.886262 3 0 2842392 +3725 1618 0 2020-03-11 20:08:56.674725 3 0 +3724 1617 0 2020-03-11 17:08:43.831612 2020-03-11 19:52:23.457691 3 0 18572 +3723 1616 0 2020-03-11 11:35:55.381494 2020-03-11 16:26:44.706306 3 0 15189 +3722 1615 0 2020-03-11 11:11:08.224051 2020-03-11 11:28:05.943494 1 0 78461 +3721 1614 0 2020-03-11 10:50:13.857463 2020-03-11 11:07:10.015084 1 0 79174 +3720 1613 0 2020-03-10 18:03:11.705837 2020-03-11 10:44:52.201226 3 0 1343055 +3719 1612 0 2020-03-09 23:05:43.472768 2020-03-10 15:42:14.900075 4 0 57774 +3718 1611 0 2020-03-09 16:32:55.75404 2020-03-09 23:00:32.582819 4 0 22210 +3717 1610 0 2020-03-09 10:04:44.975112 2020-03-09 16:30:16.924941 4 0 20127 +3716 1609 0 2020-03-09 07:31:56.19354 2020-03-09 10:01:51.315865 4 0 9070 +3715 1608 0 2020-03-09 02:50:24.875661 2020-03-09 07:28:35.047062 4 0 15896 +3714 1607 0 2020-03-09 02:28:17.759373 2020-03-09 02:44:16.843094 4 0 846 +3713 1606 1 2020-03-08 23:23:39.466869 4 0 +3712 1606 0 2020-03-08 17:05:24.14786 2020-03-08 23:21:37.37438 4 0 24396 +3711 1605 0 2020-03-07 17:45:16.38427 2020-03-08 15:57:21.477438 3 0 1084471 +3710 1604 0 2020-03-07 12:23:09.863296 2020-03-07 13:43:13.352257 3 0 151203 +3709 1603 1 2020-03-07 11:25:51.122408 3 0 +3708 1603 0 2020-03-07 10:42:56.102066 2020-03-07 11:20:38.599904 3 0 73860 +3707 1602 0 2020-03-07 10:13:10.040318 2020-03-07 10:23:15.82895 3 0 19262 +3706 1601 0 2020-03-06 10:32:25.242998 2020-03-07 09:59:52.575291 3 0 1051834 +3705 1600 0 2020-03-05 16:47:52.12913 2020-03-05 17:01:08.030138 1 0 64478 +3704 1599 0 2020-03-05 16:20:31.73699 2020-03-05 16:40:55.990203 1 0 99321 +3703 1598 0 2020-03-05 16:01:10.575291 2020-03-05 16:14:20.661593 1 0 63935 +3702 1597 0 2020-03-05 15:42:24.573697 2020-03-05 15:55:57.223753 1 0 64988 +3701 1596 0 2020-03-04 20:06:04.273134 2020-03-05 11:43:51.379743 4 0 98301 +3700 1595 0 2020-03-04 13:24:22.21181 2020-03-04 19:31:02.557815 4 0 46000 +3699 1594 0 2020-03-04 10:45:29.481816 2020-03-04 13:01:15.956251 4 0 18218 +3698 1593 0 2020-03-03 12:28:57.396926 2020-03-04 10:26:16.706527 4 0 43802 +3697 1592 0 2020-03-03 02:16:23.149793 2020-03-03 12:09:57.605319 4 0 19243 +3696 1591 0 2020-03-03 00:11:55.877133 2020-03-03 02:10:38.439718 4 0 3776 +3695 1590 0 2020-03-02 19:15:08.215986 2020-03-02 22:46:56.502602 4 0 6730 +3694 1589 0 2020-03-02 11:27:01.446972 2020-03-02 12:00:13.239397 4 0 918 +3693 1588 0 2020-03-01 13:14:58.493117 2020-03-02 11:23:15.745233 3 0 846502 +3692 1587 0 2020-03-01 11:43:41.112875 2020-03-01 12:14:19.636426 4 0 837 +3691 1586 0 2020-02-29 18:36:04.538328 2020-03-01 11:39:55.384246 3 0 749180 +3690 1585 0 2020-02-29 18:29:23.382625 2020-02-29 18:33:39.134674 3 0 2672 +3689 1584 0 2020-02-29 17:55:11.308604 2020-02-29 18:23:06.448825 3 0 19109 +3688 1583 0 2020-02-29 17:53:00.278136 3 0 +3687 1582 0 2020-02-29 17:47:46.620208 2020-02-29 17:50:50.86663 3 0 1868 +3686 1581 0 2020-02-29 14:51:19.587843 2020-02-29 17:44:39.270086 3 0 119979 +3685 1580 0 2020-02-29 14:41:05.601314 2020-02-29 14:47:41.076429 3 0 4411 +3684 1579 0 2020-02-29 14:33:25.18022 3 0 +3683 1578 0 2020-02-29 14:27:37.530619 3 0 +3682 1577 0 2020-02-29 14:23:30.318624 3 0 +3681 1576 0 2020-02-29 14:12:35.029534 3 0 +3680 1575 0 2020-02-29 13:04:04.169877 3 0 +3679 1574 0 2020-02-29 12:16:24.763421 3 0 +3678 1573 0 2020-02-29 11:13:15.428108 3 0 +3677 1572 0 2020-02-29 10:24:20.968593 3 0 +3676 1571 0 2020-02-29 10:14:09.288769 3 0 +3675 1570 0 2020-02-29 10:11:18.361094 3 0 +3674 1569 0 2020-02-29 01:14:32.334334 3 0 +3673 1568 0 2020-02-29 00:01:59.71084 2020-02-29 01:12:22.609812 4 0 1164 +3672 1567 0 2020-02-28 23:29:48.061879 2020-02-28 23:57:58.728851 4 0 912 +3671 1566 0 2020-02-28 22:43:56.510524 2020-02-28 23:15:30.879223 4 0 1055 +3670 1565 0 2020-02-28 20:01:15.725882 2020-02-28 22:40:38.679656 4 0 3474 +3669 1564 0 2020-02-28 19:10:04.869273 2020-02-28 19:59:14.702288 4 0 1336 +3668 1563 0 2020-02-28 18:37:10.846633 2020-02-28 19:06:08.690072 4 0 782 +3667 1562 0 2020-02-28 16:51:53.172042 2020-02-28 16:55:21.151699 4 0 57 +3666 1561 0 2020-02-28 16:43:45.202866 3 0 +3665 1560 0 2020-02-28 16:35:16.411751 3 0 +3664 1559 0 2020-02-28 16:16:11.324163 3 0 +3663 1558 0 2020-02-27 16:16:51.588293 2020-02-28 10:14:32.403071 4 0 17634 +3662 1557 0 2020-02-27 15:05:16.559192 2020-02-27 16:09:30.122561 4 0 1050 +3661 1556 0 2020-02-27 14:14:00.362409 2020-02-27 14:27:10.458262 4 0 87 +3660 1555 0 2020-02-26 19:51:00.993076 2020-02-27 12:01:58.319105 3 0 485517 +3659 1554 0 2020-02-26 12:58:01.289925 2020-02-26 16:48:17.073388 3 0 161065 +3658 1553 0 2020-02-26 11:16:13.640511 2020-02-26 11:32:53.687504 1 0 78710 +3657 1552 0 2020-02-26 10:55:05.419864 2020-02-26 11:09:07.483251 1 0 66480 +3656 1551 0 2020-02-26 10:43:25.809482 1 0 +3655 1550 0 2020-02-26 00:07:18.202026 3 0 +3654 1549 0 2020-02-25 01:48:57.343197 3 0 +3653 1548 0 2020-02-24 22:23:26.960244 2020-02-25 01:41:17.047754 4 0 12784 +3652 1547 0 2020-02-24 22:16:25.889752 4 0 +3651 1546 0 2020-02-24 17:25:16.141915 2020-02-24 21:56:34.705281 1 0 1194349 +3650 1545 0 2020-02-24 17:07:38.6989 2020-02-24 17:21:44.900011 1 0 66200 +3649 1544 0 2020-02-24 16:41:26.461625 2020-02-24 16:55:29.688531 1 0 66151 +3648 1543 0 2020-02-23 22:54:11.023091 3 0 +3647 1542 0 2020-02-23 22:32:07.850928 2020-02-23 22:47:22.468833 1 0 71588 +3646 1541 0 2020-02-23 22:01:14.499598 2020-02-23 22:23:56.534122 1 0 107732 +3645 1540 0 2020-02-23 21:42:33.753597 2020-02-23 21:56:35.16818 1 0 66087 +3644 1539 0 2020-02-23 21:13:30.578198 2020-02-23 21:36:13.762745 1 0 108248 +3643 1538 0 2020-02-23 16:42:51.263425 2020-02-23 21:09:20.572801 3 0 184742 +3642 1537 0 2020-02-23 16:21:58.816245 2020-02-23 16:36:52.586202 1 0 69947 +3641 1536 0 2020-02-23 15:55:46.822779 2020-02-23 16:13:15.824223 1 0 82158 +3640 1535 0 2020-02-23 15:32:27.597102 2020-02-23 15:47:14.703876 1 0 68264 +3639 1534 0 2020-02-23 14:56:45.501315 2020-02-23 15:28:30.708539 1 0 77714 +3638 1533 0 2020-02-23 02:08:06.089669 3 0 +3637 1532 0 2020-02-22 16:21:24.110946 2020-02-22 16:41:15.316105 1 0 93343 +3636 1531 0 2020-02-22 16:01:02.54189 2020-02-22 16:17:56.549747 1 0 79849 +3635 1530 0 2020-02-21 21:57:17.918803 2020-02-22 15:56:19.439611 3 0 621696 +3634 1529 0 2020-02-21 21:37:00.79073 2020-02-21 21:53:16.900874 1 0 79043 +3633 1528 0 2020-02-21 01:46:37.38863 2020-02-21 09:22:44.880889 3 0 288799 +3632 1527 0 2020-02-21 00:41:47.457955 2020-02-21 01:26:23.711467 3 0 30634 +3631 1526 0 2020-02-20 20:05:46.945096 2020-02-21 00:31:42.635886 3 0 184617 +3630 1525 0 2020-02-20 18:11:02.613303 2020-02-20 18:25:17.182198 1 0 67084 +3629 1524 0 2020-02-20 17:47:09.395759 2020-02-20 18:04:18.127408 1 0 81081 +3628 1523 0 2020-02-20 13:05:13.07519 2020-02-20 17:36:50.346734 3 0 180843 +3627 1522 0 2020-02-19 19:34:28.818778 2020-02-20 12:30:44.380094 3 0 711764 +3626 1521 0 2020-02-19 19:12:44.525394 2020-02-19 19:26:28.136296 1 0 66468 +3625 1520 0 2020-02-19 18:43:36.526785 2020-02-19 19:00:35.672248 1 0 82066 +3624 1519 0 2020-02-19 18:10:01.834335 2020-02-19 18:29:19.643117 1 0 92877 +3623 1518 0 2020-02-19 17:43:46.835441 2020-02-19 18:01:19.95954 1 0 84809 +3622 1517 0 2020-02-19 06:08:56.459385 3 0 +3621 1516 0 2020-02-19 05:53:16.672475 3 0 +3620 1515 0 2020-02-19 04:08:19.986981 3 0 +3619 1514 0 2020-02-19 03:39:41.707405 3 0 +3618 1513 0 2020-02-18 18:49:35.859047 1 0 +3617 1512 0 2020-02-18 17:56:08.365587 1 0 +3616 1511 0 2020-02-18 17:26:30.62509 1 0 +3615 1510 0 2020-02-18 17:20:43.915781 1 0 +3614 1509 0 2020-02-18 12:58:12.083274 4 0 +3613 1508 0 2020-02-17 22:13:25.61556 3 0 +3612 1507 0 2020-02-17 21:56:56.968912 2020-02-17 22:10:58.17526 1 0 65519 +3611 1506 0 2020-02-17 21:38:04.410448 2020-02-17 21:51:37.900553 1 0 63746 +3610 1505 0 2020-02-17 16:34:33.733262 2020-02-17 21:29:13.188611 3 0 204150 +3609 1504 0 2020-02-17 12:32:24.784767 4 0 +3608 1503 0 2020-02-16 20:12:16.677552 3 0 +3607 1502 0 2020-02-16 19:47:25.03946 2020-02-16 20:05:30.779271 1 0 85004 +3606 1501 0 2020-02-16 19:29:25.512217 2020-02-16 19:43:37.5053 1 0 66535 +3605 1500 0 2020-02-16 11:55:06.970239 2020-02-16 19:20:28.159117 3 0 320419 +3604 1499 0 2020-02-15 20:28:30.648637 3 0 +3603 1498 0 2020-02-15 20:06:41.758418 2020-02-15 20:20:08.932272 1 0 63563 +3602 1497 0 2020-02-15 19:47:05.292406 2020-02-15 20:01:59.31371 1 0 70739 +3601 1496 0 2020-02-15 14:03:01.304926 2020-02-15 19:42:19.022225 3 0 291247 +3600 1495 0 2020-02-14 20:06:41.013155 2020-02-15 13:59:16.183302 3 0 843644 +3599 1494 0 2020-02-14 19:45:20.286005 2020-02-14 19:59:38.274815 1 0 66921 +3598 1493 0 2020-02-14 19:26:40.331648 2020-02-14 19:41:02.403404 1 0 67255 +3597 1492 0 2020-02-14 19:05:02.514067 2020-02-14 19:18:34.993024 1 0 63901 +3596 1491 0 2020-02-14 18:46:57.779213 2020-02-14 19:01:12.851377 1 0 67105 +3595 1490 0 2020-02-14 18:30:18.413792 2020-02-14 18:42:01.412419 3 0 12095 +3594 1489 0 2020-02-14 10:45:25.585054 2020-02-14 18:27:42.281949 3 0 370020 +3593 1488 0 2020-02-14 00:55:49.58397 2020-02-14 10:37:14.533315 3 0 404105 +3592 1487 0 2020-02-13 16:19:26.857823 2020-02-14 00:50:46.449509 3 0 354844 +3591 1486 0 2020-02-13 16:03:07.005751 2020-02-13 16:16:25.252499 1 0 65413 +3590 1485 0 2020-02-13 15:41:01.12088 2020-02-13 15:58:47.219128 1 0 78821 +3589 1484 0 2020-02-13 14:24:32.158826 3 0 +3588 1483 0 2020-02-13 11:48:32.611313 2020-02-13 14:08:53.776495 3 0 95768 +3587 1482 0 2020-02-12 20:53:21.103462 2020-02-13 11:21:08.794712 3 0 596521 +3586 1481 0 2020-02-12 19:06:21.89415 2020-02-12 20:26:33.079706 1 0 374450 +3585 1480 0 2020-02-12 18:40:23.816999 2020-02-12 18:55:41.482173 1 0 71126 +3584 1479 0 2020-02-12 16:22:31.469339 2020-02-12 18:36:53.733791 4 0 8978 +3583 1478 0 2020-02-12 09:52:53.137068 2020-02-12 15:20:21.200766 3 0 264234 +3582 1477 0 2020-02-12 00:08:07.225015 3 0 +3581 1476 0 2020-02-11 23:32:22.342018 2020-02-11 23:55:30.909331 3 0 15000 +3580 1475 0 2020-02-11 21:08:47.667636 2020-02-11 23:25:32.317368 3 0 74087 +3579 1474 0 2020-02-11 20:47:00.058182 2020-02-11 21:02:37.089559 1 0 71826 +3578 1473 0 2020-02-11 20:26:54.171021 2020-02-11 20:40:57.26216 1 0 64721 +3577 1472 0 2020-02-11 20:00:14.269537 2020-02-11 20:19:22.607311 1 0 89010 +3576 1471 0 2020-02-11 14:48:39.331168 2020-02-11 15:22:48.58774 3 0 71819 +3575 1470 0 2020-02-11 09:29:39.011757 3 0 +3574 1469 0 2020-02-10 20:30:02.224735 3 0 +3573 1468 0 2020-02-10 20:10:27.696346 2020-02-10 20:24:57.402725 1 0 68058 +3572 1467 0 2020-02-10 19:47:27.34603 2020-02-10 20:03:34.178466 1 0 74744 +3571 1466 0 2020-02-10 16:22:00.824743 2020-02-10 19:41:51.279645 3 0 130829 +3570 1465 0 2020-02-10 15:53:43.879573 2020-02-10 16:17:52.729893 3 0 14348 +3569 1464 0 2020-02-10 13:07:11.050559 2020-02-10 15:49:35.645072 3 0 112932 +3568 1463 0 2020-02-10 12:49:52.0908 2020-02-10 12:58:28.580953 3 0 7092 +3567 1462 0 2020-02-10 12:00:55.346193 3 0 +3566 1461 0 2020-02-10 11:47:10.488588 2020-02-10 11:58:01.518538 3 0 7130 +3565 1460 0 2020-02-10 10:52:03.918499 2020-02-10 11:36:41.425413 3 0 30869 +3564 1459 0 2020-02-09 20:14:51.974215 2020-02-10 10:46:43.877728 3 0 614410 +3563 1458 0 2020-02-09 19:53:15.934066 2020-02-09 20:10:18.652868 1 0 78913 +3562 1457 0 2020-02-09 19:31:50.6577 2020-02-09 19:48:49.359063 1 0 79180 +3561 1456 0 2020-02-09 18:22:26.450409 2020-02-09 19:25:27.218114 3 0 43958 +3560 1455 0 2020-02-09 11:04:00.803652 2020-02-09 18:18:30.119167 3 0 360845 +3559 1454 0 2020-02-08 22:54:49.029797 2020-02-09 11:00:46.171658 3 0 510803 +3558 1453 0 2020-02-08 22:11:57.31202 2020-02-08 22:51:06.615107 3 0 27354 +3557 1452 0 2020-02-08 21:50:25.156665 2020-02-08 22:05:53.472783 1 0 71922 +3556 1451 0 2020-02-08 21:25:05.046183 2020-02-08 21:39:52.792154 1 0 68236 +3555 1450 0 2020-02-08 21:03:35.823476 2020-02-08 21:17:40.012967 1 0 65033 +3554 1449 0 2020-02-08 20:28:18.527269 2020-02-08 20:54:05.665863 3 0 17844 +3553 1448 0 2020-02-08 14:38:34.133092 2020-02-08 20:22:25.10742 3 0 241775 +3552 1447 0 2020-02-07 23:06:41.14145 2020-02-08 14:35:18.935367 3 0 496372 +3551 1446 0 2020-02-07 20:47:44.320615 2020-02-07 21:01:45.00938 1 0 64940 +3550 1445 0 2020-02-07 20:29:15.316937 2020-02-07 20:43:07.927175 1 0 64235 +3549 1444 0 2020-02-07 16:00:42.738328 2020-02-07 20:22:01.844838 3 0 183138 +3548 1443 0 2020-02-07 14:21:42.204187 2020-02-07 14:55:36.170138 1 0 159334 +3547 1442 0 2020-02-06 19:32:37.446703 3 0 +3546 1441 0 2020-02-06 19:05:55.600325 2020-02-06 19:20:32.023292 1 0 67642 +3545 1440 0 2020-02-06 18:45:31.313431 2020-02-06 18:59:27.295793 1 0 64629 +3544 1439 0 2020-02-05 23:01:47.864728 3 0 +3543 1438 0 2020-02-05 22:34:02.509712 2020-02-05 22:53:10.530568 1 0 88833 +3542 1437 0 2020-02-05 21:51:43.235355 2020-02-05 22:18:13.834407 1 0 123317 +3541 1436 0 2020-02-05 21:16:55.4853 2020-02-05 21:44:59.261044 1 0 131581 +3540 1435 0 2020-02-04 19:57:38.867539 2020-02-05 21:11:44.738453 3 0 799610 +3539 1434 0 2020-02-04 19:20:08.864355 2020-02-04 19:53:24.457967 1 0 155028 +3538 1433 0 2020-02-04 18:59:10.497823 2020-02-04 19:13:09.42238 1 0 64260 +3537 1432 0 2020-02-03 20:14:03.936588 3 0 +3536 1431 0 2020-02-03 19:05:52.290691 2020-02-03 19:35:40.543681 1 0 141972 +3535 1430 0 2020-02-03 18:39:49.965184 2020-02-03 18:56:42.684763 1 0 78810 +3534 1429 0 2020-02-03 18:13:31.98809 2020-02-03 18:31:57.733887 1 0 85797 +3533 1428 0 2020-02-02 22:01:57.591524 2020-02-03 18:04:35.436309 3 0 896287 +3532 1427 0 2020-02-02 21:33:34.809782 2020-02-02 21:47:34.667947 1 0 64524 +3531 1426 0 2020-02-02 21:08:50.503322 2020-02-02 21:25:58.51482 1 0 79510 +3530 1425 0 2020-02-02 20:41:22.055317 2020-02-02 20:56:06.032863 1 0 67981 +3529 1424 0 2020-02-01 21:21:27.521197 3 0 +3528 1423 0 2020-02-01 20:43:47.690428 2020-02-01 20:44:48.616757 3 0 352 +3527 1422 0 2020-02-01 20:26:02.427304 2020-02-01 20:40:21.50941 1 0 66441 +3526 1421 0 2020-02-01 20:04:59.230029 2020-02-01 20:20:20.449889 1 0 71416 +3525 1420 0 2020-02-01 19:42:49.616189 2020-02-01 19:57:39.863931 1 0 68551 +3524 1419 0 2020-01-31 18:39:56.459387 3 0 +3523 1418 0 2020-01-31 18:21:07.228702 2020-01-31 18:34:54.595272 1 0 63455 +3522 1417 0 2020-01-31 18:03:04.938456 2020-01-31 18:17:39.135316 1 0 67698 +3521 1416 0 2020-01-31 17:42:30.118558 2020-01-31 17:56:13.266617 1 0 63696 +3520 1415 0 2020-01-30 17:10:40.360763 2020-01-31 17:36:12.576499 3 0 1074050 +3519 1414 0 2020-01-30 16:43:48.872252 2020-01-30 17:04:15.00827 1 0 95895 +3518 1413 0 2020-01-30 16:22:32.075823 2020-01-30 16:36:34.609349 1 0 66340 +3517 1412 0 2020-01-30 15:59:15.557329 2020-01-30 16:13:56.519061 1 0 69365 +3516 1411 0 2020-01-30 15:18:44.391485 2020-01-30 15:40:15.080144 1 0 100863 +3515 1410 0 2020-01-30 13:39:12.233395 2020-01-30 14:56:56.062858 3 0 64856 +3514 1409 0 2020-01-30 13:09:50.544958 2020-01-30 13:36:22.053506 1 0 126504 +3513 1408 0 2020-01-29 19:20:18.816807 2020-01-30 13:01:15.199127 3 0 934977 +3512 1407 0 2020-01-29 18:42:03.128319 2020-01-29 19:00:57.460365 1 0 88980 +3511 1406 0 2020-01-29 18:18:07.826208 2020-01-29 18:35:52.544914 1 0 83199 +3510 1405 0 2020-01-29 17:35:21.540356 2020-01-29 17:55:35.335588 1 0 95358 +3509 1404 0 2020-01-28 19:32:03.707388 3 0 +3508 1403 0 2020-01-28 19:08:11.379945 2020-01-28 19:22:40.608521 1 0 67661 +3507 1402 0 2020-01-28 18:47:28.436142 2020-01-28 19:01:00.023773 1 0 63601 +3506 1401 0 2020-01-28 18:15:42.003537 2020-01-28 18:31:28.56679 1 0 74103 +3505 1400 0 2020-01-28 14:51:46.779334 2020-01-28 18:11:11.561012 3 0 179097 +3504 1399 0 2020-01-28 14:47:21.645807 3 0 +3503 1398 0 2020-01-28 14:44:05.444517 3 0 +3502 1397 0 2020-01-28 14:20:27.354307 3 0 +3501 1396 0 2020-01-28 13:47:40.876199 3 0 +3500 1395 0 2020-01-28 13:30:50.267887 3 0 +3499 1394 0 2020-01-28 12:00:05.192476 2020-01-28 12:45:32.240488 3 0 0 +3498 1393 0 2020-01-27 19:58:15.604477 2020-01-27 20:12:36.071538 1 0 67037 +3497 1392 0 2020-01-27 18:24:47.403273 2020-01-27 18:39:18.753417 1 0 68469 +3496 1391 0 2020-01-27 18:02:02.949606 2020-01-27 18:16:24.126192 1 0 68033 +3495 1390 0 2020-01-26 19:37:23.546455 2020-01-26 19:52:20.588642 1 0 69865 +3494 1389 0 2020-01-26 19:11:47.930629 2020-01-26 19:25:54.360006 1 0 66049 +3493 1388 0 2020-01-26 18:46:47.245326 2020-01-26 19:02:37.768805 1 0 73881 +3492 1387 0 2020-01-25 20:54:15.177195 3 0 +3491 1386 0 2020-01-25 20:31:30.790692 2020-01-25 20:49:12.653386 1 0 83751 +3490 1385 0 2020-01-25 20:06:25.82397 2020-01-25 20:20:19.234761 1 0 65220 +3489 1384 0 2020-01-25 19:45:43.48078 2020-01-25 19:59:32.83231 1 0 65394 +3488 1383 0 2020-01-24 22:55:21.142024 2020-01-25 19:36:11.724157 3 0 1052987 +3487 1382 0 2020-01-24 21:05:58.459165 2020-01-24 21:20:39.859644 1 0 68293 +3486 1381 0 2020-01-24 20:46:33.425899 2020-01-24 21:00:34.068063 1 0 65984 +3485 1380 0 2020-01-24 20:22:27.177469 2020-01-24 20:37:05.698998 1 0 68363 +3484 1379 0 2020-01-24 19:27:01.567196 2020-01-24 20:02:14.490084 1 0 170569 +3483 1378 0 2020-01-24 13:31:01.855901 2020-01-24 13:58:06.915998 1 0 129224 +3482 1377 0 2020-01-24 11:42:21.38819 2020-01-24 11:50:20.560687 4 0 245 +3481 1376 0 2020-01-24 11:20:44.709016 2020-01-24 11:26:05.255787 4 0 165 +3480 1375 0 2020-01-24 09:23:05.536868 2020-01-24 09:44:54.301991 4 0 2072 +3479 1374 0 2020-01-24 09:13:39.049566 2020-01-24 09:20:01.144457 4 0 17538 +3478 1373 0 2020-01-23 20:37:14.233195 3 0 +3477 1372 0 2020-01-23 19:33:58.586316 2020-01-23 20:23:50.745745 1 0 233914 +3476 1371 0 2020-01-23 18:31:33.91414 2020-01-23 18:45:38.484837 1 0 66081 +3475 1370 0 2020-01-23 17:59:35.693049 2020-01-23 18:13:55.763138 1 0 67239 +3474 1369 0 2020-01-23 17:38:54.321819 2020-01-23 17:52:58.53474 1 0 66408 +3473 1368 0 2020-01-23 15:48:35.802326 2020-01-23 16:14:27.278094 4 0 177 +3472 1367 0 2020-01-23 10:31:20.141881 2020-01-23 13:18:42.964935 3 0 140447 +3471 1366 0 2020-01-22 21:45:45.376048 2020-01-22 22:01:07.357323 1 0 72294 +3470 1365 0 2020-01-22 21:01:06.025282 2020-01-22 21:21:46.624001 1 0 97004 +3469 1364 0 2020-01-22 19:28:45.117405 2020-01-22 19:43:01.236843 1 0 66520 +3468 1363 0 2020-01-22 18:55:55.554782 2020-01-22 19:15:31.217321 1 0 89264 +3467 1362 0 2020-01-22 18:03:08.650734 2020-01-22 18:31:52.839535 1 0 79961 +3466 1361 0 2020-01-21 20:27:16.719783 3 0 +3465 1360 0 2020-01-21 19:37:56.507473 2020-01-21 19:59:37.069074 1 0 101769 +3464 1359 0 2020-01-21 19:19:52.065125 2020-01-21 19:33:46.902841 1 0 65381 +3463 1358 0 2020-01-21 10:58:09.733246 2020-01-21 19:02:16.508856 3 0 410990 +3462 1357 0 2020-01-20 18:05:23.123439 2020-01-20 18:18:54.955373 1 0 63385 +3461 1356 0 2020-01-20 17:47:22.561388 2020-01-20 18:01:26.757066 1 0 65994 +3460 1355 0 2020-01-19 14:36:57.653196 2020-01-19 14:50:42.257992 1 0 64670 +3459 1354 0 2020-01-19 14:14:35.042744 2020-01-19 14:32:27.452043 1 0 83622 +3458 1353 0 2020-01-18 20:19:55.422572 2020-01-18 20:33:44.645224 1 0 65057 +3457 1352 0 2020-01-18 19:59:02.567191 2020-01-18 20:14:18.777085 1 0 71056 +3456 1351 0 2020-01-17 16:00:32.44695 3 0 +3455 1350 0 2020-01-17 15:42:05.967513 2020-01-17 15:56:01.916402 1 0 64543 +3454 1349 0 2020-01-17 15:13:03.243175 2020-01-17 15:28:25.448997 1 0 71324 +3453 1348 0 2020-01-17 13:11:51.900262 2020-01-17 15:04:10.402626 3 0 73885 +3452 1347 0 2020-01-17 01:22:38.171668 2020-01-17 09:24:32.269679 3 0 331130 +3451 1346 0 2020-01-16 19:42:09.642189 2020-01-16 19:58:46.467838 1 0 77703 +3450 1345 0 2020-01-16 19:11:48.664808 2020-01-16 19:27:11.689468 1 0 71234 +3449 1344 0 2020-01-16 15:49:18.185144 1 0 +3448 1343 0 2020-01-15 17:24:34.026404 3 0 +3447 1342 0 2020-01-15 17:02:00.657646 2020-01-15 17:17:56.416293 1 0 74489 +3446 1341 0 2020-01-15 16:40:30.855656 2020-01-15 16:56:22.45625 1 0 73012 +3445 1340 0 2020-01-15 07:41:33.428632 2020-01-15 16:37:09.619397 3 0 355619 +3444 1339 0 2020-01-14 14:33:54.532562 2020-01-14 14:50:52.037036 1 0 78908 +3443 1338 0 2020-01-14 14:07:49.97333 2020-01-14 14:22:06.545964 1 0 65975 +3442 1337 0 2020-01-14 12:08:38.713763 2020-01-14 12:19:04.752191 1 0 48331 +3441 1336 0 2020-01-13 17:32:58.46514 1 0 +3440 1335 0 2020-01-13 17:28:36.023818 1 0 +3439 1334 0 2020-01-13 17:11:35.962851 1 0 +3438 1333 0 2020-01-13 16:55:37.720496 1 0 +3437 1332 0 2020-01-12 18:26:40.968129 3 0 +3436 1331 0 2020-01-12 18:03:44.156902 2020-01-12 18:23:53.489889 1 0 94732 +3435 1330 0 2020-01-12 11:14:33.236677 2020-01-12 18:01:07.546456 3 0 289051 +3434 1329 0 2020-01-11 23:49:12.188859 2020-01-12 11:10:03.437782 1 0 4737 +3433 1328 0 2020-01-11 23:12:00.590129 2020-01-11 23:28:53.933275 1 0 78793 +3432 1327 0 2020-01-11 22:48:10.851092 2020-01-11 23:04:58.801194 1 0 78859 +3431 1326 18 2020-01-11 14:09:31.431328 2020-01-11 14:09:37.981801 0 0 0 +3430 1326 17 2020-01-11 14:06:39.960133 2020-01-11 14:06:45.035379 0 0 0 +3429 1326 16 2020-01-11 14:03:47.93363 2020-01-11 14:03:52.025888 0 0 0 +3428 1326 15 2020-01-11 14:00:56.463087 2020-01-11 14:01:01.440259 0 0 0 +3427 1326 14 2020-01-11 13:58:04.036129 2020-01-11 13:58:10.581526 0 0 0 +3426 1326 13 2020-01-11 13:55:12.535737 2020-01-11 13:55:17.589529 0 0 0 +3425 1326 12 2020-01-11 13:52:20.026472 2020-01-11 13:52:26.549262 0 0 0 +3424 1326 11 2020-01-11 13:49:28.543203 2020-01-11 13:49:32.067788 0 0 0 +3423 1326 10 2020-01-11 13:46:37.063619 2020-01-11 13:46:42.081493 0 0 0 +3422 1326 9 2020-01-11 13:43:45.519456 2020-01-11 13:43:50.679041 0 0 0 +3421 1326 8 2020-01-11 13:40:54.111674 2020-01-11 13:40:59.079267 0 0 0 +3420 1326 7 2020-01-11 13:38:02.663971 2020-01-11 13:38:06.196898 0 0 0 +3419 1326 6 2020-01-11 13:35:10.343265 2020-01-11 13:35:16.179156 0 0 0 +3418 1326 5 2020-01-11 13:32:18.890103 2020-01-11 13:32:23.918611 0 0 0 +3417 1326 4 2020-01-11 13:29:27.433717 2020-01-11 13:29:30.956282 0 0 0 +3416 1326 3 2020-01-11 13:26:35.957778 2020-01-11 13:26:40.999213 0 0 0 +3415 1326 2 2020-01-11 13:23:43.469103 2020-01-11 13:23:50.016662 0 0 0 +3414 1326 1 2020-01-11 13:20:51.943371 2020-01-11 13:20:57.017824 0 0 0 +3413 1326 0 2020-01-11 13:16:13.654798 2020-01-11 13:18:05.682852 0 0 0 +3412 1325 2 2020-01-11 13:08:26.221603 2020-01-11 13:08:38.779972 0 0 0 +3411 1325 1 2020-01-11 13:04:12.733558 2020-01-11 13:04:23.340118 0 0 0 +3410 1325 0 2020-01-11 12:58:23.546582 2020-01-11 13:00:10.307996 0 0 0 +3409 1324 0 2020-01-11 08:26:04.702594 2020-01-11 08:43:00.641478 1 0 78207 +3408 1323 0 2020-01-11 00:55:26.568797 2020-01-11 01:00:29.876602 3 0 24867 +3407 1322 0 2020-01-11 00:09:24.595507 2020-01-11 00:11:09.416227 0 0 0 +3406 1321 1 2020-01-10 22:53:57.921389 2020-01-10 22:54:02.136766 0 0 0 +3405 1321 0 2020-01-10 22:48:09.47988 2020-01-10 22:49:57.095188 0 0 0 +3404 1320 0 2020-01-10 14:50:24.618355 2020-01-10 15:06:36.757543 1 0 78463 +3403 1319 3 2020-01-10 13:29:22.748538 2020-01-10 13:29:40.470186 0 0 0 +3402 1319 2 2020-01-10 13:24:57.089042 2020-01-10 13:25:14.853387 0 0 0 +3401 1319 1 2020-01-10 13:20:42.585673 2020-01-10 13:20:56.149374 0 0 0 +3400 1319 0 2020-01-10 13:14:41.786133 2020-01-10 13:16:37.243115 0 0 0 +3399 1318 0 2020-01-09 17:24:20.834681 2020-01-09 17:40:55.361552 1 0 79089 +3398 1317 0 2020-01-09 17:01:25.992169 2020-01-09 17:18:16.664629 1 0 80290 +3397 1316 0 2020-01-08 18:23:47.782889 2020-01-08 18:40:10.690507 1 0 79145 +3396 1315 0 2020-01-08 18:03:05.847403 2020-01-08 18:19:39.160743 1 0 79468 +3395 1314 0 2020-01-08 12:08:20.074337 2020-01-08 12:45:09.005636 1 0 177859 +3394 1313 0 2020-01-08 00:32:07.259184 2020-01-08 00:49:03.261194 1 0 79187 +3393 1312 0 2020-01-07 20:28:15.216195 2020-01-07 20:58:32.398398 1 0 142703 +3392 1311 0 2020-01-07 20:01:23.411392 2020-01-07 20:24:54.065852 1 0 110685 +3391 1310 0 2020-01-07 18:49:47.152951 2020-01-07 19:06:43.513925 1 0 79606 +3390 1309 0 2020-01-07 01:44:53.632439 2020-01-07 02:02:43.888115 1 0 83664 +3389 1308 0 2020-01-07 01:03:12.363761 2020-01-07 01:21:33.273391 1 0 85155 +3388 1307 0 2020-01-06 17:36:32.724117 2020-01-06 18:06:11.04139 1 0 138480 +3387 1306 0 2020-01-06 15:45:57.801276 2020-01-06 17:19:42.964155 1 0 438666 +3386 1305 0 2020-01-05 21:18:11.356988 2020-01-05 21:48:36.249923 1 0 143559 +3385 1304 0 2020-01-05 18:16:56.124928 2020-01-05 18:33:48.013344 1 0 78810 +3384 1303 0 2020-01-05 17:39:22.561664 2020-01-05 18:03:10.604124 1 0 111218 +3383 1302 0 2020-01-05 17:05:13.857235 2020-01-05 17:31:59.343538 1 0 123778 +3382 1301 0 2020-01-05 16:27:08.699523 2020-01-05 16:53:45.284171 1 0 124074 +3381 1300 0 2020-01-05 03:53:49.529056 2020-01-05 04:19:12.520234 1 0 123795 +3380 1299 0 2020-01-04 23:55:35.796332 2020-01-05 00:31:05.40787 1 0 172533 +3379 1298 0 2020-01-04 23:27:55.544735 2020-01-04 23:50:55.09756 1 0 111754 +3378 1297 0 2020-01-04 02:22:55.359822 2020-01-04 02:45:34.573167 1 0 109995 +3377 1296 0 2020-01-03 20:55:11.538697 2020-01-03 21:13:07.95609 1 0 86430 +3376 1295 0 2020-01-03 20:26:32.343579 2020-01-03 20:52:20.397327 1 0 124570 +3375 1294 0 2020-01-03 19:53:26.117625 2020-01-03 20:15:32.29886 1 0 108642 +3374 1293 0 2020-01-02 21:58:01.55106 2020-01-02 22:27:25.314622 1 0 138315 +3373 1292 0 2020-01-02 14:00:27.086566 2020-01-02 14:23:22.562592 1 0 108538 +3372 1291 0 2020-01-02 13:27:31.344794 2020-01-02 13:45:29.980436 1 0 84582 +3371 1290 0 2020-01-02 12:39:16.090609 2020-01-02 13:09:00.924031 1 0 140471 +3370 1289 0 2020-01-01 11:23:28.861708 2020-01-01 11:37:34.273918 1 0 66423 +3369 1288 0 2020-01-01 11:03:52.622227 2020-01-01 11:18:34.549968 1 0 68964 +3368 1287 0 2019-12-31 14:23:54.697229 2019-12-31 14:41:05.349815 1 0 80246 +3367 1286 0 2019-12-31 14:02:44.312799 2019-12-31 14:17:19.707593 1 0 69089 +3366 1285 0 2019-12-31 01:58:51.215228 2019-12-31 02:31:43.450385 1 0 153679 +3365 1284 0 2019-12-31 01:33:04.825236 2019-12-31 01:53:27.500565 1 0 96522 +3364 1283 0 2019-12-31 00:55:57.915275 2019-12-31 01:16:04.779231 1 0 94983 +3363 1282 0 2019-12-31 00:31:05.143449 2019-12-31 00:52:22.113231 1 0 101830 +3362 1281 0 2019-12-31 00:05:01.260668 2019-12-31 00:25:51.430773 1 0 99170 +3361 1280 0 2019-12-30 23:38:00.157426 2019-12-30 23:59:13.894937 1 0 100881 +3360 1279 0 2019-12-30 23:06:39.170498 2019-12-30 23:27:52.179033 1 0 100521 +3359 1278 0 2019-12-29 14:46:51.477369 2019-12-29 15:34:44.18582 1 0 224796 +3358 1277 0 2019-12-29 14:24:38.12778 2019-12-29 14:41:40.845033 1 0 80853 +3357 1276 0 2019-12-29 01:50:15.375016 2019-12-29 02:07:06.097171 1 0 79549 +3356 1275 0 2019-12-29 01:30:34.413278 2019-12-29 01:47:11.626514 1 0 78652 +3355 1274 0 2019-12-27 19:31:12.770472 2019-12-27 20:06:44.966206 1 0 168020 +3354 1273 0 2019-12-27 18:24:43.730151 2019-12-27 19:16:38.243025 1 0 243191 +3353 1272 0 2019-12-27 01:47:37.319384 2019-12-27 02:04:34.692341 1 0 80033 +3352 1271 0 2019-12-26 02:09:53.141962 2019-12-26 02:28:00.609094 1 0 84389 +3351 1270 0 2019-12-24 23:33:14.502335 2019-12-24 23:51:37.551656 1 0 85669 +3350 1269 0 2019-12-24 18:15:05.131642 1 0 +3349 1268 0 2019-12-24 18:08:48.198583 1 0 +3348 1267 0 2019-12-24 18:04:21.266513 1 0 +3347 1266 0 2019-12-23 15:55:37.273002 2019-12-23 16:09:40.076304 1 0 66187 +3346 1265 0 2019-12-23 15:36:22.544011 2019-12-23 15:51:33.100362 1 0 71734 +3345 1264 0 2019-12-22 15:18:55.703558 2019-12-22 15:33:06.504939 1 0 66154 +3344 1263 0 2019-12-22 14:58:58.993092 2019-12-22 15:14:28.597315 1 0 72616 +3343 1262 0 2019-12-21 12:30:17.5122 2019-12-21 12:44:10.646252 1 0 64368 +3342 1261 0 2019-12-21 12:12:16.275177 2019-12-21 12:26:42.559386 1 0 68329 +3341 1260 0 2019-12-20 19:18:39.283809 2019-12-20 19:24:23.027904 1 0 26605 +3340 1259 0 2019-12-20 15:38:36.584873 2019-12-20 15:53:26.23701 1 0 69278 +3339 1258 0 2019-12-20 14:54:36.056984 2019-12-20 15:10:00.575575 1 0 71507 +3338 1257 0 2019-12-20 14:31:15.648868 2019-12-20 14:46:21.765931 1 0 70528 +3337 1256 0 2019-12-20 10:36:59.851176 2019-12-20 11:04:32.958187 1 0 92153 +3336 1255 0 2019-12-19 22:30:11.463193 2019-12-19 22:53:30.361346 1 0 105000 +3335 1254 0 2019-12-19 22:06:33.33189 2019-12-19 22:23:36.124583 1 0 79735 +3334 1253 0 2019-12-19 21:40:38.655269 2019-12-19 21:44:51.31198 1 0 19329 +3333 1252 0 2019-12-19 19:29:54.364823 2019-12-19 19:33:56.22084 1 0 18607 +3332 1251 0 2019-12-19 17:33:39.37859 2019-12-19 17:52:04.688231 1 0 80012 +3331 1250 0 2019-12-19 15:20:13.417349 2019-12-19 15:31:22.070556 1 0 48222 +3330 1249 0 2019-12-19 11:40:52.843629 2019-12-19 11:43:07.885918 1 0 10220 +3329 1248 1 2019-12-19 11:18:56.814248 2019-12-19 11:29:28.986323 1 0 49386 +3328 1248 0 2019-12-19 11:06:06.118933 2019-12-19 11:08:24.476123 1 0 10374 +3327 1247 0 2019-12-18 15:59:20.377495 2019-12-18 16:12:45.569919 1 0 65754 +3326 1246 0 2019-12-18 15:34:49.307538 2019-12-18 15:52:37.153078 1 0 86264 +3325 1245 0 2019-12-18 14:01:55.926374 2019-12-18 14:41:34.256657 1 0 192476 +3324 1244 0 2019-12-18 01:01:59.028447 2019-12-18 01:22:00.801797 1 0 94541 +3323 1243 0 2019-12-18 00:41:55.662149 2019-12-18 00:56:22.896356 1 0 68523 +3322 1242 0 2019-12-18 00:21:49.334737 2019-12-18 00:38:35.538649 1 0 78716 +3321 1241 0 2019-12-17 12:28:11.617397 2019-12-17 12:43:07.195139 1 0 70632 +3320 1240 0 2019-12-17 12:07:11.107724 2019-12-17 12:22:51.320292 1 0 74930 +3319 1239 0 2019-12-16 12:48:16.639757 2019-12-16 13:05:43.123696 1 0 82673 +3318 1238 0 2019-12-16 12:27:23.661114 2019-12-16 12:41:57.039477 1 0 68578 +3317 1237 0 2019-12-15 13:36:35.642441 2019-12-15 13:52:22.092889 1 0 74780 +3316 1236 0 2019-12-15 13:13:18.469793 2019-12-15 13:27:55.334575 1 0 67868 +3315 1235 0 2019-12-14 15:17:47.011535 2019-12-14 15:35:05.016388 1 0 81286 +3314 1234 0 2019-12-14 14:55:45.867328 2019-12-14 15:13:28.105286 1 0 84014 +3313 1233 0 2019-12-14 13:49:37.976184 2019-12-14 14:06:26.069995 1 0 79694 +3312 1232 0 2019-12-14 13:24:55.801241 2019-12-14 13:41:44.630645 1 0 79878 +3311 1231 0 2019-12-13 20:43:44.189638 2019-12-13 21:00:49.71522 1 0 80837 +3310 1230 0 2019-12-13 20:21:38.21346 2019-12-13 20:39:58.039392 1 0 86655 +3309 1229 0 2019-12-13 20:00:23.93348 2019-12-13 20:17:14.562413 1 0 80084 +3308 1228 0 2019-12-13 19:36:52.534797 2019-12-13 19:56:51.805682 1 0 95234 +3307 1227 0 2019-12-13 19:09:03.664805 2019-12-13 19:31:05.265657 1 0 104924 +3306 1226 0 2019-12-13 18:42:05.913401 2019-12-13 18:58:29.785765 1 0 78204 +3305 1225 0 2019-12-13 18:21:30.772096 2019-12-13 18:35:59.286412 1 0 68181 +3304 1224 0 2019-12-13 17:58:04.71741 2019-12-13 18:15:28.440928 1 0 82288 +3303 1223 0 2019-12-13 01:12:39.599385 2019-12-13 01:27:48.081424 1 0 71911 +3302 1222 0 2019-12-13 00:52:56.54593 2019-12-13 01:07:08.222691 1 0 66876 +3301 1221 0 2019-12-13 00:35:05.056881 2019-12-13 00:48:36.377226 1 0 64317 +3300 1220 0 2019-12-12 19:35:27.666691 2019-12-12 19:53:16.269699 1 0 84396 +3299 1219 0 2019-12-12 19:17:35.918151 2019-12-12 19:32:52.79863 1 0 72138 +3298 1218 0 2019-12-12 18:54:20.965973 2019-12-12 19:10:05.555462 1 0 74747 +3297 1217 0 2019-12-12 18:31:23.598883 2019-12-12 18:46:52.939236 1 0 73843 +3296 1216 0 2019-12-12 18:06:34.376983 2019-12-12 18:23:02.578745 1 0 78242 +3295 1215 0 2019-12-12 17:40:59.684161 2019-12-12 17:57:57.911999 1 0 79853 +3294 1214 2 2019-12-12 17:19:31.414771 1 0 +3293 1214 1 2019-12-12 17:02:09.710691 2019-12-12 17:16:15.020742 1 0 60341 +3292 1214 0 2019-12-12 16:45:47.029094 2019-12-12 16:58:30.826949 1 0 59999 +3291 1213 5 2019-12-12 12:25:38.18829 0 0 +3290 1213 4 2019-12-12 12:21:07.878708 2019-12-12 12:22:25.423455 0 0 2999 +3289 1213 3 2019-12-12 12:16:40.016909 2019-12-12 12:17:55.876325 0 0 2999 +3288 1213 2 2019-12-12 12:12:13.221623 2019-12-12 12:13:26.168899 0 0 2999 +3287 1213 1 2019-12-12 12:07:47.085262 2019-12-12 12:09:01.218707 0 0 2999 +3286 1213 0 2019-12-12 12:03:43.993468 2019-12-12 12:04:36.074853 0 0 2999 +3285 1212 4 2019-12-12 10:02:35.814655 2019-12-12 10:03:51.645558 0 0 3328 +3284 1212 3 2019-12-12 09:58:15.462237 2019-12-12 09:59:27.93875 0 0 3077 +3283 1212 2 2019-12-12 09:53:54.724524 2019-12-12 09:55:03.175721 0 0 2999 +3282 1212 1 2019-12-12 09:49:33.048888 2019-12-12 09:50:43.210799 0 0 2999 +3281 1212 0 2019-12-12 09:45:28.380197 2019-12-12 09:46:24.10866 0 0 2999 +3280 1211 2 2019-12-12 09:42:11.863394 2019-12-12 09:43:23.051052 0 0 2999 +3279 1211 1 2019-12-12 09:37:50.096721 2019-12-12 09:38:57.733008 0 0 2999 +3278 1211 0 2019-12-12 09:33:50.716308 2019-12-12 09:34:42.887627 0 0 2999 +3277 1210 8 2019-12-12 08:37:56.042665 0 0 +3276 1210 7 2019-12-12 08:34:25.623314 2019-12-12 08:35:15.333736 0 0 3326 +3275 1210 6 2019-12-12 08:31:02.959592 2019-12-12 08:31:47.323683 0 0 2999 +3274 1210 5 2019-12-12 08:27:41.332749 2019-12-12 08:28:22.944724 0 0 2999 +3273 1210 4 2019-12-12 08:24:18.885321 2019-12-12 08:25:02.446362 0 0 2999 +3272 1210 3 2019-12-12 08:20:49.002214 2019-12-12 08:21:32.291986 0 0 2999 +3271 1210 2 2019-12-12 08:17:18.400393 2019-12-12 08:18:02.816117 0 0 2999 +3270 1210 1 2019-12-12 08:13:56.778767 2019-12-12 08:14:37.804587 0 0 2999 +3269 1210 0 2019-12-12 08:10:34.07249 2019-12-12 08:11:16.877103 0 0 2999 +3268 1209 5 2019-12-12 08:06:22.435234 0 0 +3267 1209 4 2019-12-12 08:00:27.293489 2019-12-12 08:03:09.386654 0 0 6254 +3266 1209 3 2019-12-12 07:54:24.899016 2019-12-12 07:57:09.843824 0 0 6271 +3265 1209 2 2019-12-12 07:48:30.919519 2019-12-12 07:51:14.463351 0 0 6379 +3264 1209 1 2019-12-12 07:42:36.867712 2019-12-12 07:45:18.829549 0 0 6408 +3263 1209 0 2019-12-12 07:37:43.753245 2019-12-12 07:39:47.157795 0 0 2999 +3262 1208 1 2019-12-12 07:30:11.379839 0 0 +3261 1208 0 2019-12-12 07:26:43.909344 2019-12-12 07:29:01.786569 0 0 10765 +3260 1207 10 2019-12-12 07:15:24.782764 0 0 +3259 1207 9 2019-12-12 07:14:10.772564 2019-12-12 07:14:41.057114 0 0 55156 +3258 1207 8 2019-12-12 07:12:56.778499 2019-12-12 07:13:27.043937 0 0 49267 +3257 1207 7 2019-12-12 07:11:43.021171 2019-12-12 07:12:13.302869 0 0 43362 +3256 1207 6 2019-12-12 07:10:28.593075 2019-12-12 07:10:59.669315 0 0 37479 +3255 1207 5 2019-12-12 07:09:15.451462 2019-12-12 07:09:45.713514 0 0 31544 +3254 1207 4 2019-12-12 07:08:02.277907 2019-12-12 07:08:32.536367 0 0 25659 +3253 1207 3 2019-12-12 07:06:49.24838 2019-12-12 07:07:19.534612 0 0 19762 +3252 1207 2 2019-12-12 07:05:35.260308 2019-12-12 07:06:06.615465 0 0 13915 +3251 1207 1 2019-12-12 07:04:23.453988 2019-12-12 07:04:53.931411 0 0 8103 +3250 1207 0 2019-12-12 07:03:06.384998 2019-12-12 07:03:49.974457 0 0 2999 +3249 1206 1 2019-12-12 06:54:36.186063 0 0 +3248 1206 0 2019-12-12 06:53:03.61928 2019-12-12 06:53:47.246231 0 0 2999 +3247 1205 3 2019-12-12 06:49:26.622688 2019-12-12 06:49:26.931226 0 0 3469 +3246 1205 2 2019-12-12 06:49:26.114549 2019-12-12 06:49:26.364022 0 0 3424 +3245 1205 1 2019-12-12 06:49:24.889804 2019-12-12 06:49:25.157263 0 0 3328 +3244 1205 0 2019-12-12 06:48:37.512872 2019-12-12 06:49:21.102427 0 0 2999 +3243 1204 1 2019-12-12 06:39:23.496428 0 0 +3242 1204 0 2019-12-12 06:37:50.860715 2019-12-12 06:38:33.164674 0 0 2999 +3241 1203 1 2019-12-12 06:34:23.721138 0 0 +3240 1203 0 2019-12-12 06:32:51.089566 2019-12-12 06:33:37.282686 0 0 3000 +3239 1202 1 2019-12-12 06:24:19.602413 0 0 +3238 1202 0 2019-12-12 06:22:47.017114 2019-12-12 06:23:33.346459 0 0 3000 +3237 1201 1 2019-12-12 06:03:44.348623 0 0 +3236 1201 0 2019-12-12 06:02:10.763764 2019-12-12 06:02:58.703482 0 0 3000 +3235 1200 0 2019-12-12 05:54:06.860494 2019-12-12 05:55:39.43057 0 0 3000 +3234 1199 0 2019-12-12 05:49:37.449331 2019-12-12 05:51:10.059204 0 0 3000 +3233 1198 0 2019-12-12 05:25:07.578159 2019-12-12 05:26:40.166631 0 0 3000 +3232 1197 0 2019-12-12 05:18:53.055878 2019-12-12 05:20:20.603096 0 0 3000 +3231 1196 0 2019-12-12 05:14:05.755928 2019-12-12 05:16:10.088544 0 0 3000 +3230 1195 0 2019-12-12 05:11:03.61862 2019-12-12 05:13:08.24811 0 0 3000 +3229 1194 0 2019-12-12 05:07:24.950089 2019-12-12 05:09:29.998734 0 0 3000 +3228 1193 0 2019-12-12 04:57:56.383706 2019-12-12 04:59:58.992615 0 0 3000 +3227 1192 0 2019-12-12 04:49:37.521559 2019-12-12 04:51:05.428706 0 0 1500 +3226 1191 0 2019-12-11 23:46:00.443732 2019-12-12 00:00:25.625648 1 0 15000 +3225 1190 0 2019-12-11 23:27:33.123825 2019-12-11 23:42:34.344984 1 0 15000 +3224 1189 0 2019-12-11 23:08:45.916601 2019-12-11 23:24:38.662346 1 0 15000 +3223 1188 0 2019-12-11 16:45:00.392846 1 0 +3222 1187 0 2019-12-11 16:39:07.557575 2019-12-11 16:39:50.788541 1 0 15000 +3221 1186 0 2019-12-11 16:28:25.537742 2019-12-11 16:36:28.67029 1 0 15000 +3220 1185 0 2019-12-11 16:14:54.670983 2019-12-11 16:23:59.508719 1 0 15000 +3219 1184 0 2019-12-10 16:09:38.31271 2019-12-10 16:23:32.688567 1 0 15000 +3218 1183 0 2019-12-10 15:43:12.035035 2019-12-10 16:01:10.263153 1 0 15000 +3217 1182 0 2019-12-10 15:16:05.878561 2019-12-10 15:27:46.032808 1 0 15000 +3216 1181 0 2019-12-09 19:38:28.74701 2019-12-09 19:50:15.830689 1 0 15000 +3215 1180 0 2019-12-09 19:20:59.335986 2019-12-09 19:34:18.568604 1 0 15000 +3214 1179 0 2019-12-09 18:59:21.488855 2019-12-09 19:14:27.465393 1 0 15000 +3213 1178 0 2019-12-08 17:38:59.312088 2019-12-08 17:56:15.802267 1 0 15000 +3212 1177 0 2019-12-08 17:19:48.107046 2019-12-08 17:31:16.408846 1 0 15000 +3211 1176 0 2019-12-08 16:58:31.870068 2019-12-08 17:09:21.244267 1 0 15000 +3210 1175 0 2019-12-07 20:13:50.467454 2019-12-07 20:25:42.267972 1 0 15000 +3209 1174 0 2019-12-07 19:50:19.627908 2019-12-07 20:06:48.923381 1 0 15000 +3208 1173 0 2019-12-06 19:40:30.040292 2019-12-06 19:59:02.131331 1 0 15000 +3207 1172 0 2019-12-06 19:23:35.801006 2019-12-06 19:36:25.813796 1 0 15000 +3206 1171 0 2019-12-05 15:01:03.452138 2019-12-05 15:12:49.306332 1 0 15000 +3205 1170 0 2019-12-05 14:38:06.316315 2019-12-05 14:50:21.342774 1 0 15000 +3204 1169 0 2019-12-05 13:12:12.694549 2019-12-05 13:25:29.36496 1 0 15000 +3203 1168 0 2019-12-05 12:48:00.98093 2019-12-05 13:08:43.208198 1 0 15000 +3202 1167 0 2019-12-04 16:44:44.270642 2019-12-04 16:57:30.884311 1 0 15000 +3201 1166 0 2019-12-04 16:25:44.908567 2019-12-04 16:36:42.834858 1 0 15000 +3200 1165 0 2019-12-03 16:01:26.590428 2019-12-03 16:21:33.156216 1 0 15000 +3199 1164 0 2019-12-03 15:45:18.486417 2019-12-03 15:57:53.577394 1 0 15000 +3198 1163 0 2019-12-03 14:20:13.171653 2019-12-03 14:30:21.167277 1 0 15000 +3197 1162 0 2019-12-03 13:54:18.133564 2019-12-03 14:17:15.145567 1 0 15000 +3196 1161 0 2019-12-03 13:39:08.77771 2019-12-03 13:50:30.425774 1 0 15000 +3195 1160 0 2019-12-02 23:39:03.92958 2019-12-02 23:50:54.628429 1 0 15000 +3194 1159 0 2019-12-02 23:26:04.02964 2019-12-02 23:36:24.835911 1 0 15000 +3193 1158 0 2019-12-02 23:07:41.555505 2019-12-02 23:21:49.676335 1 0 15000 +3192 1157 0 2019-12-01 23:41:27.831286 2019-12-01 23:55:12.196297 1 0 15000 +3191 1156 0 2019-12-01 13:32:48.444762 2019-12-01 13:43:12.576062 1 0 15000 +3190 1155 0 2019-12-01 12:37:05.836136 2019-12-01 13:28:43.797518 1 0 15000 +3189 1154 0 2019-11-30 20:05:10.310598 2019-11-30 20:15:31.153923 1 0 15000 +3188 1153 0 2019-11-30 19:46:17.590627 2019-11-30 19:59:14.188671 1 0 15000 +3187 1152 0 2019-11-30 00:14:58.177178 2019-11-30 00:25:19.830655 1 0 15000 +3186 1151 0 2019-11-30 00:00:27.904252 2019-11-30 00:10:39.100797 1 0 15000 +3185 1150 0 2019-11-29 13:06:47.110938 2019-11-29 13:16:18.789885 1 0 15000 +3184 1149 0 2019-11-29 12:48:31.29233 2019-11-29 13:00:45.572629 1 0 15000 +3183 1148 0 2019-11-28 15:39:57.838097 2019-11-28 15:49:23.526104 1 0 15000 +3182 1147 0 2019-11-28 15:26:46.940617 2019-11-28 15:36:52.095122 1 0 15000 +3181 1146 0 2019-11-28 15:15:26.839615 2019-11-28 15:16:20.655409 1 0 0 +3180 1145 0 2019-11-28 15:13:18.514639 2019-11-28 15:14:05.888399 1 0 0 +3179 1144 0 2019-11-28 15:11:37.848469 2019-11-28 15:12:25.260459 1 0 0 +3178 1143 0 2019-11-27 11:41:00.585703 2019-11-27 11:58:20.611136 1 0 15000 +3177 1142 0 2019-11-27 11:25:25.709442 2019-11-27 11:36:34.840321 1 0 15000 +3176 1141 0 2019-11-27 10:58:51.424162 2019-11-27 11:10:45.104792 1 0 15000 +3175 1140 0 2019-11-27 10:46:28.280625 2019-11-27 10:56:40.763208 1 0 15000 +3174 1139 0 2019-11-26 15:44:45.58909 2019-11-26 15:56:10.704088 1 0 15000 +3173 1138 0 2019-11-26 15:27:22.69878 2019-11-26 15:39:37.780742 1 0 15000 +3172 1137 0 2019-11-26 02:23:44.049546 2019-11-26 02:36:12.515188 1 0 15000 +3171 1136 0 2019-11-26 02:09:24.49525 2019-11-26 02:20:46.788735 1 0 15000 +3170 1135 0 2019-11-26 01:51:14.086275 2019-11-26 02:02:10.621387 1 0 15000 +3169 1134 0 2019-11-26 01:22:33.545502 2019-11-26 01:35:57.039625 1 0 15000 +3168 1133 0 2019-11-26 01:04:40.457931 2019-11-26 01:17:59.071979 1 0 15000 +3167 1132 0 2019-11-25 13:39:05.574978 2019-11-25 14:03:45.406085 1 0 15000 +3166 1131 0 2019-11-22 13:33:34.510892 2019-11-22 13:44:18.655115 1 0 15000 +3165 1130 0 2019-11-21 19:35:10.690465 2019-11-21 19:45:21.026803 1 0 15000 +3164 1129 0 2019-11-21 19:21:26.139185 2019-11-21 19:31:44.469414 1 0 15000 +3163 1128 0 2019-11-21 19:08:34.361885 2019-11-21 19:18:41.959403 1 0 15000 +3162 1127 0 2019-11-21 18:55:16.078889 2019-11-21 19:05:25.798718 1 0 15000 +3161 1126 0 2019-11-21 18:41:34.864595 2019-11-21 18:52:31.860095 1 0 15000 +3160 1125 0 2019-11-21 18:25:59.670337 2019-11-21 18:36:25.443067 1 0 15000 +3159 1124 0 2019-11-21 18:01:10.651857 2019-11-21 18:16:28.695629 1 0 15000 +3158 1123 0 2019-11-20 16:12:39.72023 2019-11-20 16:37:49.685459 1 0 15000 +3157 1122 0 2019-11-20 00:37:16.977423 2019-11-20 00:46:23.75726 1 0 15000 +3156 1121 0 2019-11-20 00:24:33.395419 2019-11-20 00:33:45.994166 1 0 15000 +3155 1120 0 2019-11-20 00:12:08.055218 2019-11-20 00:21:12.525561 1 0 15000 +3154 1119 0 2019-11-19 23:56:32.083283 2019-11-20 00:05:32.179864 1 0 15000 +3153 1118 0 2019-11-19 23:43:19.302805 2019-11-19 23:52:28.079439 1 0 15000 +3152 1117 0 2019-11-19 23:31:15.257016 2019-11-19 23:40:15.531334 1 0 15000 +3151 1116 0 2019-11-19 17:15:43.931835 2019-11-19 17:24:40.748148 1 0 15000 +3150 1115 0 2019-11-19 15:15:27.605313 2019-11-19 15:24:23.061619 1 0 15000 +3149 1114 0 2019-11-19 12:41:48.571522 2019-11-19 12:50:53.863488 1 0 15000 +3148 1113 0 2019-11-19 12:26:01.068939 2019-11-19 12:35:12.754695 1 0 15000 +3147 1112 0 2019-11-19 12:12:35.565767 2019-11-19 12:21:45.686572 1 0 15000 +3146 1111 0 2019-11-18 22:09:56.032732 2019-11-18 22:18:57.234296 1 0 15000 +3145 1110 0 2019-11-18 21:51:10.319066 2019-11-18 22:00:14.034219 1 0 15000 +3144 1109 0 2019-11-18 21:14:02.388529 2019-11-18 21:21:19.796727 1 0 15000 +3143 1108 0 2019-11-18 16:34:24.52146 2019-11-18 16:38:34.313663 1 0 15000 +3142 1107 0 2019-11-18 16:10:47.359094 2019-11-18 16:20:07.187424 1 0 15000 +3141 1106 0 2019-11-18 15:08:46.265837 2019-11-18 15:09:02.469263 1 0 15000 +3140 1105 0 2019-11-17 17:04:22.577209 2019-11-17 17:42:15.211883 1 0 15000 +3139 1104 0 2019-11-17 16:06:59.338164 2019-11-17 16:15:51.121547 1 0 15000 +3138 1103 0 2019-11-17 07:52:19.054197 2019-11-17 07:56:20.241929 1 0 15000 +3137 1102 0 2019-11-17 07:34:49.048431 2019-11-17 07:35:27.182241 1 0 15000 +3136 1101 0 2019-11-17 07:24:55.726972 1 0 +3135 1100 0 2019-11-17 06:49:56.060367 2019-11-17 07:15:40.592336 0 0 15000 +3134 1099 0 2019-11-17 06:16:17.007433 0 0 +3133 1098 0 2019-11-17 06:12:09.401601 0 0 +3132 1097 0 2019-11-17 05:57:48.422299 2019-11-17 06:08:14.900347 1 0 15000 +3131 1096 0 2019-11-17 03:04:01.007233 2019-11-17 03:07:06.780951 1 0 15000 +3130 1095 0 2019-11-17 02:54:26.313617 2019-11-17 02:57:46.967532 1 0 15000 +3129 1094 0 2019-11-17 02:38:27.660092 2019-11-17 02:45:39.337506 1 0 15000 +3128 1093 0 2019-11-17 01:42:23.105239 2019-11-17 01:50:52.360365 1 0 15000 +3127 1092 0 2019-11-17 01:28:26.000693 2019-11-17 01:34:40.433609 1 0 15000 +3126 1091 0 2019-11-17 00:59:12.218487 1 0 +3125 1090 0 2019-11-17 00:37:09.960741 2019-11-17 00:42:27.443548 1 0 15000 +3124 1089 0 2019-11-17 00:35:08.158834 2019-11-17 00:35:31.651302 1 0 15000 +3123 1088 0 2019-11-16 09:58:21.238358 1 0 +3122 1087 0 2019-11-16 09:48:49.802246 1 0 +3121 1086 0 2019-11-16 08:09:32.630477 1 0 +3120 1085 0 2019-11-16 08:07:25.900267 1 0 +3119 1084 0 2019-11-16 07:36:49.025822 1 0 +3118 1083 0 2019-11-16 07:14:45.646823 2019-11-16 07:15:06.128626 1 0 15000 +3117 1082 0 2019-11-16 07:10:10.084536 2019-11-16 07:11:22.430978 1 0 15000 +3116 1081 0 2019-11-16 06:59:37.788187 2019-11-16 06:59:51.452592 1 0 15000 +3115 1080 0 2019-11-16 02:46:54.303861 1 0 +3114 1079 0 2019-11-16 02:23:54.748977 1 0 +3113 1078 0 2019-11-16 02:13:54.352742 1 0 +3112 1077 0 2019-11-16 01:56:09.484622 1 0 +3111 1076 0 2019-11-16 01:36:29.311694 1 0 +3110 1075 0 2019-11-16 01:34:45.999801 1 0 +3109 1074 0 2019-11-16 01:18:01.088034 1 0 +3108 1073 0 2019-11-16 01:13:00.762061 1 0 +3107 1072 0 2019-11-16 01:08:33.872257 2019-11-16 01:09:32.116189 1 0 15000 +3106 1071 0 2019-11-16 00:13:56.636779 2019-11-16 00:18:50.792031 1 0 15000 +3105 1070 0 2019-11-15 22:50:25.019524 2019-11-15 23:37:51.679436 1 0 15000 +3104 1069 0 2019-11-15 22:34:13.276303 2019-11-15 22:36:59.156604 1 0 15000 +3103 1068 0 2019-11-15 22:10:08.841297 2019-11-15 22:17:26.527186 0 0 15000 +3102 1067 0 2019-11-15 22:05:14.06287 2019-11-15 22:08:07.819029 0 0 15000 +3101 1066 0 2019-11-15 22:03:41.940633 0 0 +3100 1065 0 2019-11-15 21:11:05.030273 1 0 +3099 1064 0 2019-11-15 21:07:21.541364 1 0 +3098 1063 0 2019-11-15 20:49:56.747849 2019-11-15 20:58:35.289374 0 0 15000 +3097 1062 0 2019-11-15 20:47:13.823639 1 0 +3096 1061 0 2019-11-15 20:38:56.742854 1 0 +3095 1060 0 2019-11-15 20:27:51.131992 1 0 +3094 1059 0 2019-11-15 20:22:26.17163 1 0 +3093 1058 0 2019-11-15 20:17:06.727389 2019-11-15 20:20:22.044229 1 0 15000 +3092 1057 0 2019-11-15 20:13:08.244946 1 0 +3091 1056 0 2019-11-15 20:09:16.134601 2019-11-15 20:11:42.528747 0 0 15000 +3090 1055 0 2019-11-15 19:59:49.451983 0 0 +3089 1054 0 2019-11-15 19:54:39.812625 1 0 +3088 1053 0 2019-11-15 19:22:05.144733 1 0 +3087 1052 0 2019-11-15 19:20:02.019515 1 0 +3086 1051 0 2019-11-15 19:10:30.460882 2019-11-15 19:17:30.676543 1 0 15000 +3085 1050 0 2019-11-15 18:38:02.579866 1 0 +3084 1049 0 2019-11-15 18:34:42.516296 1 0 +3083 1048 0 2019-11-15 17:26:10.554633 2019-11-15 17:34:00.149448 1 0 15000 +3082 1047 1 2019-11-15 16:41:43.924338 2019-11-15 16:47:31.968532 1 0 15000 +3081 1047 0 2019-11-15 16:32:29.295861 2019-11-15 16:34:50.933302 1 0 15000 +3080 1046 0 2019-11-15 13:53:03.490721 2019-11-15 14:03:07.220258 1 0 15000 +3079 1045 0 2019-11-15 13:36:41.943645 2019-11-15 13:42:03.689511 1 0 15000 +3078 1044 0 2019-11-15 13:12:24.718674 2019-11-15 13:18:39.28527 1 0 15000 +3077 1043 0 2019-11-15 11:54:10.840572 2019-11-15 12:16:27.55607 1 0 15000 +3076 1042 0 2019-11-15 02:29:44.046767 0 0 +3075 1041 0 2019-11-15 01:38:54.467058 0 0 +3074 1040 1 2019-11-15 00:20:23.526948 2019-11-15 00:20:53.029455 0 0 15000 +3073 1040 0 2019-11-15 00:15:56.942685 2019-11-15 00:16:49.932326 0 0 15000 +3072 1039 2 2019-11-15 00:08:02.009335 2019-11-15 00:08:39.661615 0 0 15000 +3071 1039 1 2019-11-15 00:05:55.023663 2019-11-15 00:06:42.782936 0 0 15000 +3070 1039 0 2019-11-14 23:55:22.188478 2019-11-15 00:03:49.337775 0 0 15000 +3069 1038 0 2019-11-14 23:50:33.221491 2019-11-14 23:52:16.934369 0 0 15000 +3068 1037 0 2019-11-14 23:35:55.602283 2019-11-14 23:40:38.891849 0 0 15000 +3067 1036 0 2019-11-14 23:28:49.30128 2019-11-14 23:30:06.055183 0 0 15000 +3066 1035 0 2019-11-14 23:21:46.868693 0 0 +3065 1034 0 2019-11-14 23:14:56.681586 2019-11-14 23:17:27.588692 0 0 15000 +3064 1033 0 2019-11-14 22:48:57.032273 2019-11-14 22:51:47.896049 0 0 15000 +3063 1032 0 2019-11-14 22:46:03.331481 2019-11-14 22:47:31.479689 0 0 15000 +3062 1031 0 2019-11-14 22:36:23.882948 2019-11-14 22:39:09.619463 0 0 15000 +3061 1030 0 2019-11-14 22:24:43.731849 2019-11-14 22:34:26.341007 0 0 15000 +3060 1029 0 2019-11-14 22:11:39.070502 2019-11-14 22:21:36.860774 0 0 15000 +3059 1028 0 2019-11-14 18:42:31.783894 2019-11-14 18:44:59.718336 1 0 15000 +3058 1027 0 2019-11-14 17:14:31.797271 2019-11-14 17:17:10.854069 1 0 15000 +3057 1026 0 2019-11-14 16:57:53.375774 1 0 +3056 1025 0 2019-11-14 16:22:57.066963 1 0 +3055 1024 0 2019-11-14 16:08:06.506538 1 0 +3054 1023 0 2019-11-14 15:50:35.611926 2019-11-14 15:54:36.120249 1 0 15000 +3053 1022 0 2019-11-14 15:40:30.177696 1 0 +3052 1021 0 2019-11-14 06:57:15.783394 0 0 +3051 1020 0 2019-11-14 06:51:23.295658 0 0 +3050 1019 0 2019-11-13 23:20:39.430736 2019-11-13 23:21:50.812752 0 0 15000 +3049 1018 0 2019-11-13 23:17:19.994893 0 0 +3048 1017 0 2019-11-13 23:10:37.605718 0 0 +3047 1016 0 2019-11-13 23:08:01.340402 2019-11-13 23:08:31.907766 0 0 15000 +3046 1015 0 2019-11-13 22:41:34.865883 2019-11-13 22:42:14.590524 0 0 15000 +3045 1014 1 2019-11-13 19:35:25.377103 2019-11-13 19:36:39.702164 0 0 15000 +3044 1014 0 2019-11-13 19:32:00.597249 2019-11-13 19:32:55.123425 0 0 15000 +3043 1013 0 2019-11-13 17:53:18.743052 2019-11-13 17:55:40.041269 1 0 15000 +3042 1012 0 2019-11-13 17:47:36.068146 2019-11-13 17:50:14.091338 1 0 15000 +3041 1011 0 2019-11-13 17:37:01.426185 2019-11-13 17:42:05.734539 1 0 15000 +3040 1010 0 2019-11-13 09:45:56.8444 2019-11-13 10:10:41.180473 0 0 15000 +3039 1009 0 2019-11-13 08:44:28.314471 2019-11-13 09:03:01.861027 1 0 15000 +3038 1008 0 2019-11-13 08:39:19.533355 2019-11-13 08:41:30.356814 1 0 15000 +3037 1007 0 2019-11-13 08:33:39.509138 2019-11-13 08:36:47.200166 0 0 15000 +3036 1006 0 2019-11-13 08:24:55.37913 2019-11-13 08:28:56.655823 0 0 15000 +3035 1005 0 2019-11-13 08:17:48.072335 0 0 +3034 1004 0 2019-11-13 07:52:08.338275 0 0 +3033 1003 0 2019-11-13 00:51:06.324141 2019-11-13 01:00:21.83285 0 0 15000 +3032 1002 0 2019-11-13 00:04:45.909804 2019-11-13 00:23:27.057839 0 0 15000 +3031 1001 0 2019-11-12 23:51:17.287853 0 0 +3030 1000 0 2019-11-12 22:54:31.646148 0 0 +3029 999 0 2019-11-12 22:37:59.844608 0 0 +3028 998 0 2019-11-12 22:25:36.085283 0 0 +3027 997 0 2019-11-12 22:06:05.147873 0 0 +3026 996 0 2019-11-12 21:49:37.259684 0 0 +3025 995 0 2019-11-12 21:44:57.935587 2019-11-12 21:47:32.479966 0 0 15000 +3024 994 0 2019-11-12 11:52:30.349026 0 0 +3023 993 0 2019-11-12 11:44:52.22903 0 0 +3022 992 0 2019-11-12 11:34:05.738569 2019-11-12 11:37:37.745943 0 0 15000 +3021 991 0 2019-11-12 11:28:49.596042 2019-11-12 11:30:14.375666 0 0 15000 +3020 990 0 2019-11-12 11:24:15.465252 2019-11-12 11:26:05.511055 0 0 15000 +3019 989 0 2019-11-12 11:08:41.504488 2019-11-12 11:10:04.332926 0 0 15000 +3018 988 0 2019-11-12 10:55:33.606727 2019-11-12 10:58:41.16658 0 0 15000 +3017 987 0 2019-11-12 10:39:35.525112 2019-11-12 10:41:21.355708 0 0 15000 +3016 986 0 2019-11-12 10:36:41.560625 0 0 +3015 985 0 2019-11-12 10:27:58.506647 2019-11-12 10:30:21.732941 0 0 15000 +3014 984 0 2019-11-12 10:16:37.776667 2019-11-12 10:18:46.6581 0 0 15000 +3013 983 0 2019-11-12 10:07:45.693597 2019-11-12 10:09:46.596004 0 0 15000 +3012 982 0 2019-11-12 09:54:19.510808 0 0 +3011 981 0 2019-11-12 09:48:37.887257 0 0 +3010 980 0 2019-11-12 09:31:12.757282 0 0 +3009 979 0 2019-11-12 09:20:33.131161 0 0 +3008 978 0 2019-11-12 09:14:14.078152 0 0 +3007 977 0 2019-11-12 09:11:10.373719 0 0 +3006 976 0 2019-11-12 08:55:47.191542 0 0 +3005 975 0 2019-11-12 08:41:59.104109 0 0 +3004 974 0 2019-11-12 08:17:57.592095 0 0 +3003 973 0 2019-11-12 07:53:48.023017 0 0 +3002 972 0 2019-11-12 07:29:04.067015 2019-11-12 07:34:05.306834 0 0 15000 +3001 971 0 2019-11-12 07:17:45.822251 0 0 +3000 970 0 2019-11-12 07:07:41.490935 0 0 +2999 969 0 2019-11-12 06:55:33.005294 0 0 +2998 968 0 2019-11-12 04:23:01.138507 2019-11-12 04:39:22.972385 0 0 15000 +2997 967 0 2019-11-12 04:08:47.541326 2019-11-12 04:15:28.853056 1 0 15000 +2996 966 0 2019-11-12 02:22:00.028646 1 0 +2995 965 0 2019-11-12 02:06:33.46409 2019-11-12 02:13:19.215462 1 0 15000 +2994 964 0 2019-11-12 02:04:26.990449 1 0 +2993 963 0 2019-11-12 02:03:28.370992 1 0 +2992 962 0 2019-11-12 00:58:51.144952 2019-11-12 01:20:46.009843 1 0 15000 +2991 961 0 2019-11-11 22:42:22.032565 2019-11-11 23:04:13.75387 1 0 15000 +2990 960 0 2019-11-11 22:41:28.049824 1 0 +2989 959 0 2019-11-11 22:19:06.983304 1 0 +2988 958 0 2019-11-11 21:49:08.241492 2019-11-11 22:13:46.375843 1 0 15000 +2987 957 0 2019-11-11 21:15:58.330028 1 0 +2986 956 0 2019-11-11 20:49:04.066023 2019-11-11 21:01:35.492404 1 0 15000 +2985 955 0 2019-11-11 20:13:40.229104 2019-11-11 20:30:16.739632 1 0 15000 +2984 954 0 2019-11-11 20:05:13.209305 2019-11-11 20:09:54.116131 0 0 15000 +2983 953 0 2019-11-11 18:53:23.126425 2019-11-11 19:00:44.149349 1 0 2000 +2982 952 0 2019-11-11 18:43:06.589551 1 0 +2981 951 0 2019-11-11 18:05:38.16248 0 0 +2980 950 0 2019-11-11 13:43:54.252123 0 0 +2979 949 0 2019-11-11 10:24:17.702921 1 0 +2978 948 0 2019-11-10 20:04:37.053547 2019-11-10 20:06:50.969793 0 0 2000 +2977 947 0 2019-11-10 19:41:49.833997 2019-11-10 19:47:14.676948 0 0 15000 +2976 946 0 2019-11-10 19:20:26.266107 2019-11-10 19:24:09.490664 0 0 15000 +2975 945 0 2019-11-10 19:05:21.142657 2019-11-10 19:06:49.489498 0 0 4096 +2974 944 0 2019-11-10 09:45:07.201491 2019-11-10 09:53:42.901053 0 0 4096 +2973 943 0 2019-11-10 09:19:24.681915 0 0 +2972 942 0 2019-11-10 08:49:24.688519 2019-11-10 08:52:40.276613 0 0 4096 +2971 941 0 2019-11-10 07:08:32.321915 2019-11-10 07:11:23.61908 0 0 4096 +2970 940 0 2019-11-10 06:41:04.591715 2019-11-10 06:43:14.783675 0 0 4096 +2969 939 0 2019-09-06 08:22:28.214154 0 0 +2968 938 0 2019-09-06 01:44:12.877677 2019-09-06 01:45:15.439156 0 0 4096 +2967 937 0 2019-09-06 01:40:06.412427 0 0 +2966 936 0 2019-09-06 00:50:53.749619 0 0 +2965 935 0 2019-09-06 00:44:05.594192 0 0 +2964 934 0 2019-09-05 23:55:16.426188 0 0 +2963 933 0 2019-09-05 22:40:21.967819 0 0 +2962 932 0 2019-09-05 22:37:12.488016 0 0 +2961 931 0 2019-09-05 22:31:21.287963 2019-09-05 22:32:17.787401 0 0 4176 +2960 930 0 2019-09-05 11:23:18.894853 2019-09-05 11:23:31.677921 0 0 4176 +2959 929 0 2019-09-05 01:20:39.316016 2019-09-05 01:24:04.89804 0 0 4096 +2958 928 0 2019-09-05 00:39:30.528753 0 0 +2957 927 8 2018-07-08 13:06:15.041999 2018-07-08 23:43:19.927542 8 0 3821 +2956 927 7 2018-07-07 09:18:48.816891 2018-07-08 13:05:52.597055 8 0 10001 +2955 927 6 2018-07-06 03:16:10.392284 2018-07-07 09:18:26.569688 8 0 10001 +2954 927 5 2018-07-04 08:49:50.999525 2018-07-06 03:15:49.3786 8 0 10001 +2953 927 4 2018-07-03 10:07:53.689277 2018-07-04 08:49:28.935533 8 0 10001 +2952 927 3 2018-07-02 13:42:51.720234 2018-07-03 10:07:31.88763 8 0 10001 +2951 927 2 2018-07-01 15:00:52.380842 2018-07-02 13:42:29.569905 8 0 10001 +2950 927 1 2018-06-30 13:49:25.741058 2018-07-01 15:00:30.02254 8 0 10001 +2949 927 0 2018-06-29 14:25:54.581801 2018-06-30 13:49:04.827154 8 0 10001 +2948 926 0 2018-06-29 11:03:08.991996 2018-06-29 13:19:46.380072 8 0 1088 +2947 925 6 2018-06-29 08:32:36.328263 2018-06-29 10:58:07.846814 8 0 9705 +2946 925 5 2018-06-29 06:02:45.306782 2018-06-29 08:32:14.092439 8 0 10001 +2945 925 4 2018-06-29 03:37:18.182078 2018-06-29 06:02:24.916554 8 0 10001 +2944 925 3 2018-06-29 01:17:09.150032 2018-06-29 03:36:55.998298 8 0 10001 +2943 925 2 2018-06-28 22:56:30.01961 2018-06-29 01:16:47.467442 8 0 10001 +2942 925 1 2018-06-28 20:36:34.375581 2018-06-28 22:56:08.8969 8 0 10001 +2941 925 0 2018-06-28 18:16:16.932587 2018-06-28 20:36:12.365013 8 0 10001 +2940 924 63 2018-06-28 15:44:12.265561 2018-06-28 16:52:27.887939 8 0 4884 +2939 924 62 2018-06-28 13:24:07.449743 2018-06-28 15:43:50.741942 8 0 10001 +2938 924 61 2018-06-28 11:01:51.278623 2018-06-28 13:23:46.178614 8 0 10001 +2937 924 60 2018-06-28 08:35:56.230847 2018-06-28 11:01:29.596883 8 0 10001 +2936 924 59 2018-06-28 06:15:12.272485 2018-06-28 08:35:34.666642 8 0 10001 +2935 924 58 2018-06-28 03:54:30.022063 2018-06-28 06:14:50.081168 8 0 10001 +2934 924 57 2018-06-28 01:33:43.216725 2018-06-28 03:54:08.708199 8 0 10001 +2933 924 56 2018-06-27 23:12:59.885973 2018-06-28 01:33:19.856563 8 0 10001 +2932 924 55 2018-06-27 20:52:10.021529 2018-06-27 23:12:38.805725 8 0 10001 +2931 924 54 2018-06-27 18:30:39.882024 2018-06-27 20:51:47.373152 8 0 10001 +2930 924 53 2018-06-27 16:08:19.999473 2018-06-27 18:30:19.195546 8 0 10001 +2929 924 52 2018-06-27 13:47:38.15481 2018-06-27 16:07:58.013466 8 0 10001 +2928 924 51 2018-06-27 11:25:35.015401 2018-06-27 13:47:16.540407 8 0 10001 +2927 924 50 2018-06-27 09:03:49.961 2018-06-27 11:24:51.994275 8 0 10001 +2926 924 49 2018-06-27 06:42:54.905675 2018-06-27 09:03:13.157003 8 0 10001 +2925 924 48 2018-06-27 04:22:10.935665 2018-06-27 06:42:33.661941 8 0 10001 +2924 924 47 2018-06-27 02:00:51.811392 2018-06-27 04:21:47.582656 8 0 10001 +2923 924 46 2018-06-26 23:39:04.790217 2018-06-27 02:00:28.113459 8 0 10001 +2922 924 45 2018-06-26 21:18:28.731679 2018-06-26 23:38:43.327638 8 0 10001 +2921 924 44 2018-06-26 18:57:46.771767 2018-06-26 21:18:06.529363 8 0 10001 +2920 924 43 2018-06-26 16:30:45.761154 2018-06-26 18:57:23.277014 8 0 10001 +2919 924 42 2018-06-26 14:03:22.552177 2018-06-26 16:30:24.67606 8 0 10001 +2918 924 41 2018-06-26 11:42:02.803565 2018-06-26 14:03:01.926405 8 0 10001 +2917 924 40 2018-06-26 09:19:46.951755 2018-06-26 11:41:40.313012 8 0 10001 +2916 924 39 2018-06-26 06:58:57.201717 2018-06-26 09:19:25.226307 8 0 10001 +2915 924 38 2018-06-26 04:38:20.591744 2018-06-26 06:58:36.115904 8 0 10001 +2914 924 37 2018-06-26 02:17:40.611617 2018-06-26 04:37:57.858386 8 0 10001 +2913 924 36 2018-06-25 23:56:10.776145 2018-06-26 02:17:19.548959 8 0 10001 +2912 924 35 2018-06-25 21:34:59.302141 2018-06-25 23:55:49.936814 8 0 10001 +2911 924 34 2018-06-25 19:07:19.212092 2018-06-25 21:34:37.946832 8 0 10001 +2910 924 33 2018-06-25 16:43:19.723888 2018-06-25 19:06:56.29749 8 0 10001 +2909 924 32 2018-06-25 14:22:34.384007 2018-06-25 16:42:55.70779 8 0 10001 +2908 924 31 2018-06-25 12:01:42.07514 2018-06-25 14:22:13.296847 8 0 10001 +2907 924 30 2018-06-25 09:39:56.341194 2018-06-25 12:01:17.726257 8 0 10001 +2906 924 29 2018-06-25 07:18:45.405901 2018-06-25 09:39:34.746489 8 0 10001 +2905 924 28 2018-06-25 04:58:08.402164 2018-06-25 07:18:24.015665 8 0 10001 +2904 924 27 2018-06-25 02:37:28.221102 2018-06-25 04:57:46.836592 8 0 10001 +2903 924 26 2018-06-25 00:15:34.732254 2018-06-25 02:37:06.438217 8 0 10001 +2902 924 25 2018-06-24 21:51:52.221778 2018-06-25 00:15:12.33521 8 0 10001 +2901 924 24 2018-06-24 19:29:29.292012 2018-06-24 21:51:30.456731 8 0 10001 +2900 924 23 2018-06-24 17:07:30.20151 2018-06-24 19:29:08.026842 8 0 10001 +2899 924 22 2018-06-24 14:46:17.092325 2018-06-24 17:07:08.857465 8 0 10001 +2898 924 21 2018-06-24 12:25:31.151039 2018-06-24 14:45:55.313874 8 0 10001 +2897 924 20 2018-06-24 10:04:45.081624 2018-06-24 12:25:09.537941 8 0 10001 +2896 924 19 2018-06-24 07:44:02.00131 2018-06-24 10:04:23.763201 8 0 10001 +2895 924 18 2018-06-24 05:23:16.751605 2018-06-24 07:43:40.787196 8 0 10001 +2894 924 17 2018-06-24 03:02:39.904378 2018-06-24 05:22:54.927968 8 0 10001 +2893 924 16 2018-06-24 00:41:57.930989 2018-06-24 03:02:18.306004 8 0 10001 +2892 924 15 2018-06-23 22:21:22.723854 2018-06-24 00:41:36.396737 8 0 10001 +2891 924 14 2018-06-23 20:00:45.701651 2018-06-23 22:21:00.770294 8 0 10001 +2890 924 13 2018-06-23 17:38:30.732268 2018-06-23 20:00:22.247594 8 0 10001 +2889 924 12 2018-06-23 15:15:36.331533 2018-06-23 17:38:10.804092 8 0 10001 +2888 924 11 2018-06-23 12:54:40.70451 2018-06-23 15:15:15.812444 8 0 10001 +2887 924 10 2018-06-23 10:34:01.640165 2018-06-23 12:54:19.748048 8 0 10001 +2886 924 9 2018-06-23 08:13:23.501709 2018-06-23 10:33:40.88651 8 0 10001 +2885 924 8 2018-06-23 05:52:40.872041 2018-06-23 08:13:03.162738 8 0 10001 +2884 924 7 2018-06-23 03:32:03.492221 2018-06-23 05:52:19.212159 8 0 10001 +2883 924 6 2018-06-23 01:11:14.501378 2018-06-23 03:31:41.556457 8 0 10001 +2882 924 5 2018-06-22 22:50:19.390595 2018-06-23 01:10:53.912166 8 0 10001 +2881 924 4 2018-06-22 20:28:17.462292 2018-06-22 22:49:58.644243 8 0 10001 +2880 924 3 2018-06-22 18:06:14.342532 2018-06-22 20:27:55.557187 8 0 10001 +2879 924 2 2018-06-22 15:43:50.446045 2018-06-22 18:05:52.486857 8 0 10001 +2878 924 1 2018-06-22 13:14:34.745806 2018-06-22 15:43:28.677014 8 0 10001 +2877 924 0 2018-06-22 12:18:58.731315 2018-06-22 12:51:54.197341 8 0 2332 +2876 923 0 2018-06-22 12:09:56.547412 2018-06-22 12:17:33.245819 8 0 518 +2875 922 18 2018-06-22 09:21:34.931214 2018-06-22 11:10:06.900856 8 0 7728 +2874 922 17 2018-06-22 07:00:51.795815 2018-06-22 09:21:14.1671 8 0 10001 +2873 922 16 2018-06-22 04:33:28.268763 2018-06-22 07:00:27.742834 8 0 10001 +2872 922 15 2018-06-22 02:12:49.669022 2018-06-22 04:33:06.556871 8 0 10001 +2871 922 14 2018-06-21 23:51:59.585185 2018-06-22 02:12:25.618034 8 0 10001 +2870 922 13 2018-06-21 21:32:04.574783 2018-06-21 23:51:37.639635 8 0 10001 +2869 922 12 2018-06-21 19:11:16.535832 2018-06-21 21:31:42.927761 8 0 10001 +2868 922 11 2018-06-21 16:50:13.528353 2018-06-21 19:10:54.238092 8 0 10001 +2867 922 10 2018-06-21 14:29:46.611843 2018-06-21 16:49:51.926805 8 0 10001 +2866 922 9 2018-06-21 12:08:02.67251 2018-06-21 14:29:23.737414 8 0 10001 +2865 922 8 2018-06-21 09:47:11.212707 2018-06-21 12:07:41.526878 8 0 10001 +2864 922 7 2018-06-21 07:24:51.268796 2018-06-21 09:46:48.96874 8 0 10001 +2863 922 6 2018-06-21 05:04:10.079994 2018-06-21 07:24:30.968706 8 0 10001 +2862 922 5 2018-06-21 02:43:28.072791 2018-06-21 05:03:48.60783 8 0 10001 +2861 922 4 2018-06-21 00:22:52.112383 2018-06-21 02:43:07.823748 8 0 10001 +2860 922 3 2018-06-20 22:02:14.972738 2018-06-21 00:22:31.617089 8 0 10001 +2859 922 2 2018-06-20 19:41:31.912478 2018-06-20 22:01:53.8157 8 0 10001 +2858 922 1 2018-06-20 17:20:44.841186 2018-06-20 19:41:10.207897 8 0 10001 +2857 922 0 2018-06-20 14:59:42.091038 2018-06-20 17:20:23.515515 8 0 10001 +2856 921 0 2018-06-20 09:48:55.231303 2018-06-20 09:55:53.148054 0 0 395 +2855 920 0 2018-06-20 09:47:37.022046 0 0 +2854 919 0 2018-06-20 09:37:37.553101 2018-06-20 09:48:01.147571 0 0 591 +2853 918 0 2018-06-20 09:30:20.988479 2018-06-20 09:31:31.637695 0 0 54 +2852 917 0 2018-06-20 09:30:07.782581 0 0 +2851 916 0 2018-06-20 09:26:13.342025 0 0 +2850 915 0 2018-06-20 09:16:57.022269 2018-06-20 09:17:47.131561 0 0 28 +2849 914 0 2018-06-20 09:13:05.253177 2018-06-20 09:14:29.217563 0 0 40 +2848 913 0 2018-06-20 09:11:07.05206 0 0 +2847 912 0 2018-06-20 09:05:25.051706 0 0 +2846 911 0 2018-06-20 09:03:50.5323 2018-06-20 09:04:27.577762 0 0 1 +2845 910 0 2018-06-19 23:26:32.195656 2018-06-19 23:27:17.707745 0 0 3 +2844 909 0 2018-06-19 23:01:17.842414 2018-06-19 23:02:51.267391 0 0 7 +2843 908 0 2018-06-19 22:56:07.991726 2018-06-19 22:57:41.577389 0 0 7 +2842 907 0 2018-06-19 22:46:39.222586 0 0 +2841 906 0 2018-06-19 22:44:25.131516 2018-06-19 22:44:50.856966 0 0 1 +2840 905 0 2018-06-19 22:42:44.12184 2018-06-19 22:43:46.817277 0 0 3 +2839 904 0 2018-06-19 22:34:44.19157 2018-06-19 22:36:02.807097 0 0 1 +2838 903 12 2018-06-19 21:09:12.870823 2018-06-19 22:30:15.941356 3 0 5694 +2837 903 11 2018-06-19 18:45:58.783882 2018-06-19 21:08:49.046876 3 0 10001 +2836 903 10 2018-06-19 16:22:13.633983 2018-06-19 18:45:35.51721 3 0 10001 +2835 903 9 2018-06-19 13:58:54.68303 2018-06-19 16:21:52.607406 3 0 10001 +2834 903 8 2018-06-19 11:35:34.026666 2018-06-19 13:58:32.906338 3 0 10001 +2833 903 7 2018-06-19 09:13:06.239662 2018-06-19 11:35:12.584824 3 0 10001 +2832 903 6 2018-06-19 06:51:28.617701 2018-06-19 09:12:43.826676 3 0 10001 +2831 903 5 2018-06-19 04:29:44.580754 2018-06-19 06:51:05.181621 3 0 10001 +2830 903 4 2018-06-19 02:08:19.385567 2018-06-19 04:29:23.246198 3 0 10001 +2829 903 3 2018-06-18 23:47:14.431717 2018-06-19 02:07:57.616777 3 0 10001 +2828 903 2 2018-06-18 21:18:50.529083 2018-06-18 23:46:52.049642 3 0 10001 +2827 903 1 2018-06-18 18:48:24.39962 2018-06-18 21:18:28.907046 3 0 10001 +2826 903 0 2018-06-18 16:20:54.640863 2018-06-18 18:48:00.837274 3 0 10001 +2825 902 42 2018-06-18 15:31:44.600017 2018-06-18 16:17:27.835984 8 0 3176 +2824 902 41 2018-06-18 12:45:55.519048 2018-06-18 15:31:23.396079 8 0 10001 +2823 902 40 2018-06-18 10:22:22.184041 2018-06-18 12:45:34.743466 8 0 10001 +2822 902 39 2018-06-18 07:51:53.331808 2018-06-18 10:21:59.174589 8 0 10001 +2821 902 38 2018-06-18 05:19:56.480073 2018-06-18 07:51:31.48189 8 0 10001 +2820 902 37 2018-06-18 02:59:11.330673 2018-06-18 05:19:35.708456 8 0 10001 +2819 902 36 2018-06-18 00:38:27.183524 2018-06-18 02:58:50.179477 8 0 10001 +2818 902 35 2018-06-17 22:11:02.391153 2018-06-18 00:38:04.686771 8 0 10001 +2817 902 34 2018-06-17 19:45:05.108466 2018-06-17 22:10:40.146895 8 0 10001 +2816 902 33 2018-06-17 17:24:20.730843 2018-06-17 19:44:43.641259 8 0 10001 +2815 902 32 2018-06-17 15:03:41.488875 2018-06-17 17:23:58.294765 8 0 10001 +2814 902 31 2018-06-17 12:42:57.802944 2018-06-17 15:03:20.616933 8 0 10001 +2813 902 30 2018-06-17 10:22:13.270766 2018-06-17 12:42:36.13651 8 0 10001 +2812 902 29 2018-06-17 08:01:28.085112 2018-06-17 10:21:51.317557 8 0 10001 +2811 902 28 2018-06-17 05:40:49.11357 2018-06-17 08:01:05.965113 8 0 10001 +2810 902 27 2018-06-17 03:20:10.040986 2018-06-17 05:40:25.798783 8 0 10001 +2809 902 26 2018-06-17 00:59:26.000662 2018-06-17 03:19:48.266733 8 0 10001 +2808 902 25 2018-06-16 22:36:20.893833 2018-06-17 00:59:02.868605 8 0 10001 +2807 902 24 2018-06-16 20:15:34.609595 2018-06-16 22:35:58.497006 8 0 10001 +2806 902 23 2018-06-16 17:54:48.819974 2018-06-16 20:15:11.370306 8 0 10001 +2805 902 22 2018-06-16 15:34:01.965075 2018-06-16 17:54:24.891411 8 0 10001 +2804 902 21 2018-06-16 13:13:17.400911 2018-06-16 15:33:39.877647 8 0 10001 +2803 902 20 2018-06-16 10:52:33.056989 2018-06-16 13:12:55.245965 8 0 10001 +2802 902 19 2018-06-16 08:31:46.809108 2018-06-16 10:52:11.443678 8 0 10001 +2801 902 18 2018-06-16 06:11:09.076551 2018-06-16 08:31:25.656182 8 0 10001 +2800 902 17 2018-06-16 03:50:25.739806 2018-06-16 06:10:48.698427 8 0 10001 +2799 902 16 2018-06-16 01:29:40.782967 2018-06-16 03:50:04.50708 8 0 10001 +2798 902 15 2018-06-15 23:08:53.842507 2018-06-16 01:29:18.496385 8 0 10001 +2797 902 14 2018-06-15 20:49:12.861137 2018-06-15 23:08:31.671009 8 0 10001 +2796 902 13 2018-06-15 18:29:40.83564 2018-06-15 20:48:50.786381 8 0 10001 +2795 902 12 2018-06-15 16:04:55.760728 2018-06-15 18:29:18.799688 8 0 10001 +2794 902 11 2018-06-15 13:41:06.419765 2018-06-15 16:04:33.164628 8 0 10001 +2793 902 10 2018-06-15 11:18:40.651042 2018-06-15 13:40:45.10453 8 0 10001 +2792 902 9 2018-06-15 08:54:40.179874 2018-06-15 11:18:19.336607 8 0 10001 +2791 902 8 2018-06-15 06:33:07.516568 2018-06-15 08:54:17.668225 8 0 10001 +2790 902 7 2018-06-15 04:09:55.520901 2018-06-15 06:32:45.687565 8 0 10001 +2789 902 6 2018-06-15 01:48:42.13289 2018-06-15 04:09:31.19559 8 0 10001 +2788 902 5 2018-06-14 23:23:53.499216 2018-06-15 01:48:20.266584 8 0 10001 +2787 902 4 2018-06-14 21:00:12.050975 2018-06-14 23:23:29.055714 8 0 10001 +2786 902 3 2018-06-14 18:33:48.397535 2018-06-14 20:59:50.169126 8 0 10001 +2785 902 2 2018-06-14 16:04:09.342683 2018-06-14 18:33:27.663185 8 0 10001 +2784 902 1 2018-06-14 13:26:00.381409 2018-06-14 16:03:49.455745 8 0 10001 +2783 902 0 2018-06-14 10:57:10.590225 2018-06-14 13:25:38.595698 8 0 10001 +2782 901 0 2018-06-13 16:42:35.220655 2018-06-14 10:26:09.906219 8 0 6884 +2781 900 4 2018-06-12 19:12:36.8087 2018-06-13 16:38:08.227193 8 0 8049 +2780 900 3 2018-06-11 18:03:06.701926 2018-06-12 19:12:15.249625 8 0 10001 +2779 900 2 2018-06-11 03:00:35.660233 2018-06-11 12:03:15.695579 8 0 3615 +2778 900 1 2018-06-09 21:57:30.25065 2018-06-11 03:00:13.436833 8 0 10001 +2777 900 0 2018-06-08 15:26:41.95054 2018-06-09 21:57:09.066943 8 0 10001 +2776 899 0 2018-06-08 13:02:54.999335 2018-06-08 13:16:49.916787 0 0 67 +2775 898 7 2017-10-04 06:38:28.471798 2017-10-04 13:19:11.973548 7 0 4923 +2774 898 6 2017-10-04 03:50:45.384601 2017-10-04 06:38:03.115944 7 0 10001 +2773 898 5 2017-10-04 01:02:30.254289 2017-10-04 03:50:22.105171 7 0 10001 +2772 898 4 2017-10-03 22:13:49.251632 2017-10-04 01:02:08.93733 7 0 10001 +2771 898 3 2017-10-03 19:24:09.374822 2017-10-03 22:13:26.652019 7 0 10001 +2770 898 2 2017-10-03 16:33:17.273788 2017-10-03 19:23:48.483317 7 0 10001 +2769 898 1 2017-10-03 13:39:01.234083 2017-10-03 16:32:55.296897 7 0 10001 +2768 898 0 2017-10-03 10:53:49.574351 2017-10-03 13:38:39.775711 7 0 10001 +2767 897 5 2017-10-03 10:19:46.27497 2017-10-03 10:46:43.526703 6 0 1495 +2766 897 4 2017-10-03 07:15:43.101173 2017-10-03 10:19:23.166033 6 0 10001 +2765 897 3 2017-10-03 04:06:53.132574 2017-10-03 07:15:20.867554 6 0 10001 +2764 897 2 2017-10-03 00:58:03.350901 2017-10-03 04:06:31.334818 6 0 10001 +2763 897 1 2017-10-02 21:49:29.317049 2017-10-03 00:57:41.52596 6 0 10001 +2762 897 0 2017-10-02 18:40:57.390826 2017-10-02 21:49:05.969212 6 0 10001 +2761 896 40 2017-10-02 18:37:21.122656 2017-10-02 18:38:23.631835 5 0 56 +2760 896 39 2017-10-02 16:46:00.086335 2017-10-02 18:37:00.246813 5 0 10001 +2759 896 38 2017-10-02 14:54:34.042313 2017-10-02 16:45:36.891772 5 0 10001 +2758 896 37 2017-10-02 13:03:04.085996 2017-10-02 14:54:10.391935 5 0 10001 +2757 896 36 2017-10-02 11:11:40.155244 2017-10-02 13:02:40.398273 5 0 10001 +2756 896 35 2017-10-02 09:20:18.989936 2017-10-02 11:11:18.423485 5 0 10001 +2755 896 34 2017-10-02 07:29:01.053058 2017-10-02 09:19:57.211303 5 0 10001 +2754 896 33 2017-10-02 05:37:37.458344 2017-10-02 07:28:35.723919 5 0 10001 +2753 896 32 2017-10-02 03:46:18.013542 2017-10-02 05:37:15.615166 5 0 10001 +2752 896 31 2017-10-02 01:54:55.015468 2017-10-02 03:45:56.245846 5 0 10001 +2751 896 30 2017-10-02 00:03:20.938831 2017-10-02 01:54:32.185709 5 0 10001 +2750 896 29 2017-10-01 22:11:56.029733 2017-10-02 00:02:58.357523 5 0 10001 +2749 896 28 2017-10-01 20:20:35.833567 2017-10-01 22:11:34.175973 5 0 10001 +2748 896 27 2017-10-01 18:29:15.960673 2017-10-01 20:20:09.984126 5 0 10001 +2747 896 26 2017-10-01 16:37:54.909996 2017-10-01 18:28:52.696092 5 0 10001 +2746 896 25 2017-10-01 14:46:35.949857 2017-10-01 16:37:32.105242 5 0 10001 +2745 896 24 2017-10-01 12:55:05.140202 2017-10-01 14:46:10.15704 5 0 10001 +2744 896 23 2017-10-01 11:03:43.849705 2017-10-01 12:54:39.238688 5 0 10001 +2743 896 22 2017-10-01 09:12:24.691688 2017-10-01 11:03:21.294562 5 0 10001 +2742 896 21 2017-10-01 07:20:49.77945 2017-10-01 09:12:03.746512 5 0 10001 +2741 896 20 2017-10-01 05:29:25.764807 2017-10-01 07:20:27.714515 5 0 10001 +2740 896 19 2017-10-01 03:38:08.623723 2017-10-01 05:29:04.030809 5 0 10001 +2739 896 18 2017-10-01 01:46:41.76186 2017-10-01 03:37:42.325984 5 0 10001 +2738 896 17 2017-09-30 23:55:13.6764 2017-10-01 01:46:19.594341 5 0 10001 +2737 896 16 2017-09-30 22:03:57.623421 2017-09-30 23:54:51.74566 5 0 10001 +2736 896 15 2017-09-30 20:12:32.581048 2017-09-30 22:03:32.352718 5 0 10001 +2735 896 14 2017-09-30 18:21:21.741072 2017-09-30 20:12:05.635582 5 0 10001 +2734 896 13 2017-09-30 16:30:01.611214 2017-09-30 18:20:58.774988 5 0 10001 +2733 896 12 2017-09-30 14:38:38.608857 2017-09-30 16:29:40.305905 5 0 10001 +2732 896 11 2017-09-30 12:47:24.744959 2017-09-30 14:38:15.616791 5 0 10001 +2731 896 10 2017-09-30 10:56:08.749037 2017-09-30 12:46:59.55689 5 0 10001 +2730 896 9 2017-09-30 09:04:59.502497 2017-09-30 10:55:46.319678 5 0 10001 +2729 896 8 2017-09-30 07:13:25.080723 2017-09-30 09:04:37.67886 5 0 10001 +2728 896 7 2017-09-30 05:21:59.4996 2017-09-30 07:13:02.24613 5 0 10001 +2727 896 6 2017-09-30 03:30:35.610958 2017-09-30 05:21:38.336799 5 0 10001 +2726 896 5 2017-09-30 01:39:11.659523 2017-09-30 03:30:14.356314 5 0 10001 +2725 896 4 2017-09-29 23:47:42.371024 2017-09-30 01:38:49.374668 5 0 10001 +2724 896 3 2017-09-29 21:56:28.351101 2017-09-29 23:47:20.521869 5 0 10001 +2723 896 2 2017-09-29 20:04:53.48536 2017-09-29 21:56:05.806271 5 0 10001 +2722 896 1 2017-09-29 18:13:33.570018 2017-09-29 20:04:32.404371 5 0 10001 +2721 896 0 2017-09-29 16:22:16.410549 2017-09-29 18:13:12.065597 5 0 10001 +2720 895 8 2017-09-29 15:14:02.992131 2017-09-29 16:10:55.69903 5 0 3937 +2719 895 7 2017-09-29 12:49:33.470971 2017-09-29 15:13:40.666667 5 0 10001 +2718 895 6 2017-09-29 10:25:00.433471 2017-09-29 12:49:11.635912 5 0 10001 +2717 895 5 2017-09-29 08:00:31.360839 2017-09-29 10:24:32.985732 5 0 10001 +2716 895 4 2017-09-29 05:36:03.431192 2017-09-29 08:00:06.946944 5 0 10001 +2715 895 3 2017-09-29 03:11:26.47253 2017-09-29 05:35:40.837099 5 0 10001 +2714 895 2 2017-09-29 00:46:51.266047 2017-09-29 03:11:00.635943 5 0 10001 +2713 895 1 2017-09-28 22:22:09.113902 2017-09-29 00:46:29.629432 5 0 10001 +2712 895 0 2017-09-28 19:57:26.970359 2017-09-28 22:21:44.906773 5 0 10001 +2711 894 0 2017-09-28 14:18:48.950677 2017-09-28 19:55:31.176394 7 0 3858 +2710 893 0 2017-09-28 00:40:27.991577 2017-09-28 14:15:52.266283 6 0 2427 +2709 892 0 2017-09-26 23:37:11.870312 2017-09-27 07:59:34.22697 7 0 4745 +2708 891 0 2017-09-25 23:21:22.700223 2017-09-26 07:11:45.69696 6 0 5045 +2707 890 0 2017-09-25 19:33:43.100091 2017-09-25 23:19:10.052143 7 0 2056 +2706 889 0 2017-09-25 16:42:45.080729 2017-09-25 19:30:43.905932 5 0 9947 +2705 888 0 2017-09-25 16:23:13.951143 5 0 +2704 887 0 2017-09-25 16:15:12.420754 5 0 +2703 886 0 2017-09-18 14:37:26.679292 2017-09-18 14:59:36.53127 7 0 1187 +2702 885 0 2017-09-18 12:48:02.798128 2017-09-18 14:26:05.793526 7 0 5209 +2701 884 0 2017-09-18 11:26:15.17647 2017-09-18 12:35:42.612929 7 0 3468 +2700 883 0 2017-09-18 10:02:02.264396 2017-09-18 11:10:45.05382 7 0 3755 +2699 882 1 2017-09-16 22:31:36.056177 2017-09-18 05:29:53.105667 6 0 5532 +2698 882 0 2017-09-14 14:32:22.575328 2017-09-16 22:31:12.867709 6 0 10001 +2697 881 0 2017-09-11 16:33:17.522801 2017-09-13 17:42:04.325111 6 0 9016 +2696 880 0 2017-09-11 13:45:23.428796 6 0 +2695 879 0 2017-09-11 13:40:43.979234 6 0 +2694 878 0 2017-09-11 13:30:27.618506 6 0 +2693 877 0 2017-09-11 13:17:43.010454 6 0 +2692 876 0 2017-09-11 12:24:16.220102 6 0 +2691 875 0 2017-09-11 12:12:57.720264 6 0 +2690 874 1 2017-09-10 19:16:12.519167 2017-09-11 05:02:16.976082 6 0 1789 +2689 874 0 2017-09-08 12:40:14.899281 2017-09-10 19:15:48.374552 6 0 10001 +2688 873 0 2017-09-07 09:43:35.339623 2017-09-08 12:06:28.846936 6 0 6397 +2687 872 0 2017-09-06 22:51:27.651965 2017-09-07 09:24:14.704943 6 0 2033 +2686 871 2 2017-09-06 04:30:49.257367 2017-09-06 22:45:02.016529 6 0 3345 +2685 871 1 2017-09-03 21:57:26.537649 2017-09-06 04:30:22.456579 6 0 10001 +2684 871 0 2017-09-01 15:26:28.910695 2017-09-03 21:57:02.125445 6 0 10001 +2683 870 2 2017-08-31 12:35:05.936936 2017-08-31 13:56:14.82933 5 0 7297 +2682 870 1 2017-08-31 10:43:37.002982 2017-08-31 12:34:38.877911 5 0 10001 +2681 870 0 2017-08-31 08:52:17.511602 2017-08-31 10:43:13.117948 5 0 10001 +2680 869 0 2017-08-30 14:13:54.23334 2017-08-31 08:41:27.760833 6 0 3383 +2679 868 2 2017-08-30 12:24:21.473546 2017-08-30 14:00:17.469487 5 0 8655 +2678 868 1 2017-08-30 10:33:08.483121 2017-08-30 12:23:58.858018 5 0 10001 +2677 868 0 2017-08-30 08:41:54.128865 2017-08-30 10:32:45.569226 5 0 10001 +2676 867 0 2017-08-29 14:24:09.889434 2017-08-30 08:13:45.699748 6 0 3266 +2675 866 2 2017-08-29 12:41:10.115883 2017-08-29 14:09:40.882532 5 0 7968 +2674 866 1 2017-08-29 10:49:46.199307 2017-08-29 12:40:42.989876 5 0 10001 +2673 866 0 2017-08-29 08:58:37.792906 2017-08-29 10:49:22.722999 5 0 10001 +2672 865 0 2017-08-28 14:44:25.823573 2017-08-29 08:37:01.20039 6 0 3278 +2671 864 1 2017-08-28 12:53:09.87172 2017-08-28 14:28:27.828561 5 0 8597 +2670 864 0 2017-08-28 11:01:47.377329 2017-08-28 12:52:46.380099 5 0 10001 +2669 863 4 2017-08-27 11:02:28.200326 2017-08-28 10:35:03.590514 6 0 4316 +2668 863 3 2017-08-25 04:28:10.500451 2017-08-27 11:02:04.038684 6 0 10001 +2667 863 2 2017-08-22 21:55:07.566025 2017-08-25 04:27:47.18336 6 0 10001 +2666 863 1 2017-08-20 20:13:03.437113 2017-08-22 21:54:45.271109 6 0 10001 +2665 863 0 2017-08-18 13:41:35.975189 2017-08-20 20:12:40.779422 6 0 10001 +2664 862 2 2017-08-18 12:53:05.285777 2017-08-18 13:11:23.388265 5 0 1605 +2663 862 1 2017-08-18 11:01:19.453842 2017-08-18 12:52:44.408991 5 0 10001 +2662 862 0 2017-08-18 09:09:32.98943 2017-08-18 11:00:56.759018 5 0 10001 +2661 861 9 2017-08-18 07:32:13.292833 2017-08-18 08:44:13.835646 2 0 6439 +2660 861 8 2017-08-18 05:40:29.125551 2017-08-18 07:31:51.776661 2 0 10001 +2659 861 7 2017-08-18 03:48:25.274253 2017-08-18 05:40:03.298939 2 0 10001 +2658 861 6 2017-08-18 01:56:05.093814 2017-08-18 03:48:02.82737 2 0 10001 +2657 861 5 2017-08-18 00:04:03.163487 2017-08-18 01:55:42.977824 2 0 10001 +2656 861 4 2017-08-17 22:12:15.012465 2017-08-18 00:03:41.086755 2 0 10001 +2655 861 3 2017-08-17 20:20:22.151937 2017-08-17 22:11:50.009045 2 0 10001 +2654 861 2 2017-08-17 18:28:28.292378 2017-08-17 20:19:59.099828 2 0 10001 +2653 861 1 2017-08-17 16:36:30.142043 2017-08-17 18:28:06.63 2 0 10001 +2652 861 0 2017-08-17 14:44:30.269483 2017-08-17 16:36:08.160674 2 0 10001 +2651 860 3 2017-08-17 14:13:57.052504 2017-08-17 14:27:53.500008 5 0 1216 +2650 860 2 2017-08-17 12:22:13.863774 2017-08-17 14:13:33.778983 5 0 10001 +2649 860 1 2017-08-17 10:30:34.062738 2017-08-17 12:21:49.187615 5 0 10001 +2648 860 0 2017-08-17 08:38:59.375496 2017-08-17 10:30:11.120007 5 0 10001 +2647 859 9 2017-08-17 07:47:01.791245 2017-08-17 08:11:54.617035 2 0 2189 +2646 859 8 2017-08-17 05:55:03.978373 2017-08-17 07:46:38.234988 2 0 10001 +2645 859 7 2017-08-17 04:02:53.829725 2017-08-17 05:54:40.930434 2 0 10001 +2644 859 6 2017-08-17 02:11:07.806791 2017-08-17 04:02:33.728827 2 0 10001 +2643 859 5 2017-08-17 00:19:12.754219 2017-08-17 02:10:42.717624 2 0 10001 +2642 859 4 2017-08-16 22:26:54.004773 2017-08-17 00:18:46.462995 2 0 10001 +2641 859 3 2017-08-16 20:35:01.853945 2017-08-16 22:26:29.922285 2 0 10001 +2640 859 2 2017-08-16 18:42:57.554028 2017-08-16 20:34:38.309769 2 0 10001 +2639 859 1 2017-08-16 16:51:07.889746 2017-08-16 18:42:35.939571 2 0 10001 +2638 859 0 2017-08-16 14:58:56.540481 2017-08-16 16:50:43.598607 2 0 10001 +2637 858 2 2017-08-16 12:47:57.514237 2017-08-16 14:12:22.968777 5 0 7594 +2636 858 1 2017-08-16 10:56:17.107986 2017-08-16 12:47:36.490099 5 0 10001 +2635 858 0 2017-08-16 09:04:22.586783 2017-08-16 10:55:54.977163 5 0 10001 +2634 857 21 2017-08-16 07:09:14.687975 2017-08-16 08:44:21.780496 2 0 8514 +2633 857 20 2017-08-16 05:17:10.640506 2017-08-16 07:08:52.041003 2 0 10001 +2632 857 19 2017-08-16 03:25:21.700507 2017-08-16 05:16:47.920352 2 0 10001 +2631 857 18 2017-08-16 01:33:24.643993 2017-08-16 03:24:59.759703 2 0 10001 +2630 857 17 2017-08-15 23:41:35.467591 2017-08-16 01:33:03.279181 2 0 10001 +2629 857 16 2017-08-15 21:49:52.509231 2017-08-15 23:41:12.958065 2 0 10001 +2628 857 15 2017-08-15 19:57:52.605101 2017-08-15 21:49:30.556108 2 0 10001 +2627 857 14 2017-08-15 18:05:54.352671 2017-08-15 19:57:28.141417 2 0 10001 +2626 857 13 2017-08-15 16:13:56.322237 2017-08-15 18:05:32.109027 2 0 10001 +2625 857 12 2017-08-15 14:22:05.508721 2017-08-15 16:13:32.814204 2 0 10001 +2624 857 11 2017-08-15 12:30:09.25433 2017-08-15 14:21:45.091845 2 0 10001 +2623 857 10 2017-08-15 10:37:14.287004 2017-08-15 12:29:44.269044 2 0 10001 +2622 857 9 2017-08-15 08:45:10.161507 2017-08-15 10:36:51.429767 2 0 10001 +2621 857 8 2017-08-15 06:53:24.143849 2017-08-15 08:44:46.636483 2 0 10001 +2620 857 7 2017-08-15 05:01:24.308195 2017-08-15 06:53:00.83188 2 0 10001 +2619 857 6 2017-08-15 03:09:37.064501 2017-08-15 05:00:59.707129 2 0 10001 +2618 857 5 2017-08-15 01:17:57.093789 2017-08-15 03:09:15.108195 2 0 10001 +2617 857 4 2017-08-14 23:26:07.144186 2017-08-15 01:17:32.511338 2 0 10001 +2616 857 3 2017-08-14 21:34:16.355102 2017-08-14 23:25:43.231858 2 0 10001 +2615 857 2 2017-08-14 19:42:31.136824 2017-08-14 21:33:50.818034 2 0 10001 +2614 857 1 2017-08-14 17:50:43.139438 2017-08-14 19:42:10.169448 2 0 10001 +2613 857 0 2017-08-14 15:58:36.143944 2017-08-14 17:50:21.554926 2 0 10001 +2612 856 39 2017-08-14 15:23:07.017913 2017-08-14 15:55:52.853727 2 0 2925 +2611 856 38 2017-08-14 13:31:22.101827 2017-08-14 15:22:45.576349 2 0 10001 +2610 856 37 2017-08-14 11:39:43.865131 2017-08-14 13:31:00.128487 2 0 10001 +2609 856 36 2017-08-14 09:47:58.933413 2017-08-14 11:39:18.941717 2 0 10001 +2608 856 35 2017-08-14 07:56:01.852991 2017-08-14 09:47:34.706629 2 0 10001 +2607 856 34 2017-08-14 06:04:19.955919 2017-08-14 07:55:40.940365 2 0 10001 +2606 856 33 2017-08-14 04:12:30.972487 2017-08-14 06:03:58.308405 2 0 10001 +2605 856 32 2017-08-14 02:20:47.816845 2017-08-14 04:12:05.000171 2 0 10001 +2604 856 31 2017-08-14 00:29:01.902928 2017-08-14 02:20:25.695559 2 0 10001 +2603 856 30 2017-08-13 22:37:11.788562 2017-08-14 00:28:36.026019 2 0 10001 +2602 856 29 2017-08-13 20:45:33.897321 2017-08-13 22:36:49.537779 2 0 10001 +2601 856 28 2017-08-13 18:53:36.682526 2017-08-13 20:45:10.969453 2 0 10001 +2600 856 27 2017-08-13 17:01:46.772325 2017-08-13 18:53:09.18923 2 0 10001 +2599 856 26 2017-08-13 15:10:05.615926 2017-08-13 17:01:22.900252 2 0 10001 +2598 856 25 2017-08-13 13:18:27.582078 2017-08-13 15:09:40.976567 2 0 10001 +2597 856 24 2017-08-13 11:26:40.59109 2017-08-13 13:18:05.911607 2 0 10001 +2596 856 23 2017-08-13 09:34:41.419476 2017-08-13 11:26:15.289405 2 0 10001 +2595 856 22 2017-08-13 07:43:02.482179 2017-08-13 09:34:19.518474 2 0 10001 +2594 856 21 2017-08-13 05:51:10.565884 2017-08-13 07:42:39.795344 2 0 10001 +2593 856 20 2017-08-13 03:59:23.502781 2017-08-13 05:50:48.572235 2 0 10001 +2592 856 19 2017-08-13 02:07:45.662656 2017-08-13 03:58:55.874843 2 0 10001 +2591 856 18 2017-08-13 00:16:06.413373 2017-08-13 02:07:21.719526 2 0 10001 +2590 856 17 2017-08-12 22:24:31.493704 2017-08-13 00:15:42.551369 2 0 10001 +2589 856 16 2017-08-12 20:32:39.523581 2017-08-12 22:24:08.396503 2 0 10001 +2588 856 15 2017-08-12 18:41:02.373023 2017-08-12 20:32:17.660345 2 0 10001 +2587 856 14 2017-08-12 16:49:28.321459 2017-08-12 18:40:40.504294 2 0 10001 +2586 856 13 2017-08-12 14:57:46.513376 2017-08-12 16:49:06.400305 2 0 10001 +2585 856 12 2017-08-12 13:06:10.305377 2017-08-12 14:57:24.55967 2 0 10001 +2584 856 11 2017-08-12 11:14:36.223075 2017-08-12 13:05:48.8896 2 0 10001 +2583 856 10 2017-08-12 09:22:57.172277 2017-08-12 11:14:12.675041 2 0 10001 +2582 856 9 2017-08-12 07:31:09.094018 2017-08-12 09:22:34.601574 2 0 10001 +2581 856 8 2017-08-12 05:39:25.206012 2017-08-12 07:30:47.908617 2 0 10001 +2580 856 7 2017-08-12 03:47:59.178363 2017-08-12 05:39:01.834146 2 0 10001 +2579 856 6 2017-08-12 01:56:02.111778 2017-08-12 03:47:31.086948 2 0 10001 +2578 856 5 2017-08-12 00:04:03.972379 2017-08-12 01:55:37.780873 2 0 10001 +2577 856 4 2017-08-11 22:12:35.092845 2017-08-12 00:03:40.631399 2 0 10001 +2576 856 3 2017-08-11 20:20:58.477705 2017-08-11 22:12:14.587322 2 0 10001 +2575 856 2 2017-08-11 18:29:13.212467 2017-08-11 20:20:32.996897 2 0 10001 +2574 856 1 2017-08-11 16:37:33.88234 2017-08-11 18:28:51.708654 2 0 10001 +2573 856 0 2017-08-11 14:45:36.194233 2017-08-11 16:37:10.927722 2 0 10001 +2572 855 2 2017-08-11 12:22:26.023195 2017-08-11 13:59:14.535987 5 0 8721 +2571 855 1 2017-08-11 10:30:57.804934 2017-08-11 12:22:05.293079 5 0 10001 +2570 855 0 2017-08-11 08:39:31.573382 2017-08-11 10:30:31.095055 5 0 10001 +2569 854 9 2017-08-11 07:23:44.94623 2017-08-11 08:30:53.211389 2 0 6026 +2568 854 8 2017-08-11 05:32:09.839271 2017-08-11 07:23:24.125334 2 0 10001 +2567 854 7 2017-08-11 03:40:25.816315 2017-08-11 05:31:49.728103 2 0 10001 +2566 854 6 2017-08-11 01:48:50.632215 2017-08-11 03:40:00.229378 2 0 10001 +2565 854 5 2017-08-10 23:57:26.877992 2017-08-11 01:48:29.321353 2 0 10001 +2564 854 4 2017-08-10 22:05:55.959377 2017-08-10 23:56:59.718945 2 0 10001 +2563 854 3 2017-08-10 20:14:29.234129 2017-08-10 22:05:32.957989 2 0 10001 +2562 854 2 2017-08-10 18:23:00.522697 2017-08-10 20:14:07.107792 2 0 10001 +2561 854 1 2017-08-10 16:31:31.588396 2017-08-10 18:22:38.509328 2 0 10001 +2560 854 0 2017-08-10 14:39:51.563093 2017-08-10 16:31:09.947372 2 0 10001 +2559 853 2 2017-08-10 12:22:14.435247 2017-08-10 14:10:03.056583 5 0 9698 +2558 853 1 2017-08-10 10:30:54.710541 2017-08-10 12:21:49.887683 5 0 10001 +2557 853 0 2017-08-10 08:39:27.499842 2017-08-10 10:30:29.066058 5 0 10001 +2556 852 9 2017-08-10 08:03:22.291415 2017-08-10 08:26:33.921358 2 0 2056 +2555 852 8 2017-08-10 06:11:56.278432 2017-08-10 08:03:01.456925 2 0 10001 +2554 852 7 2017-08-10 04:20:26.283714 2017-08-10 06:11:35.447917 2 0 10001 +2553 852 6 2017-08-10 02:28:42.272889 2017-08-10 04:20:03.455522 2 0 10001 +2552 852 5 2017-08-10 00:37:05.341189 2017-08-10 02:28:17.514582 2 0 10001 +2551 852 4 2017-08-09 22:45:33.543505 2017-08-10 00:36:44.982364 2 0 10001 +2550 852 3 2017-08-09 20:54:01.333252 2017-08-09 22:45:11.638589 2 0 10001 +2549 852 2 2017-08-09 19:02:12.23327 2017-08-09 20:53:35.331251 2 0 10001 +2548 852 1 2017-08-09 17:10:48.321229 2017-08-09 19:01:49.846166 2 0 10001 +2547 852 0 2017-08-09 15:19:05.675559 2017-08-09 17:10:26.28633 2 0 10001 +2546 851 2 2017-08-09 12:34:01.081191 2017-08-09 14:05:05.995253 5 0 8218 +2545 851 1 2017-08-09 10:42:47.210151 2017-08-09 12:33:34.069185 5 0 10001 +2544 851 0 2017-08-09 08:51:26.263351 2017-08-09 10:42:24.837347 5 0 10001 +2543 850 22 2017-08-09 07:47:20.303547 2017-08-09 08:38:21.804707 2 0 4579 +2542 850 21 2017-08-09 05:55:27.224115 2017-08-09 07:46:56.128744 2 0 10001 +2541 850 20 2017-08-09 04:04:00.281762 2017-08-09 05:55:04.529508 2 0 10001 +2540 850 19 2017-08-09 02:12:27.26402 2017-08-09 04:03:34.391864 2 0 10001 +2539 850 18 2017-08-09 00:21:01.21268 2017-08-09 02:12:00.730778 2 0 10001 +2538 850 17 2017-08-08 22:29:37.007279 2017-08-09 00:20:36.94985 2 0 10001 +2537 850 16 2017-08-08 20:38:23.107446 2017-08-08 22:29:14.696924 2 0 10001 +2536 850 15 2017-08-08 18:46:54.939907 2017-08-08 20:37:57.721522 2 0 10001 +2535 850 14 2017-08-08 16:55:33.939025 2017-08-08 18:46:31.241153 2 0 10001 +2534 850 13 2017-08-08 15:04:14.668852 2017-08-08 16:55:12.670533 2 0 10001 +2533 850 12 2017-08-08 13:12:37.795124 2017-08-08 15:03:52.361575 2 0 10001 +2532 850 11 2017-08-08 11:21:07.770307 2017-08-08 13:12:13.646963 2 0 10001 +2531 850 10 2017-08-08 09:29:45.28752 2017-08-08 11:20:44.497282 2 0 10001 +2530 850 9 2017-08-08 07:38:17.959685 2017-08-08 09:29:23.168103 2 0 10001 +2529 850 8 2017-08-08 05:46:29.774743 2017-08-08 07:37:52.208427 2 0 10001 +2528 850 7 2017-08-08 03:55:14.029954 2017-08-08 05:46:08.626615 2 0 10001 +2527 850 6 2017-08-08 02:03:40.741383 2017-08-08 03:54:52.076303 2 0 10001 +2526 850 5 2017-08-08 00:12:00.791969 2017-08-08 02:03:14.999642 2 0 10001 +2525 850 4 2017-08-07 22:20:43.585593 2017-08-08 00:11:39.539151 2 0 10001 +2524 850 3 2017-08-07 20:29:28.539802 2017-08-07 22:20:20.896405 2 0 10001 +2523 850 2 2017-08-07 18:38:04.722005 2017-08-07 20:29:07.099163 2 0 10001 +2522 850 1 2017-08-07 16:46:44.477726 2017-08-07 18:37:42.931458 2 0 10001 +2521 850 0 2017-08-07 14:55:14.884402 2017-08-07 16:46:19.648397 2 0 10001 +2520 849 2 2017-08-07 13:21:14.314414 2017-08-07 14:20:55.329258 5 0 5367 +2519 849 1 2017-08-07 11:30:25.461703 2017-08-07 13:20:52.539111 5 0 10001 +2518 849 0 2017-08-07 09:39:21.064851 2017-08-07 11:30:04.298791 5 0 10001 +2517 848 35 2017-08-07 07:55:18.441797 2017-08-07 09:09:39.517359 2 0 6668 +2516 848 34 2017-08-07 06:03:54.403724 2017-08-07 07:54:57.188708 2 0 10001 +2515 848 33 2017-08-07 04:12:36.313442 2017-08-07 06:03:32.549722 2 0 10001 +2514 848 32 2017-08-07 02:21:20.285335 2017-08-07 04:12:14.718183 2 0 10001 +2513 848 31 2017-08-07 00:30:07.269797 2017-08-07 02:20:58.837083 2 0 10001 +2512 848 30 2017-08-06 22:38:44.25782 2017-08-07 00:29:41.675959 2 0 10001 +2511 848 29 2017-08-06 20:47:27.2388 2017-08-06 22:38:22.392623 2 0 10001 +2510 848 28 2017-08-06 18:56:09.190298 2017-08-06 20:47:04.507736 2 0 10001 +2509 848 27 2017-08-06 17:04:33.187966 2017-08-06 18:55:47.510001 2 0 10001 +2508 848 26 2017-08-06 15:13:19.135822 2017-08-06 17:04:11.212465 2 0 10001 +2507 848 25 2017-08-06 13:21:48.018487 2017-08-06 15:12:53.555067 2 0 10001 +2506 848 24 2017-08-06 11:30:16.986632 2017-08-06 13:21:27.110443 2 0 10001 +2505 848 23 2017-08-06 09:38:45.024534 2017-08-06 11:29:54.446438 2 0 10001 +2504 848 22 2017-08-06 07:47:31.071636 2017-08-06 09:38:23.651505 2 0 10001 +2503 848 21 2017-08-06 05:56:02.012087 2017-08-06 07:47:10.110184 2 0 10001 +2502 848 20 2017-08-06 04:04:43.915862 2017-08-06 05:55:37.807896 2 0 10001 +2501 848 19 2017-08-06 02:13:24.907853 2017-08-06 04:04:17.684376 2 0 10001 +2500 848 18 2017-08-06 00:22:15.011845 2017-08-06 02:13:02.700479 2 0 10001 +2499 848 17 2017-08-05 22:30:53.935335 2017-08-06 00:21:53.078822 2 0 10001 +2498 848 16 2017-08-05 20:39:40.890996 2017-08-05 22:30:28.905393 2 0 10001 +2497 848 15 2017-08-05 18:48:24.78861 2017-08-05 20:39:16.567149 2 0 10001 +2496 848 14 2017-08-05 16:57:11.79142 2017-08-05 18:48:04.466318 2 0 10001 +2495 848 13 2017-08-05 15:05:54.838285 2017-08-05 16:56:51.338686 2 0 10001 +2494 848 12 2017-08-05 13:14:37.978725 2017-08-05 15:05:31.333212 2 0 10001 +2493 848 11 2017-08-05 11:23:24.6515 2017-08-05 13:14:16.808011 2 0 10001 +2492 848 10 2017-08-05 09:32:08.127579 2017-08-05 11:23:02.407944 2 0 10001 +2491 848 9 2017-08-05 07:40:56.575133 2017-08-05 09:31:46.405666 2 0 10001 +2490 848 8 2017-08-05 05:49:26.78378 2017-08-05 07:40:33.956023 2 0 10001 +2489 848 7 2017-08-05 03:57:05.525016 2017-08-05 05:49:03.891507 2 0 10001 +2488 848 6 2017-08-05 02:05:53.757355 2017-08-05 03:56:44.928078 2 0 10001 +2487 848 5 2017-08-05 00:14:36.570112 2017-08-05 02:05:32.981318 2 0 10001 +2486 848 4 2017-08-04 22:23:11.460132 2017-08-05 00:14:13.405737 2 0 10001 +2485 848 3 2017-08-04 20:32:03.525088 2017-08-04 22:22:47.948563 2 0 10001 +2484 848 2 2017-08-04 18:41:02.499957 2017-08-04 20:31:42.755696 2 0 10001 +2483 848 1 2017-08-04 16:49:54.54767 2017-08-04 18:40:38.952156 2 0 10001 +2482 848 0 2017-08-04 14:58:52.501087 2017-08-04 16:49:32.210916 2 0 10001 +2481 847 3 2017-08-04 14:39:39.000391 2017-08-04 14:44:12.966383 5 0 377 +2480 847 2 2017-08-04 12:48:36.849902 2017-08-04 14:39:16.680007 5 0 10001 +2479 847 1 2017-08-04 10:57:47.970885 2017-08-04 12:48:15.046759 5 0 10001 +2478 847 0 2017-08-04 09:06:51.895438 2017-08-04 10:57:25.531111 5 0 10001 +2477 846 9 2017-08-04 07:45:21.833625 2017-08-04 08:42:25.681299 2 0 5132 +2476 846 8 2017-08-04 05:54:09.871893 2017-08-04 07:45:00.627877 2 0 10001 +2475 846 7 2017-08-04 04:02:42.863336 2017-08-04 05:53:46.788216 2 0 10001 +2474 846 6 2017-08-04 02:11:28.940272 2017-08-04 04:02:20.438831 2 0 10001 +2473 846 5 2017-08-04 00:20:18.70717 2017-08-04 02:11:08.660886 2 0 10001 +2472 846 4 2017-08-03 22:29:04.63348 2017-08-04 00:19:56.127199 2 0 10001 +2471 846 3 2017-08-03 20:37:58.651447 2017-08-03 22:28:42.556171 2 0 10001 +2470 846 2 2017-08-03 18:46:51.8307 2017-08-03 20:37:33.818426 2 0 10001 +2469 846 1 2017-08-03 16:55:39.599869 2017-08-03 18:46:26.808315 2 0 10001 +2468 846 0 2017-08-03 15:04:32.410191 2017-08-03 16:55:17.905615 2 0 10001 +2467 845 2 2017-08-03 13:09:25.67175 2017-08-03 13:27:54.230494 5 0 1643 +2466 845 1 2017-08-03 11:18:36.696136 2017-08-03 13:09:02.827893 5 0 10001 +2465 845 0 2017-08-03 09:27:29.60495 2017-08-03 11:18:12.484328 5 0 10001 +2464 844 7 2017-08-03 07:47:27.500181 2017-08-03 09:14:47.186217 2 0 7870 +2463 844 6 2017-08-03 05:56:09.4327 2017-08-03 07:47:02.577286 2 0 10001 +2462 844 5 2017-08-03 04:05:04.5619 2017-08-03 05:55:48.131697 2 0 10001 +2461 844 4 2017-08-03 02:13:51.543041 2017-08-03 04:04:42.881604 2 0 10001 +2460 844 3 2017-08-03 00:22:35.450463 2017-08-03 02:13:26.069742 2 0 10001 +2459 844 2 2017-08-02 22:31:27.429769 2017-08-03 00:22:13.209823 2 0 10001 +2458 844 1 2017-08-02 20:40:25.543602 2017-08-02 22:31:06.197632 2 0 10001 +2457 844 0 2017-08-02 18:49:18.113268 2017-08-02 20:40:02.097901 2 0 10001 +2456 843 8 2017-08-01 05:15:17.881957 2 0 +2455 843 7 2017-08-01 03:24:13.51407 2017-08-01 05:14:56.096106 2 0 10001 +2454 843 6 2017-08-01 01:32:54.872205 2017-08-01 03:23:50.027077 2 0 10001 +2453 843 5 2017-07-31 23:41:43.572468 2017-08-01 01:32:32.985231 2 0 10001 +2452 843 4 2017-07-31 21:50:16.528368 2017-07-31 23:41:21.178118 2 0 10001 +2451 843 3 2017-07-31 19:59:02.399606 2017-07-31 21:49:54.077745 2 0 10001 +2450 843 2 2017-07-31 18:07:41.296222 2017-07-31 19:58:42.108668 2 0 10001 +2449 843 1 2017-07-31 16:16:37.745625 2017-07-31 18:07:19.008869 2 0 10001 +2448 843 0 2017-07-31 14:25:18.598609 2017-07-31 16:16:13.804362 2 0 10001 +2447 842 2 2017-07-31 13:16:07.449837 2017-07-31 14:15:46.563975 5 0 5381 +2446 842 1 2017-07-31 11:24:55.296148 2017-07-31 13:15:45.084656 5 0 10001 +2445 842 0 2017-07-31 09:33:43.302425 2017-07-31 11:24:32.304458 5 0 10001 +2444 841 1 2017-07-30 21:04:23.376424 2017-07-31 09:04:11.459603 6 0 2197 +2443 841 0 2017-07-28 14:30:57.742272 2017-07-30 21:04:01.370442 6 0 10001 +2442 840 2 2017-07-28 13:01:36.230434 2017-07-28 14:20:12.370544 5 0 7096 +2441 840 1 2017-07-28 11:10:44.279035 2017-07-28 13:01:13.729249 5 0 10001 +2440 840 0 2017-07-28 09:19:46.462123 2017-07-28 11:10:21.511917 5 0 10001 +2439 839 9 2017-07-28 08:45:27.11019 2017-07-28 08:54:30.945967 2 0 788 +2438 839 8 2017-07-28 06:54:09.172876 2017-07-28 08:45:04.145656 2 0 10001 +2437 839 7 2017-07-28 05:03:03.139177 2017-07-28 06:53:46.235271 2 0 10001 +2436 839 6 2017-07-28 03:11:47.034762 2017-07-28 05:02:41.111125 2 0 10001 +2435 839 5 2017-07-28 01:20:43.014242 2017-07-28 03:11:25.893727 2 0 10001 +2434 839 4 2017-07-27 23:29:32.086612 2017-07-28 01:20:22.688988 2 0 10001 +2433 839 3 2017-07-27 21:38:27.060076 2017-07-27 23:29:08.430555 2 0 10001 +2432 839 2 2017-07-27 19:47:20.092068 2017-07-27 21:38:05.399372 2 0 10001 +2431 839 1 2017-07-27 17:56:00.939445 2017-07-27 19:46:56.799238 2 0 10001 +2430 839 0 2017-07-27 16:04:41.248884 2017-07-27 17:55:35.6321 2 0 10001 +2429 838 0 2017-07-27 14:31:15.620153 2017-07-27 16:02:54.071353 2 0 8241 +2428 837 1 2017-07-27 13:24:21.850258 2017-07-27 14:13:51.42058 5 0 4468 +2427 837 0 2017-07-27 11:27:19.051762 2017-07-27 13:23:59.969411 5 0 10001 +2426 836 0 2017-07-27 09:25:27.201868 2017-07-27 09:37:39.95586 5 0 338 +2425 835 9 2017-07-27 07:14:19.740019 2017-07-27 08:55:52.466272 2 0 9166 +2424 835 8 2017-07-27 05:23:12.735275 2017-07-27 07:13:57.752674 2 0 10001 +2423 835 7 2017-07-27 03:31:59.81543 2017-07-27 05:22:50.787019 2 0 10001 +2422 835 6 2017-07-27 01:40:40.600005 2017-07-27 03:31:37.028445 2 0 10001 +2421 835 5 2017-07-26 23:49:34.685087 2017-07-27 01:40:17.436608 2 0 10001 +2420 835 4 2017-07-26 21:58:35.664063 2017-07-26 23:49:12.487278 2 0 10001 +2419 835 3 2017-07-26 20:07:27.636643 2017-07-26 21:58:13.17579 2 0 10001 +2418 835 2 2017-07-26 18:16:13.63797 2017-07-26 20:07:03.972582 2 0 10001 +2417 835 1 2017-07-26 16:25:10.761676 2017-07-26 18:15:51.487176 2 0 10001 +2416 835 0 2017-07-26 14:34:05.450191 2017-07-26 16:24:49.07688 2 0 10001 +2415 834 1 2017-07-26 14:24:07.700138 2017-07-26 14:25:21.944423 7 0 33 +2414 834 0 2017-07-26 09:55:29.687729 2017-07-26 14:23:42.049189 7 0 10001 +2413 833 0 2017-07-25 14:31:16.902028 2017-07-26 09:41:10.723644 6 0 3511 +2412 832 1 2017-07-25 13:29:23.553362 2017-07-25 14:20:19.374838 7 0 2111 +2411 832 0 2017-07-25 09:27:53.966968 2017-07-25 13:29:01.423884 7 0 10001 +2410 831 0 2017-07-24 14:40:24.441775 2017-07-25 09:16:33.952056 6 0 3407 +2409 830 1 2017-07-24 14:05:03.859193 2017-07-24 14:22:29.841896 7 0 721 +2408 830 0 2017-07-24 10:06:07.556764 2017-07-24 14:04:40.391288 7 0 10001 +2407 829 1 2017-07-23 21:26:31.866957 2017-07-24 09:31:45.603461 6 0 2216 +2406 829 0 2017-07-21 14:53:22.266598 2017-07-23 21:26:10.333258 6 0 10001 +2405 828 1 2017-07-21 12:11:05.93406 2017-07-21 14:26:29.721245 7 0 5796 +2404 828 0 2017-07-21 08:15:37.934875 2017-07-21 12:10:38.334443 7 0 10001 +2403 827 0 2017-07-20 15:13:35.40796 2017-07-21 07:44:55.340603 6 0 3026 +2402 826 1 2017-07-20 13:30:57.732824 2017-07-20 14:43:47.288337 7 0 2678 +2401 826 0 2017-07-20 09:24:14.689967 2017-07-20 13:30:37.281033 7 0 10001 +2400 825 0 2017-07-19 15:33:39.833497 2017-07-20 08:13:13.440459 6 0 3049 +2399 824 5 2017-07-19 03:09:28.327135 2017-07-19 13:41:47.489252 6 0 1921 +2398 824 4 2017-07-16 20:19:14.410263 2017-07-19 03:09:05.80133 6 0 10001 +2397 824 3 2017-07-14 13:30:19.77116 2017-07-16 20:18:46.731245 6 0 10001 +2396 824 2 2017-07-12 06:40:18.659035 2017-07-14 13:29:58.165584 6 0 10001 +2395 824 1 2017-07-09 23:53:10.780331 2017-07-12 06:39:56.995601 6 0 10001 +2394 824 0 2017-07-07 17:02:45.074467 2017-07-09 23:52:49.707175 6 0 10001 +2393 823 2 2017-07-07 09:46:58.501383 2017-07-07 12:09:02.174406 6 0 1176 +2392 823 1 2017-07-06 12:13:07.415064 2017-07-07 09:46:35.339493 6 0 10001 +2391 823 0 2017-07-06 00:29:33.738233 2017-07-06 12:08:14.143959 6 0 5681 +2390 822 0 2017-07-06 00:13:33.436507 2017-07-06 00:27:00.292504 3 0 889 +2389 821 0 2017-07-05 23:56:48.380225 2017-07-06 00:11:59.194605 6 0 123 +2388 820 0 2017-07-05 23:45:17.127085 2017-07-05 23:54:38.733432 6 0 76 +2387 819 0 2017-07-05 23:04:43.119993 6 0 +2386 818 0 2017-07-05 23:02:20.369483 6 0 +2385 817 0 2017-07-05 21:35:47.207635 6 0 +2384 816 0 2017-07-05 18:55:17.302737 6 0 +2383 815 3 2017-07-04 22:49:02.431989 2017-07-05 18:44:00.107553 6 0 9440 +2382 815 2 2017-07-04 16:17:29.565991 2017-07-04 22:47:54.530345 6 0 2921 +2381 815 1 2017-07-04 14:41:28.656312 2017-07-04 16:09:40.351662 6 0 689 +2380 815 0 2017-07-03 16:49:05.538437 2017-07-04 14:41:06.052275 6 0 10001 +2379 814 3 2017-07-03 04:30:05.369345 2017-07-03 14:21:25.771185 6 0 4547 +2378 814 2 2017-07-02 06:57:34.84139 2017-07-03 04:29:42.356438 6 0 10001 +2377 814 1 2017-07-01 09:30:12.900035 2017-07-02 06:57:12.639841 6 0 10001 +2376 814 0 2017-06-30 13:55:38.631336 2017-07-01 09:29:50.513253 6 0 10001 +2375 813 7 2017-06-30 00:28:16.276524 2017-06-30 12:07:46.184201 6 0 5805 +2374 813 6 2017-06-29 03:28:40.580288 2017-06-30 00:27:53.558442 6 0 10001 +2373 813 5 2017-06-28 06:28:01.917443 2017-06-29 03:28:16.615152 6 0 10001 +2372 813 4 2017-06-27 08:23:09.57985 2017-06-28 06:27:38.881557 6 0 10001 +2371 813 3 2017-06-26 08:27:52.377989 2017-06-27 08:22:45.217243 6 0 10001 +2370 813 2 2017-06-25 11:25:24.053775 2017-06-26 08:27:29.323529 6 0 10001 +2369 813 1 2017-06-24 12:47:23.785247 2017-06-25 11:24:56.437882 6 0 10001 +2368 813 0 2017-06-23 14:36:35.20612 2017-06-24 12:47:00.861005 6 0 10001 +2367 812 2 2017-06-23 11:42:37.323869 2017-06-23 11:57:02.074598 6 0 104 +2366 812 1 2017-06-22 12:44:07.048043 2017-06-23 11:42:14.142162 6 0 10001 +2365 812 0 2017-06-21 14:43:34.618211 2017-06-22 12:43:42.032667 6 0 10001 +2364 811 1 2017-06-21 12:43:27.642318 2017-06-21 14:22:08.821297 7 0 4233 +2363 811 0 2017-06-21 08:52:24.930966 2017-06-21 12:43:04.686677 7 0 10001 +2362 810 0 2017-06-20 14:51:33.966124 2017-06-21 08:20:02.255164 6 0 8023 +2361 809 1 2017-06-20 14:09:30.807984 2017-06-20 14:27:46.334801 7 0 738 +2360 809 0 2017-06-20 10:08:23.750386 2017-06-20 14:09:08.989066 7 0 10001 +2359 808 11 2017-06-19 16:19:54.141663 2017-06-20 08:58:08.074642 6 0 8649 +2358 808 10 2017-06-18 18:50:06.836892 2017-06-19 16:19:30.205758 6 0 10001 +2357 808 9 2017-06-17 20:11:50.80812 2017-06-18 18:49:40.965326 6 0 10001 +2356 808 8 2017-06-16 21:49:15.206513 2017-06-17 20:11:30.742808 6 0 10001 +2355 808 7 2017-06-15 20:47:12.862968 2017-06-16 21:48:53.345886 6 0 10001 +2354 808 6 2017-06-14 21:19:45.822808 2017-06-15 20:46:50.001465 6 0 10001 +2353 808 5 2017-06-13 20:18:47.538994 2017-06-14 21:19:23.275248 6 0 10001 +2352 808 4 2017-06-12 19:45:55.045135 2017-06-13 20:18:27.905034 6 0 10001 +2351 808 3 2017-06-11 19:13:04.00517 2017-06-12 19:45:29.939129 6 0 10001 +2350 808 2 2017-06-10 18:34:28.967605 2017-06-11 19:12:34.511524 6 0 10001 +2349 808 1 2017-06-09 18:00:07.497059 2017-06-10 18:34:01.465164 6 0 10001 +2348 808 0 2017-06-08 19:14:59.597276 2017-06-09 17:59:43.03593 6 0 10001 +2347 807 0 2017-06-08 09:45:37.328519 2017-06-08 14:55:23.594431 6 0 2257 +2346 806 0 2017-06-08 09:27:28.728468 2017-06-08 09:40:59.680769 4 0 32 +2345 805 1 2017-06-07 14:54:28.31765 2017-06-08 09:23:50.778116 6 0 8022 +2344 805 0 2017-06-06 16:11:08.647169 2017-06-07 14:54:03.989527 6 0 10001 +2343 804 6 2017-06-06 02:50:23.646116 2017-06-06 16:06:46.294201 6 0 5806 +2342 804 5 2017-06-05 04:10:23.350524 2017-06-06 02:49:58.325035 6 0 10001 +2341 804 4 2017-06-04 05:43:12.784316 2017-06-05 04:09:58.083127 6 0 10001 +2340 804 3 2017-06-03 07:17:47.855206 2017-06-04 05:42:50.962996 6 0 10001 +2339 804 2 2017-06-02 09:06:58.727763 2017-06-03 07:17:23.016426 6 0 10001 +2338 804 1 2017-06-01 11:55:33.415828 2017-06-02 09:06:35.433285 6 0 10001 +2337 804 0 2017-05-31 14:11:37.996493 2017-06-01 11:55:10.460942 6 0 10001 +2336 803 7 2017-05-30 23:02:37.081625 2017-05-31 12:25:29.354885 6 0 5988 +2335 803 6 2017-05-30 01:37:08.811353 2017-05-30 23:02:14.812913 6 0 10001 +2334 803 5 2017-05-29 03:36:35.524091 2017-05-30 01:36:46.259909 6 0 10001 +2333 803 4 2017-05-28 06:10:09.25108 2017-05-29 03:36:14.313588 6 0 10001 +2332 803 3 2017-05-27 10:26:50.096682 2017-05-28 06:09:43.993009 6 0 10001 +2331 803 2 2017-05-26 14:00:43.755774 2017-05-27 10:26:30.165789 6 0 10001 +2330 803 1 2017-05-25 15:55:19.475232 2017-05-26 14:00:19.342174 6 0 10001 +2329 803 0 2017-05-24 14:17:27.337054 2017-05-25 15:54:53.248597 6 0 10001 +2328 802 0 2017-05-24 14:11:35.448409 6 0 +2327 801 0 2017-05-23 15:46:07.719456 2017-05-24 08:57:57.07936 6 0 8656 +2326 800 0 2017-05-23 13:28:53.12727 2017-05-23 15:37:08.399348 6 0 1044 +2325 799 7 2017-05-23 13:05:57.961507 2017-05-23 13:22:19.825795 6 0 133 +2324 799 6 2017-05-23 12:46:35.724447 2017-05-23 13:02:30.211298 6 0 129 +2323 799 5 2017-05-23 12:38:03.457934 2017-05-23 12:45:57.880056 6 0 64 +2322 799 4 2017-05-23 12:28:57.797189 2017-05-23 12:37:18.341342 6 0 65 +2321 799 3 2017-05-23 12:16:32.686257 2017-05-23 12:25:32.153436 6 0 71 +2320 799 2 2017-05-23 12:00:45.523101 2017-05-23 12:15:48.250958 6 0 122 +2319 799 1 2017-05-23 11:43:19.496245 2017-05-23 11:59:56.903598 6 0 137 +2318 799 0 2017-05-23 11:28:13.7113 2017-05-23 11:42:45.69954 6 0 121 +2317 798 7 2017-05-22 16:49:37.454556 2017-05-23 11:21:14.631947 6 0 7905 +2316 798 6 2017-05-21 16:27:49.487697 2017-05-22 16:49:12.976136 6 0 10001 +2315 798 5 2017-05-20 17:26:08.409158 2017-05-21 16:27:26.957923 6 0 10001 +2314 798 4 2017-05-19 17:58:08.016927 2017-05-20 17:25:46.373761 6 0 10001 +2313 798 3 2017-05-18 18:57:12.572581 2017-05-19 17:57:46.598505 6 0 10001 +2312 798 2 2017-05-17 20:04:07.594593 2017-05-18 18:56:50.338693 6 0 10001 +2311 798 1 2017-05-16 21:07:17.053087 2017-05-17 20:03:44.748738 6 0 10001 +2310 798 0 2017-05-15 22:25:10.006924 2017-05-16 21:06:55.098508 6 0 10001 +2309 797 1 2017-05-15 19:48:03.286372 2017-05-15 22:19:45.533689 4 0 358 +2308 797 0 2017-05-15 11:14:06.877706 2017-05-15 19:45:53.562656 4 0 1244 +2307 796 2 2017-05-14 11:42:37.304087 2017-05-15 11:10:43.627914 6 0 7602 +2306 796 1 2017-05-13 12:43:22.964615 2017-05-14 11:42:15.550104 6 0 10001 +2305 796 0 2017-05-12 13:57:08.281751 2017-05-13 12:42:58.261075 6 0 10001 +2304 795 7 2017-05-12 11:36:15.335307 2017-05-12 12:15:31.792682 6 0 2265 +2303 795 6 2017-05-12 08:43:27.436858 2017-05-12 11:35:49.875244 6 0 10001 +2302 795 5 2017-05-12 05:49:33.367318 2017-05-12 08:43:03.748763 6 0 10001 +2301 795 4 2017-05-12 02:55:53.352004 2017-05-12 05:49:08.054899 6 0 10001 +2300 795 3 2017-05-12 00:01:57.225704 2017-05-12 02:55:31.220076 6 0 10001 +2299 795 2 2017-05-11 21:09:16.8272 2017-05-12 00:01:36.978813 6 0 10001 +2298 795 1 2017-05-11 18:18:21.097663 2017-05-11 21:08:50.60052 6 0 10001 +2297 795 0 2017-05-11 15:27:24.896214 2017-05-11 18:17:58.138737 6 0 10001 +2296 794 1 2017-05-11 14:57:03.133708 2017-05-11 15:22:05.990333 6 0 1451 +2295 794 0 2017-05-11 12:01:09.275623 2017-05-11 14:56:39.137777 6 0 10001 +2294 793 1 2017-05-11 11:37:33.89168 2017-05-11 11:38:34.308964 0 0 32 +2293 793 0 2017-05-11 11:35:13.332087 2017-05-11 11:37:05.228334 0 0 86 +2292 792 1 2017-05-11 11:27:34.346612 2017-05-11 11:28:12.393771 0 0 14 +2291 792 0 2017-05-11 11:25:50.482808 2017-05-11 11:27:11.913505 0 0 51 +2290 791 0 2017-05-11 11:22:24.905889 2017-05-11 11:23:32.490884 0 0 42 +2289 790 0 2017-05-11 11:12:03.747399 0 0 +2288 789 0 2017-05-11 11:10:15.971377 2017-05-11 11:11:29.378751 0 0 51 +2287 788 0 2017-05-11 11:00:55.227024 2017-05-11 11:05:20.243153 0 0 223 +2286 787 0 2017-05-11 10:52:42.28064 0 0 +2285 786 0 2017-05-11 10:47:33.412158 2017-05-11 10:49:31.508746 0 0 30 +2284 785 0 2017-05-11 10:09:00.617612 2017-05-11 10:29:27.145872 0 0 351 +2283 784 0 2017-05-11 09:53:56.914797 2017-05-11 10:04:51.906592 0 0 187 +2282 783 0 2017-05-11 09:42:26.052086 0 0 +2281 782 0 2017-05-11 08:40:26.242418 0 0 +2280 781 0 2017-05-11 08:36:13.891927 0 0 +2279 780 0 2017-05-11 08:20:38.747201 0 0 +2278 779 0 2017-05-11 08:02:31.501567 2017-05-11 08:03:13.192312 0 0 2 +2277 778 0 2017-05-11 08:00:47.07188 0 0 +2276 777 0 2017-05-11 07:55:59.808278 0 0 +2275 776 0 2017-05-11 07:50:24.305623 0 0 +2274 775 0 2017-05-11 07:43:25.216398 0 0 +2273 774 0 2017-05-11 07:38:50.225339 0 0 +2272 773 0 2017-05-11 07:35:54.54588 0 0 +2271 772 0 2017-05-11 07:30:02.778049 0 0 +2270 771 0 2017-05-11 07:20:17.276665 0 0 +2269 770 0 2017-05-11 07:19:15.637264 0 0 +2268 769 0 2017-05-11 06:23:03.605866 0 0 +2267 768 0 2017-05-11 06:14:00.31331 0 0 +2266 767 0 2017-05-11 06:12:15.612538 0 0 +2265 766 0 2017-05-11 06:09:18.44551 0 0 +2264 765 0 2017-05-11 06:03:36.351775 0 0 +2263 764 0 2017-05-11 05:51:02.195863 0 0 +2262 763 0 2017-05-11 05:31:36.798611 0 0 +2261 762 0 2017-05-11 05:10:28.71226 3 0 +2260 761 0 2017-05-11 05:08:11.313345 3 0 +2259 760 0 2017-05-11 04:59:24.831765 3 0 +2258 759 0 2017-05-11 04:54:54.074365 3 0 +2257 758 0 2017-05-11 04:53:05.194489 0 0 +2256 757 0 2017-05-11 04:44:15.453631 2017-05-11 04:47:10.105858 0 0 45 +2255 756 0 2017-05-11 04:33:20.958113 0 0 +2254 755 0 2017-05-11 04:15:54.365045 0 0 +2253 754 0 2017-05-11 04:07:59.021153 0 0 +2252 753 0 2017-05-11 04:03:09.654045 0 0 +2251 752 0 2017-05-11 03:57:16.177825 0 0 +2250 751 0 2017-05-11 03:53:38.741842 0 0 +2249 750 0 2017-05-11 03:51:03.671841 0 0 +2248 749 0 2017-05-11 03:44:32.345227 0 0 +2247 748 0 2017-05-11 03:37:30.447082 0 0 +2246 747 0 2017-05-11 03:10:34.073227 0 0 +2245 746 0 2017-05-11 03:07:12.785913 0 0 +2244 745 0 2017-05-11 03:03:50.150804 0 0 +2243 744 0 2017-05-11 02:58:25.264105 0 0 +2242 743 0 2017-05-11 02:50:38.735671 0 0 +2241 742 0 2017-05-11 02:10:31.201835 6 0 +2240 741 0 2017-05-10 23:45:08.385433 2017-05-11 02:06:02.818672 6 0 2468 +2239 740 0 2017-05-10 22:13:24.007233 6 0 +2238 739 0 2017-05-10 20:44:04.89137 2017-05-10 21:31:42.402845 4 0 0 +2237 738 0 2017-05-10 20:32:16.916792 3 0 +2236 737 0 2017-05-10 19:38:35.880901 6 0 +2235 736 0 2017-05-10 19:18:20.49383 6 0 +2234 735 2 2017-05-10 15:50:20.819627 2017-05-10 18:57:46.502574 6 0 1401 +2233 735 1 2017-05-09 17:01:37.853804 2017-05-10 15:49:54.918413 6 0 10001 +2232 735 0 2017-05-08 15:52:54.192426 2017-05-09 17:01:12.187664 6 0 10001 +2231 734 2 2017-05-08 14:13:26.795975 6 0 +2230 734 1 2017-05-07 14:59:15.26688 2017-05-08 14:13:04.257574 6 0 10001 +2229 734 0 2017-05-06 16:18:06.671544 2017-05-07 14:58:53.099493 6 0 10001 +2228 733 2 2017-05-06 14:42:34.249303 6 0 +2227 733 1 2017-05-05 15:37:00.68093 2017-05-06 14:42:07.828155 6 0 10001 +2226 733 0 2017-05-04 16:53:11.275673 2017-05-05 15:36:38.61385 6 0 10001 +2225 732 0 2017-05-04 16:50:19.593079 6 0 +2224 731 0 2017-05-04 15:38:44.137146 2017-05-04 16:47:50.918006 6 0 506 +2223 730 1 2017-05-04 14:07:24.545729 6 0 +2222 730 0 2017-05-03 14:37:50.930761 2017-05-04 14:07:02.306804 6 0 10001 +2221 729 1 2017-05-03 12:21:00.052567 6 0 +2220 729 0 2017-05-02 13:51:46.149483 2017-05-03 12:20:38.402873 6 0 10001 +2219 728 0 2017-05-02 13:42:34.484418 3 0 +2218 727 0 2017-05-02 13:35:15.419962 2017-05-02 13:41:33.85104 3 0 53 +2217 726 0 2017-05-02 13:30:37.163355 2017-05-02 13:34:21.011969 3 0 50 +2216 725 0 2017-05-02 13:11:15.963015 2017-05-02 13:29:47.527563 3 0 59 +2215 724 0 2017-05-02 13:00:06.165984 2017-05-02 13:10:25.22204 3 0 45 +2214 723 1 2017-05-02 12:43:24.334986 2017-05-02 12:59:02.578507 3 0 47 +2213 723 0 2017-05-02 12:39:39.323746 2017-05-02 12:42:36.94618 3 0 0 +2212 722 0 2017-05-02 12:19:39.090249 2017-05-02 12:29:04.066742 3 0 468 +2211 721 0 2017-05-02 11:41:47.92288 2017-05-02 12:17:43.54661 3 0 1868 +2210 720 0 2017-05-01 10:38:28.960991 2017-05-02 08:26:14.74372 6 0 7475 +2209 719 0 2017-05-01 10:25:12.449921 2017-05-01 10:34:38.571963 0 0 139774213855744 +2208 718 9 2017-05-01 03:09:05.99567 2017-05-01 03:49:28.399789 3 0 1960 +2207 718 8 2017-04-30 23:14:17.372032 2017-05-01 03:08:43.559294 3 0 10001 +2206 718 7 2017-04-30 19:14:38.851105 2017-04-30 23:13:53.9318 3 0 10001 +2205 718 6 2017-04-30 15:15:01.869997 2017-04-30 19:14:16.909584 3 0 10001 +2204 718 5 2017-04-30 11:15:28.756438 2017-04-30 15:14:40.178146 3 0 10001 +2203 718 4 2017-04-30 07:15:46.521583 2017-04-30 11:15:04.158023 3 0 10001 +2202 718 3 2017-04-30 03:19:04.335168 2017-04-30 07:15:24.118366 3 0 10001 +2201 718 2 2017-04-29 23:59:29.430329 2017-04-30 03:18:39.947733 3 0 10001 +2200 718 1 2017-04-29 20:45:42.29572 2017-04-29 23:59:04.706297 3 0 10001 +2199 718 0 2017-04-29 17:16:31.602619 2017-04-29 20:45:20.148725 3 0 10001 +2198 717 2 2017-04-29 06:45:24.851761 2017-04-29 07:43:05.553043 3 0 2397 +2197 717 1 2017-04-29 02:45:52.979795 2017-04-29 06:44:59.502671 3 0 10001 +2196 717 0 2017-04-28 22:46:17.686503 2017-04-29 02:45:28.931311 3 0 10001 +2195 716 21 2017-04-28 22:31:14.195633 2017-04-28 22:32:01.522138 3 0 0 +2194 716 20 2017-04-28 18:31:31.962919 2017-04-28 22:30:51.509647 3 0 10001 +2193 716 19 2017-04-28 14:31:40.755833 2017-04-28 18:31:07.322529 3 0 10001 +2192 716 18 2017-04-28 10:31:52.680214 2017-04-28 14:31:18.91104 3 0 10001 +2191 716 17 2017-04-28 06:17:48.630537 2017-04-28 10:31:30.876282 3 0 10001 +2190 716 16 2017-04-28 02:18:13.361927 2017-04-28 06:17:21.059784 3 0 10001 +2189 716 15 2017-04-27 22:18:29.335646 2017-04-28 02:17:50.992031 3 0 10001 +2188 716 14 2017-04-27 18:18:44.121986 2017-04-27 22:18:01.093913 3 0 10001 +2187 716 13 2017-04-27 14:17:07.040855 2017-04-27 18:18:21.298011 3 0 10001 +2186 716 12 2017-04-27 10:27:23.822138 2017-04-27 14:16:45.409338 3 0 10001 +2185 716 11 2017-04-27 06:44:10.872288 2017-04-27 10:26:57.359817 3 0 10001 +2184 716 10 2017-04-27 03:07:40.768945 2017-04-27 06:43:48.586472 3 0 10001 +2183 716 9 2017-04-26 23:54:00.441326 2017-04-27 03:07:14.002992 3 0 10001 +2182 716 8 2017-04-26 20:40:12.440438 2017-04-26 23:53:38.655763 3 0 10001 +2181 716 7 2017-04-26 17:26:23.411662 2017-04-26 20:39:45.119383 3 0 10001 +2180 716 6 2017-04-26 13:52:30.295751 2017-04-26 17:25:58.828012 3 0 10001 +2179 716 5 2017-04-26 10:38:44.220145 2017-04-26 13:52:08.2083 3 0 10001 +2178 716 4 2017-04-26 07:24:43.122697 2017-04-26 10:38:22.429992 3 0 10001 +2177 716 3 2017-04-26 04:11:00.191634 2017-04-26 07:24:18.966403 3 0 10001 +2176 716 2 2017-04-26 00:57:21.145458 2017-04-26 04:10:36.697339 3 0 10001 +2175 716 1 2017-04-25 21:43:23.739757 2017-04-26 00:56:57.670014 3 0 10001 +2174 716 0 2017-04-25 18:30:01.960812 2017-04-25 21:42:59.608586 3 0 10001 +2173 715 0 2017-04-25 14:41:56.709822 2017-04-25 18:24:19.198798 4 0 644 +2172 714 0 2017-04-25 09:13:44.192862 2017-04-25 14:18:31.248241 6 0 22 +2171 713 0 2017-04-25 07:38:16.341656 2017-04-25 08:27:47.688521 6 0 3 +2170 712 7 2017-04-25 03:02:39.405795 2017-04-25 07:29:20.049782 3 0 4943 +2169 712 6 2017-04-24 23:19:23.573387 2017-04-25 03:02:10.909177 3 0 10001 +2168 712 5 2017-04-24 19:26:13.164785 2017-04-24 23:18:57.042339 3 0 10001 +2167 712 4 2017-04-24 15:30:47.264458 2017-04-24 19:25:51.277737 3 0 10001 +2166 712 3 2017-04-24 11:47:51.924197 2017-04-24 15:30:25.28817 3 0 10001 +2165 712 2 2017-04-24 07:51:08.954927 2017-04-24 11:47:29.772287 3 0 10001 +2164 712 1 2017-04-24 03:51:28.865909 2017-04-24 07:50:42.358496 3 0 10001 +2163 712 0 2017-04-23 23:51:48.360275 2017-04-24 03:51:07.451184 3 0 10001 +2162 711 17 2017-04-23 20:11:36.611865 2017-04-23 23:48:21.778285 3 0 9646 +2161 711 16 2017-04-23 16:04:16.78182 2017-04-23 20:11:14.241376 3 0 10001 +2160 711 15 2017-04-23 12:04:43.454601 2017-04-23 16:03:54.470876 3 0 10001 +2159 711 14 2017-04-23 08:16:13.352626 2017-04-23 12:04:21.328709 3 0 10001 +2158 711 13 2017-04-23 04:16:38.093589 2017-04-23 08:15:51.497444 3 0 10001 +2157 711 12 2017-04-23 00:19:43.425429 2017-04-23 04:16:15.820158 3 0 10001 +2156 711 11 2017-04-22 20:36:44.060681 2017-04-23 00:19:19.572912 3 0 10001 +2155 711 10 2017-04-22 16:34:31.17108 2017-04-22 20:36:20.499497 3 0 10001 +2154 711 9 2017-04-22 12:32:43.810089 2017-04-22 16:34:04.45933 3 0 10001 +2153 711 8 2017-04-22 08:29:11.751586 2017-04-22 12:32:21.483719 3 0 10001 +2152 711 7 2017-04-22 04:29:31.933169 2017-04-22 08:28:45.589671 3 0 10001 +2151 711 6 2017-04-22 00:29:45.752236 2017-04-22 04:29:08.498062 3 0 10001 +2150 711 5 2017-04-21 20:28:59.243979 2017-04-22 00:29:18.964553 3 0 10001 +2149 711 4 2017-04-21 16:20:04.180965 2017-04-21 20:28:36.738192 3 0 10001 +2148 711 3 2017-04-21 12:20:29.211742 2017-04-21 16:19:40.537946 3 0 10001 +2147 711 2 2017-04-21 08:20:41.045164 2017-04-21 12:20:04.157372 3 0 10001 +2146 711 1 2017-04-21 04:21:01.734411 2017-04-21 08:20:18.285878 3 0 10001 +2145 711 0 2017-04-21 00:20:06.615915 2017-04-21 04:20:35.584626 3 0 10001 +2144 710 0 2017-04-20 21:59:42.591011 2017-04-21 00:11:32.337669 6 0 966 +2143 709 1 2017-04-20 19:58:30.571309 2017-04-20 21:57:24.240275 3 0 4953 +2142 709 0 2017-04-20 15:58:53.911526 2017-04-20 19:58:10.042684 3 0 10001 +2141 708 3 2017-04-20 15:22:38.924976 2017-04-20 15:40:26.878127 3 0 720 +2140 708 2 2017-04-20 15:00:52.235094 2017-04-20 15:10:58.272564 3 0 403 +2139 708 1 2017-04-20 14:30:28.955408 2017-04-20 14:32:24.992047 3 0 70 +2138 708 0 2017-04-20 14:17:08.670474 2017-04-20 14:21:04.187526 3 0 150 +2137 707 8 2017-04-20 01:48:28.580586 2017-04-20 05:47:46.294267 3 0 10001 +2136 707 7 2017-04-19 21:48:45.002853 2017-04-20 01:48:04.348189 3 0 10001 +2135 707 6 2017-04-19 16:39:56.009887 2017-04-19 21:48:23.329963 3 0 10001 +2134 707 5 2017-04-19 12:40:23.261665 2017-04-19 16:39:33.487915 3 0 10001 +2133 707 4 2017-04-19 08:41:01.781591 2017-04-19 12:40:00.94867 3 0 10001 +2132 707 3 2017-04-19 04:58:00.740834 2017-04-19 08:40:39.148984 3 0 10001 +2131 707 2 2017-04-19 01:14:58.349687 2017-04-19 04:57:36.260318 3 0 10001 +2130 707 1 2017-04-18 21:31:55.35475 2017-04-19 01:14:34.54561 3 0 10001 +2129 707 0 2017-04-18 17:48:51.666529 2017-04-18 21:31:29.407343 3 0 10001 +2128 706 7 2017-04-18 15:08:23.55479 2017-04-18 17:22:29.328851 3 0 6013 +2127 706 6 2017-04-18 11:36:23.469461 2017-04-18 15:07:57.727045 3 0 10001 +2126 706 5 2017-04-18 08:23:43.220995 2017-04-18 11:35:59.617793 3 0 10001 +2125 706 4 2017-04-18 05:09:56.105443 2017-04-18 08:23:16.680216 3 0 10001 +2124 706 3 2017-04-18 01:55:55.049913 2017-04-18 05:09:29.838166 3 0 10001 +2123 706 2 2017-04-17 22:44:01.944997 2017-04-18 01:55:30.436709 3 0 10001 +2122 706 1 2017-04-17 19:33:59.774307 2017-04-17 22:43:37.137767 3 0 10001 +2121 706 0 2017-04-17 16:21:02.867351 2017-04-17 19:33:35.95142 3 0 10001 +2120 705 17 2017-04-17 13:08:20.782156 2017-04-17 16:15:09.232969 3 0 9655 +2119 705 16 2017-04-17 09:54:25.94247 2017-04-17 13:07:59.189161 3 0 10001 +2118 705 15 2017-04-17 06:40:30.334469 2017-04-17 09:53:59.757387 3 0 10001 +2117 705 14 2017-04-17 03:03:33.602488 2017-04-17 06:40:08.498841 3 0 10001 +2116 705 13 2017-04-16 23:20:35.371612 2017-04-17 03:03:05.299354 3 0 10001 +2115 705 12 2017-04-16 19:37:43.567584 2017-04-16 23:20:13.99729 3 0 10001 +2114 705 11 2017-04-16 15:54:42.991371 2017-04-16 19:37:18.830606 3 0 10001 +2113 705 10 2017-04-16 12:11:36.90387 2017-04-16 15:54:21.59698 3 0 10001 +2112 705 9 2017-04-16 08:12:03.261686 2017-04-16 12:11:16.15807 3 0 10001 +2111 705 8 2017-04-16 04:12:20.851109 2017-04-16 08:11:41.997584 3 0 10001 +2110 705 7 2017-04-16 00:12:30.619728 2017-04-16 04:11:58.85735 3 0 10001 +2109 705 6 2017-04-15 20:12:52.669415 2017-04-16 00:12:08.909532 3 0 10001 +2108 705 5 2017-04-15 16:13:19.383463 2017-04-15 20:12:29.727955 3 0 10001 +2107 705 4 2017-04-15 05:22:04.103601 2017-04-15 16:12:53.469942 3 0 10001 +2106 705 3 2017-04-15 01:26:49.132402 2017-04-15 05:21:42.137256 3 0 10001 +2105 705 2 2017-04-14 21:27:09.882503 2017-04-15 01:26:23.147346 3 0 10001 +2104 705 1 2017-04-14 17:27:35.659423 2017-04-14 21:26:47.037653 3 0 10001 +2103 705 0 2017-04-14 13:27:48.610495 2017-04-14 17:27:13.101451 3 0 10001 +2102 704 0 2017-04-14 13:24:54.432746 3 0 +2101 703 4 2017-04-14 08:13:20.511866 2017-04-14 10:46:15.076796 3 0 6344 +2100 703 3 2017-04-14 04:13:34.630726 2017-04-14 08:12:54.147322 3 0 10001 +2099 703 2 2017-04-14 00:13:52.453466 2017-04-14 04:13:10.159144 3 0 10001 +2098 703 1 2017-04-13 20:14:10.412443 2017-04-14 00:13:26.838338 3 0 10001 +2097 703 0 2017-04-13 16:15:08.962639 2017-04-13 20:13:43.8984 3 0 10001 +2096 702 0 2017-04-13 14:52:59.405336 2017-04-13 16:04:08.559817 6 0 530 +2095 701 2 2017-04-13 12:48:41.940307 2017-04-13 14:21:14.568159 5 0 8356 +2094 701 1 2017-04-13 10:57:33.991502 2017-04-13 12:48:20.727204 5 0 10001 +2093 701 0 2017-04-13 09:06:29.295179 2017-04-13 10:57:11.470005 5 0 10001 +2092 700 3 2017-04-13 08:26:21.051107 2017-04-13 08:36:19.325541 3 0 402 +2091 700 2 2017-04-13 04:26:27.984739 2017-04-13 08:25:56.205407 3 0 10001 +2090 700 1 2017-04-13 00:26:53.860259 2017-04-13 04:26:05.67725 3 0 10001 +2089 700 0 2017-04-12 19:25:41.956305 2017-04-12 23:34:09.588214 3 0 7605 +2088 699 0 2017-04-12 15:41:15.691485 2017-04-12 19:22:04.307273 6 0 1659 +2087 698 2 2017-04-12 13:11:07.471597 2017-04-12 14:18:59.538215 5 0 6094 +2086 698 1 2017-04-12 11:57:02.572048 2017-04-12 13:09:04.333589 5 0 6455 +2085 698 0 2017-04-12 10:05:44.670187 2017-04-12 11:56:39.038177 5 0 10001 +2084 697 3 2017-04-12 05:59:20.131959 2017-04-12 08:42:20.75456 3 0 3340 +2083 697 2 2017-04-12 00:10:20.972284 2017-04-12 05:58:57.128549 3 0 10001 +2082 697 1 2017-04-11 20:10:47.112377 2017-04-12 00:09:56.508626 3 0 10001 +2081 697 0 2017-04-11 15:38:11.652052 2017-04-11 20:10:19.176057 3 0 10001 +2080 696 9 2017-04-11 12:24:39.414515 2017-04-11 13:35:05.6483 3 0 3070 +2079 696 8 2017-04-11 08:25:02.045026 2017-04-11 12:24:18.253647 3 0 10001 +2078 696 7 2017-04-11 04:25:23.152001 2017-04-11 08:24:35.540101 3 0 10001 +2077 696 6 2017-04-11 00:07:01.004182 2017-04-11 04:24:58.435651 3 0 10001 +2076 696 5 2017-04-10 20:07:26.461765 2017-04-11 00:06:38.668187 3 0 10001 +2075 696 4 2017-04-10 16:07:53.813337 2017-04-10 20:07:03.595644 3 0 10001 +2074 696 3 2017-04-10 11:58:51.584293 2017-04-10 16:07:32.97803 3 0 10001 +2073 696 2 2017-04-10 07:27:54.871397 2017-04-10 11:58:27.149137 3 0 10001 +2072 696 1 2017-04-10 03:28:16.89208 2017-04-10 07:27:28.137182 3 0 10001 +2071 696 0 2017-04-09 23:28:39.880447 2017-04-10 03:27:56.471311 3 0 10001 +2070 695 10 2017-04-09 20:45:29.692536 2017-04-09 23:24:18.389441 3 0 6637 +2069 695 9 2017-04-09 16:45:43.70157 2017-04-09 20:45:04.807866 3 0 10001 +2068 695 8 2017-04-09 12:46:00.632667 2017-04-09 16:45:17.7927 3 0 10001 +2067 695 7 2017-04-09 08:46:25.430566 2017-04-09 12:45:38.898394 3 0 10001 +2066 695 6 2017-04-09 04:46:53.890205 2017-04-09 08:46:03.56824 3 0 10001 +2065 695 5 2017-04-09 00:47:17.447826 2017-04-09 04:46:31.487778 3 0 10001 +2064 695 4 2017-04-08 20:47:44.990667 2017-04-09 00:46:55.398032 3 0 10001 +2063 695 3 2017-04-08 16:48:01.952852 2017-04-08 20:47:19.518058 3 0 10001 +2062 695 2 2017-04-08 12:48:22.780477 2017-04-08 16:47:38.156871 3 0 10001 +2061 695 1 2017-04-08 08:48:45.712988 2017-04-08 12:47:58.905764 3 0 10001 +2060 695 0 2017-04-08 04:34:01.23026 2017-04-08 08:48:23.378138 3 0 10001 +2059 694 14 2017-04-08 01:37:28.851954 2017-04-08 04:30:43.425043 3 0 7236 +2058 694 13 2017-04-07 21:37:44.568419 2017-04-08 01:37:07.505446 3 0 10001 +2057 694 12 2017-04-07 18:05:33.626087 2017-04-07 21:37:22.103094 3 0 10001 +2056 694 11 2017-04-07 14:24:50.520192 2017-04-07 18:05:09.957209 3 0 10001 +2055 694 10 2017-04-07 10:25:08.318857 2017-04-07 14:24:26.960365 3 0 10001 +2054 694 9 2017-04-07 01:35:32.92601 2017-04-07 10:24:45.448354 3 0 10001 +2053 694 8 2017-04-06 21:35:58.86836 2017-04-07 01:35:10.67906 3 0 10001 +2052 694 7 2017-04-06 17:36:21.771107 2017-04-06 21:35:34.536479 3 0 10001 +2051 694 6 2017-04-06 13:36:23.583656 2017-04-06 17:35:56.315079 3 0 10001 +2050 694 5 2017-04-06 09:36:42.679173 2017-04-06 13:35:57.965558 3 0 10001 +2049 694 4 2017-04-06 05:36:51.43461 2017-04-06 09:36:18.371532 3 0 10001 +2048 694 3 2017-04-06 01:16:41.241902 2017-04-06 05:36:24.237096 3 0 10001 +2047 694 2 2017-04-05 21:16:57.303079 2017-04-06 01:16:18.537067 3 0 10001 +2046 694 1 2017-04-05 17:17:23.993455 2017-04-05 21:16:35.838513 3 0 10001 +2045 694 0 2017-04-05 13:17:49.788156 2017-04-05 17:17:02.679828 3 0 10001 +2044 693 2 2017-04-05 08:40:27.401296 2017-04-05 12:37:00.106376 3 0 9876 +2043 693 1 2017-04-05 04:40:36.931621 2017-04-05 08:40:04.805419 3 0 10001 +2042 693 0 2017-04-04 23:50:46.88925 2017-04-05 04:40:14.971025 3 0 10001 +2041 692 0 2017-04-04 15:56:25.623057 2017-04-04 22:10:08.046581 6 0 2679 +2040 691 0 2017-04-04 11:38:08.599218 2017-04-04 11:47:13.957512 6 0 67 +2039 690 0 2017-04-04 11:19:41.818166 2017-04-04 11:34:27.076312 0 0 437 +2038 689 2 2017-04-04 11:16:18.251578 2017-04-04 11:18:22.02755 0 0 81 +2037 689 1 2017-04-04 11:13:00.512893 2017-04-04 11:15:44.497033 0 0 124 +2036 689 0 2017-04-04 11:01:26.931906 2017-04-04 11:12:04.990748 0 0 532 +2035 688 0 2017-04-04 10:00:07.609579 2017-04-04 10:25:04.856959 6 0 187 +2034 687 0 2017-04-03 17:40:00.718781 2017-04-03 17:40:44.172565 6 0 0 +2033 686 0 2017-04-03 17:31:55.809056 2017-04-03 17:33:02.577032 6 0 4 +2032 685 0 2017-04-03 13:57:54.119876 2017-04-03 17:08:12.0887 6 0 1345 +2031 684 1 2017-04-03 12:09:51.019934 2017-04-03 13:37:05.001767 6 0 653 +2030 684 0 2017-04-03 09:58:30.280689 2017-04-03 12:07:52.73689 6 0 814 +2029 683 6 2017-04-03 06:46:30.019188 2017-04-03 09:56:49.008326 3 0 7698 +2028 683 5 2017-04-03 02:46:53.468333 2017-04-03 06:46:06.000417 3 0 10001 +2027 683 4 2017-04-02 22:47:15.328458 2017-04-03 02:46:30.998471 3 0 10001 +2026 683 3 2017-04-02 18:47:34.114254 2017-04-02 22:46:48.997483 3 0 10001 +2025 683 2 2017-04-02 14:47:54.950551 2017-04-02 18:47:11.001644 3 0 10001 +2024 683 1 2017-04-02 10:48:28.11827 2017-04-02 14:47:32.65665 3 0 10001 +2023 683 0 2017-04-02 06:47:26.960847 2017-04-02 10:48:04.650899 3 0 10001 +2022 682 0 2017-04-02 06:20:45.809499 2017-04-02 06:44:30.25693 0 0 981 +2021 681 0 2017-04-02 06:02:59.053496 2017-04-02 06:18:29.037642 0 0 628 +2020 680 0 2017-04-02 05:10:48.510164 2017-04-02 05:24:51.477763 0 0 578 +2019 679 8 2017-04-02 02:56:06.940401 2017-04-02 05:08:59.826518 3 0 5537 +2018 679 7 2017-04-01 22:08:10.970692 2017-04-02 02:55:44.276633 3 0 10001 +2017 679 6 2017-04-01 18:08:31.468579 2017-04-01 22:07:47.271908 3 0 10001 +2016 679 5 2017-04-01 14:09:00.709584 2017-04-01 18:08:09.076957 3 0 10001 +2015 679 4 2017-04-01 10:09:21.482117 2017-04-01 14:08:33.949068 3 0 10001 +2014 679 3 2017-04-01 06:09:36.580751 2017-04-01 10:08:53.306731 3 0 10001 +2013 679 2 2017-04-01 02:09:55.99245 2017-04-01 06:09:14.256276 3 0 10001 +2012 679 1 2017-03-31 22:10:17.950678 2017-04-01 02:09:29.877319 3 0 10001 +2011 679 0 2017-03-31 18:10:47.952129 2017-03-31 22:09:56.29638 3 0 10001 +2010 678 0 2017-03-31 18:07:28.359413 2017-03-31 18:09:17.729191 3 0 64 +2009 677 0 2017-03-31 18:01:28.029569 2017-03-31 18:02:04.528285 0 0 6 +2008 676 0 2017-03-31 17:53:36.760108 2017-03-31 17:54:20.598159 0 0 12 +2007 675 0 2017-03-31 17:51:37.871094 2017-03-31 17:52:13.287185 0 0 15 +2006 674 0 2017-03-31 17:33:01.933478 2017-03-31 17:44:47.888253 0 0 455 +2005 673 1 2017-03-31 16:13:41.731677 2017-03-31 17:20:51.127946 3 0 2791 +2004 673 0 2017-03-31 12:14:34.329468 2017-03-31 16:13:19.279824 3 0 10001 +2003 672 0 2017-03-31 08:10:47.071953 2017-03-31 12:11:06.656302 4 0 540 +2002 671 9 2017-03-31 04:10:10.668862 2017-03-31 08:05:35.636911 3 0 6215 +2001 671 8 2017-03-31 00:10:35.529218 2017-03-31 04:09:42.60863 3 0 10001 +2000 671 7 2017-03-30 20:10:55.519761 2017-03-31 00:10:08.328159 3 0 10001 +1999 671 6 2017-03-30 16:11:09.618587 2017-03-30 20:10:29.414961 3 0 10001 +1998 671 5 2017-03-30 12:11:29.198079 2017-03-30 16:10:46.967515 3 0 10001 +1997 671 4 2017-03-30 08:11:34.310479 2017-03-30 12:11:05.922808 3 0 10001 +1996 671 3 2017-03-30 04:12:05.171196 2017-03-30 08:11:12.21038 3 0 10001 +1995 671 2 2017-03-30 00:12:15.811572 2017-03-30 04:11:39.170423 3 0 10001 +1994 671 1 2017-03-29 20:12:19.881456 2017-03-30 00:11:52.647738 3 0 10001 +1993 671 0 2017-03-29 16:12:27.897911 2017-03-29 20:11:53.783719 3 0 10001 +1992 670 16 2017-03-29 16:03:20.741139 2017-03-29 16:04:39.335781 3 0 32 +1991 670 15 2017-03-29 12:03:30.620088 2017-03-29 16:02:53.446383 3 0 10001 +1990 670 14 2017-03-29 08:03:50.019547 2017-03-29 12:03:08.52532 3 0 10001 +1989 670 13 2017-03-29 04:04:16.508845 2017-03-29 08:03:28.307653 3 0 10001 +1988 670 12 2017-03-29 00:04:41.209105 2017-03-29 04:03:53.929325 3 0 10001 +1987 670 11 2017-03-28 20:05:07.298491 2017-03-29 00:04:18.972739 3 0 10001 +1986 670 10 2017-03-28 16:05:35.010122 2017-03-28 20:04:44.734406 3 0 10001 +1985 670 9 2017-03-28 11:46:17.920709 2017-03-28 16:05:06.98507 3 0 10001 +1984 670 8 2017-03-28 07:44:07.769135 2017-03-28 11:45:56.273404 3 0 10001 +1983 670 7 2017-03-28 03:44:28.793128 2017-03-28 07:43:45.026231 3 0 10001 +1982 670 6 2017-03-27 23:44:51.477462 2017-03-28 03:44:04.275983 3 0 10001 +1981 670 5 2017-03-27 19:45:24.550281 2017-03-27 23:44:28.038162 3 0 10001 +1980 670 4 2017-03-27 15:45:55.347603 2017-03-27 19:45:03.658248 3 0 10001 +1979 670 3 2017-03-27 11:50:35.171495 2017-03-27 15:45:33.224714 3 0 10001 +1978 670 2 2017-03-27 07:53:59.707462 2017-03-27 11:50:12.239848 3 0 10001 +1977 670 1 2017-03-27 03:54:23.999489 2017-03-27 07:53:37.370151 3 0 10001 +1976 670 0 2017-03-26 23:54:47.426338 2017-03-27 03:54:00.773724 3 0 10001 +1975 669 13 2017-03-26 20:42:21.971382 2017-03-26 23:50:52.33975 3 0 7870 +1974 669 12 2017-03-26 16:42:41.877926 2017-03-26 20:42:00.347039 3 0 10001 +1973 669 11 2017-03-26 12:42:59.922776 2017-03-26 16:42:19.134218 3 0 10001 +1972 669 10 2017-03-26 08:43:09.572178 2017-03-26 12:42:33.459045 3 0 10001 +1971 669 9 2017-03-26 04:43:28.586016 2017-03-26 08:42:47.982298 3 0 10001 +1970 669 8 2017-03-26 00:43:43.611909 2017-03-26 04:43:02.714125 3 0 10001 +1969 669 7 2017-03-25 20:44:09.289364 2017-03-26 00:43:21.319944 3 0 10001 +1968 669 6 2017-03-25 16:44:42.241198 2017-03-25 20:43:47.435363 3 0 10001 +1967 669 5 2017-03-25 12:45:04.179841 2017-03-25 16:44:18.64492 3 0 10001 +1966 669 4 2017-03-25 08:45:22.831863 2017-03-25 12:44:40.856094 3 0 10001 +1965 669 3 2017-03-25 04:45:46.238128 2017-03-25 08:45:00.344623 3 0 10001 +1964 669 2 2017-03-25 00:49:03.668358 2017-03-25 04:45:22.62519 3 0 10001 +1963 669 1 2017-03-24 20:12:28.730688 2017-03-25 00:48:40.924191 3 0 10001 +1962 669 0 2017-03-24 16:12:44.600756 2017-03-24 20:12:06.556166 3 0 10001 +1961 668 11 2017-03-24 12:36:19.826819 2017-03-24 16:09:16.923946 3 0 8995 +1960 668 10 2017-03-24 08:42:51.328674 2017-03-24 12:35:52.608575 3 0 10001 +1959 668 9 2017-03-24 04:42:54.480346 2017-03-24 08:42:28.943669 3 0 10001 +1958 668 8 2017-03-24 00:43:07.312287 2017-03-24 04:42:30.717896 3 0 10001 +1957 668 7 2017-03-23 20:43:09.089345 2017-03-24 00:42:45.064513 3 0 10001 +1956 668 6 2017-03-23 16:43:24.991272 2017-03-23 20:42:46.637241 3 0 10001 +1955 668 5 2017-03-23 12:35:56.819159 2017-03-23 16:43:03.824548 3 0 10001 +1954 668 4 2017-03-23 08:42:24.752101 2017-03-23 12:35:34.66415 3 0 10001 +1953 668 3 2017-03-23 04:42:55.630351 2017-03-23 08:42:01.403953 3 0 10001 +1952 668 2 2017-03-23 00:43:04.309487 2017-03-23 04:42:33.587973 3 0 10001 +1951 668 1 2017-03-22 20:43:26.328697 2017-03-23 00:42:42.737997 3 0 10001 +1950 668 0 2017-03-22 16:43:44.720367 2017-03-22 20:43:01.555448 3 0 10001 +1949 667 0 2017-03-22 16:14:14.321109 0 0 +1948 666 0 2017-03-22 16:05:53.450318 2017-03-22 16:06:28.709081 0 0 6 +1947 665 0 2017-03-22 15:53:55.350943 0 0 +1946 664 0 2017-03-22 15:53:00.039946 0 0 +1945 663 0 2017-03-22 15:44:36.180798 0 0 +1944 662 0 2017-03-22 15:11:10.230038 0 0 +1943 661 0 2017-03-22 15:08:52.029197 0 0 +1942 660 0 2017-03-22 14:46:03.269831 0 0 +1941 659 0 2017-03-22 11:17:25.12935 2017-03-22 11:25:43.76747 0 0 608 +1940 658 0 2017-03-22 11:07:47.259114 2017-03-22 11:12:30.029365 0 0 325 +1939 657 0 2017-03-22 09:13:59.679506 2017-03-22 09:15:36.584557 0 0 28 +1938 656 0 2017-03-22 09:10:05.391345 0 0 +1937 655 9 2017-03-22 07:24:03.020345 2017-03-22 09:00:24.787806 3 0 4021 +1936 655 8 2017-03-22 03:24:28.008454 2017-03-22 07:23:40.167159 3 0 10001 +1935 655 7 2017-03-21 23:24:45.814183 2017-03-22 03:24:01.811736 3 0 10001 +1934 655 6 2017-03-21 19:25:15.550175 2017-03-21 23:24:23.596761 3 0 10001 +1933 655 5 2017-03-21 15:25:45.879399 2017-03-21 19:24:53.861515 3 0 10001 +1932 655 4 2017-03-21 11:24:17.630439 2017-03-21 15:25:23.637068 3 0 10001 +1931 655 3 2017-03-21 07:24:28.309629 2017-03-21 11:23:53.436266 3 0 10001 +1930 655 2 2017-03-21 03:25:01.030243 2017-03-21 07:24:05.529377 3 0 10001 +1929 655 1 2017-03-20 23:25:17.17896 2017-03-21 03:24:38.114436 3 0 10001 +1928 655 0 2017-03-20 19:25:35.550322 2017-03-20 23:24:54.495281 3 0 10001 +1927 654 1 2017-03-20 16:09:40.938328 2017-03-20 19:11:01.915339 3 0 7379 +1926 654 0 2017-03-20 12:10:37.911116 2017-03-20 16:09:17.225087 3 0 10001 +1925 653 27 2017-03-20 03:38:05.018293 2017-03-20 10:56:48.413553 3 0 4997 +1924 653 26 2017-03-19 23:38:21.880956 2017-03-20 03:37:38.924337 3 0 10001 +1923 653 25 2017-03-19 19:38:28.848463 2017-03-19 23:37:55.817628 3 0 10001 +1922 653 24 2017-03-19 15:34:04.551464 2017-03-19 19:38:05.001928 3 0 10001 +1921 653 23 2017-03-19 11:34:13.358132 2017-03-19 15:33:38.092029 3 0 10001 +1920 653 22 2017-03-19 07:34:28.31135 2017-03-19 11:33:48.172306 3 0 10001 +1919 653 21 2017-03-19 03:34:43.56833 2017-03-19 07:34:06.756042 3 0 10001 +1918 653 20 2017-03-18 23:34:51.892813 2017-03-19 03:34:21.111113 3 0 10001 +1917 653 19 2017-03-18 19:35:12.978336 2017-03-18 23:34:31.305891 3 0 10001 +1916 653 18 2017-03-18 15:35:18.861725 2017-03-18 19:34:49.14791 3 0 10001 +1915 653 17 2017-03-18 11:35:37.017979 2017-03-18 15:34:53.340711 3 0 10001 +1914 653 16 2017-03-18 07:35:57.659525 2017-03-18 11:35:11.304454 3 0 10001 +1913 653 15 2017-03-18 03:36:17.788776 2017-03-18 07:35:34.495658 3 0 10001 +1912 653 14 2017-03-17 23:36:30.448604 2017-03-18 03:35:54.101223 3 0 10001 +1911 653 13 2017-03-17 19:36:53.24861 2017-03-17 23:36:09.809121 3 0 10001 +1910 653 12 2017-03-17 15:37:11.268514 2017-03-17 19:36:30.700748 3 0 10001 +1909 653 11 2017-03-17 11:37:27.277447 2017-03-17 15:36:48.273531 3 0 10001 +1908 653 10 2017-03-17 07:37:53.791563 2017-03-17 11:37:00.36867 3 0 10001 +1907 653 9 2017-03-17 03:38:13.917184 2017-03-17 07:37:29.624866 3 0 10001 +1906 653 8 2017-03-16 23:38:17.738006 2017-03-17 03:37:51.887544 3 0 10001 +1905 653 7 2017-03-16 19:38:25.570777 2017-03-16 23:37:52.019108 3 0 10001 +1904 653 6 2017-03-16 15:37:19.976375 2017-03-16 19:38:01.911323 3 0 10001 +1903 653 5 2017-03-16 11:37:24.328413 2017-03-16 15:36:56.585176 3 0 10001 +1902 653 4 2017-03-16 07:37:48.257882 2017-03-16 11:37:01.167339 3 0 10001 +1901 653 3 2017-03-16 03:38:06.049414 2017-03-16 07:37:26.651489 3 0 10001 +1900 653 2 2017-03-15 23:38:14.948747 2017-03-16 03:37:43.906408 3 0 10001 +1899 653 1 2017-03-15 19:38:32.969672 2017-03-15 23:37:49.319551 3 0 10001 +1898 653 0 2017-03-15 15:38:31.486928 2017-03-15 19:38:12.369125 3 0 10001 +1897 652 6 2017-03-15 13:58:26.069235 2017-03-15 14:04:57.304346 3 0 257 +1896 652 5 2017-03-15 10:06:33.618127 2017-03-15 13:58:02.873086 3 0 10001 +1895 652 4 2017-03-15 06:09:09.578322 2017-03-15 10:06:03.259508 3 0 10001 +1894 652 3 2017-03-15 02:09:31.501687 2017-03-15 06:08:47.787182 3 0 10001 +1893 652 2 2017-03-14 21:54:32.368647 2017-03-15 02:09:07.506664 3 0 10001 +1892 652 1 2017-03-14 17:54:59.209614 2017-03-14 21:54:10.384076 3 0 10001 +1891 652 0 2017-03-14 13:57:57.899065 2017-03-14 17:54:37.655548 3 0 10001 +1890 651 0 2017-03-14 12:06:08.6702 2017-03-14 12:30:26.37131 3 0 1002 +1889 650 34 2017-03-14 08:56:14.420466 2017-03-14 11:56:06.223215 3 0 7513 +1888 650 33 2017-03-14 04:56:40.084178 2017-03-14 08:55:52.14693 3 0 10001 +1887 650 32 2017-03-14 00:57:00.117782 2017-03-14 04:56:14.204775 3 0 10001 +1886 650 31 2017-03-13 20:52:27.427811 2017-03-14 00:56:38.471601 3 0 10001 +1885 650 30 2017-03-13 16:52:44.738596 2017-03-13 20:52:04.993695 3 0 10001 +1884 650 29 2017-03-13 12:37:49.612177 2017-03-13 16:52:19.262669 3 0 10001 +1883 650 28 2017-03-13 08:38:17.72995 2017-03-13 12:37:27.899842 3 0 10001 +1882 650 27 2017-03-13 04:38:43.250831 2017-03-13 08:37:54.602711 3 0 10001 +1881 650 26 2017-03-13 00:39:01.606862 2017-03-13 04:38:21.098932 3 0 10001 +1880 650 25 2017-03-12 20:39:20.447319 2017-03-13 00:38:39.336402 3 0 10001 +1879 650 24 2017-03-12 16:39:44.737003 2017-03-12 20:38:58.14684 3 0 10001 +1878 650 23 2017-03-12 12:26:24.580288 2017-03-12 16:39:22.479751 3 0 10001 +1877 650 22 2017-03-12 08:26:39.330636 2017-03-12 12:26:01.689972 3 0 10001 +1876 650 21 2017-03-12 04:27:04.043674 2017-03-12 08:26:17.222603 3 0 10001 +1875 650 20 2017-03-11 23:43:52.627041 2017-03-12 04:26:41.345272 3 0 10001 +1874 650 19 2017-03-11 20:44:36.660011 2017-03-11 23:43:30.126086 3 0 10001 +1873 650 18 2017-03-11 17:45:18.708138 2017-03-11 20:44:14.060163 3 0 10001 +1872 650 17 2017-03-11 14:31:27.677701 2017-03-11 17:44:55.90771 3 0 10001 +1871 650 16 2017-03-11 10:29:12.630384 2017-03-11 14:31:05.40259 3 0 10001 +1870 650 15 2017-03-11 06:29:37.71812 2017-03-11 10:28:50.365807 3 0 10001 +1869 650 14 2017-03-11 02:29:51.871113 2017-03-11 06:29:15.135912 3 0 10001 +1868 650 13 2017-03-10 22:22:12.268029 2017-03-11 02:29:29.784253 3 0 10001 +1867 650 12 2017-03-10 18:22:32.06866 2017-03-10 22:21:49.748716 3 0 10001 +1866 650 11 2017-03-10 14:19:39.469193 2017-03-10 18:22:09.744454 3 0 10001 +1865 650 10 2017-03-10 10:05:31.097823 2017-03-10 14:19:16.563249 3 0 10001 +1864 650 9 2017-03-10 05:59:14.712951 2017-03-10 10:05:08.370807 3 0 10001 +1863 650 8 2017-03-10 01:59:39.307169 2017-03-10 05:58:51.955893 3 0 10001 +1862 650 7 2017-03-09 22:00:04.336657 2017-03-10 01:59:16.702097 3 0 10001 +1861 650 6 2017-03-09 18:00:31.569231 2017-03-09 21:59:41.913942 3 0 10001 +1860 650 5 2017-03-09 12:46:43.338403 2017-03-09 18:00:09.022751 3 0 10001 +1859 650 4 2017-03-09 08:47:20.191136 2017-03-09 12:46:20.678888 3 0 10001 +1858 650 3 2017-03-09 04:47:39.78321 2017-03-09 08:46:57.795393 3 0 10001 +1857 650 2 2017-03-09 00:47:58.860466 2017-03-09 04:47:17.843409 3 0 10001 +1856 650 1 2017-03-08 20:46:36.268694 2017-03-09 00:47:36.366157 3 0 10001 +1855 650 0 2017-03-08 16:21:57.058423 2017-03-08 20:46:13.82619 3 0 10001 +1854 649 3 2017-03-08 14:01:28.37518 2017-03-08 15:48:36.294682 5 0 9678 +1853 649 2 2017-03-08 12:10:29.845442 2017-03-08 14:01:06.379464 5 0 10001 +1852 649 1 2017-03-08 10:19:21.247317 2017-03-08 12:10:08.129945 5 0 10001 +1851 649 0 2017-03-08 08:28:07.4291 2017-03-08 10:18:59.157043 5 0 10001 +1850 648 0 2017-03-07 17:06:34.918678 2017-03-08 07:59:05.425059 4 0 1657 +1849 647 3 2017-03-07 15:05:13.508554 2017-03-07 15:44:39.516359 5 0 3543 +1848 647 2 2017-03-07 13:14:01.008585 2017-03-07 15:04:51.633619 5 0 10001 +1847 647 1 2017-03-07 11:22:52.887195 2017-03-07 13:13:39.316968 5 0 10001 +1846 647 0 2017-03-07 09:31:48.736498 2017-03-07 11:22:31.129976 5 0 10001 +1845 646 0 2017-03-06 18:15:30.239205 2017-03-07 09:06:44.862955 4 0 2135 +1844 645 1 2017-03-06 18:04:16.670589 2017-03-06 18:08:57.730272 1 0 386 +1843 645 0 2017-03-06 16:05:09.044733 2017-03-06 18:03:54.471421 1 0 10001 +1842 644 3 2017-03-06 14:57:09.27818 2017-03-06 15:50:28.368197 5 0 4805 +1841 644 2 2017-03-06 13:06:09.106142 2017-03-06 14:56:45.665125 5 0 10001 +1840 644 1 2017-03-06 11:15:14.109424 2017-03-06 13:05:44.354482 5 0 10001 +1839 644 0 2017-03-06 09:24:05.567039 2017-03-06 11:14:44.766774 5 0 10001 +1838 643 0 2017-03-06 08:53:53.60881 2017-03-06 09:09:08.627354 1 0 1350 +1837 642 0 2017-03-04 13:43:53.527665 2017-03-06 08:51:58.216144 4 0 5858 +1836 641 0 2017-03-03 16:21:44.419479 2017-03-04 12:35:58.297072 4 0 2624 +1835 640 3 2017-03-03 14:36:01.246164 2017-03-03 15:51:36.932427 5 0 6813 +1834 640 2 2017-03-03 12:44:51.756343 2017-03-03 14:35:38.30612 5 0 10001 +1833 640 1 2017-03-03 10:53:52.727374 2017-03-03 12:44:29.200725 5 0 10001 +1832 640 0 2017-03-03 09:02:42.847779 2017-03-03 10:53:25.836381 5 0 10001 +1831 639 0 2017-03-02 16:20:02.979588 2017-03-03 08:43:49.466554 4 0 2203 +1830 638 4 2017-03-02 15:33:10.676909 2017-03-02 15:52:05.393648 5 0 1690 +1829 638 3 2017-03-02 13:42:10.709702 2017-03-02 15:32:48.827924 5 0 10001 +1828 638 2 2017-03-02 11:51:06.611074 2017-03-02 13:41:49.231378 5 0 10001 +1827 638 1 2017-03-02 10:00:06.519684 2017-03-02 11:50:44.776223 5 0 10001 +1826 638 0 2017-03-02 08:08:59.277899 2017-03-02 09:59:45.26502 5 0 10001 +1825 637 0 2017-03-01 15:58:49.240134 2017-03-02 07:56:29.604041 4 0 2200 +1824 636 2 2017-03-01 15:38:54.357164 2017-03-01 15:41:44.717683 5 0 203 +1823 636 1 2017-03-01 13:47:34.419687 2017-03-01 15:38:29.27875 5 0 10001 +1822 636 0 2017-03-01 11:56:31.918951 2017-03-01 13:47:11.425882 5 0 10001 +1821 635 0 2017-03-01 10:05:37.297606 2017-03-01 10:17:05.079518 1 0 1009 +1820 634 0 2017-02-28 18:52:27.808783 2017-03-01 09:18:52.795874 4 0 2036 +1819 633 0 2017-02-28 17:45:24.386896 2017-02-28 18:50:27.363133 1 0 4754 +1818 632 0 2017-02-27 15:43:54.347822 2017-02-28 11:42:19.252609 4 0 3556 +1817 631 3 2017-02-27 14:43:28.949744 2017-02-27 15:42:20.822624 1 0 5315 +1816 631 2 2017-02-27 12:52:28.295837 2017-02-27 14:43:05.092674 1 0 10001 +1815 631 1 2017-02-27 11:01:23.138229 2017-02-27 12:52:02.633183 1 0 10001 +1814 631 0 2017-02-27 09:10:20.218138 2017-02-27 11:00:59.493514 1 0 10001 +1813 630 67 2017-02-27 04:15:56.142894 2017-02-27 09:01:56.057315 3 0 8008 +1812 630 66 2017-02-27 00:16:16.799042 2017-02-27 04:15:33.991773 3 0 10001 +1811 630 65 2017-02-26 20:16:46.691941 2017-02-27 00:15:52.514397 3 0 10001 +1810 630 64 2017-02-26 16:17:13.742337 2017-02-26 20:16:22.320992 3 0 10001 +1809 630 63 2017-02-26 12:02:12.507451 2017-02-26 16:16:49.774923 3 0 10001 +1808 630 62 2017-02-26 08:02:40.536883 2017-02-26 12:01:49.868389 3 0 10001 +1807 630 61 2017-02-26 04:03:09.491895 2017-02-26 08:02:19.07192 3 0 10001 +1806 630 60 2017-02-26 00:03:35.516523 2017-02-26 04:02:47.193462 3 0 10001 +1805 630 59 2017-02-25 20:03:50.717669 2017-02-26 00:03:08.120626 3 0 10001 +1804 630 58 2017-02-25 16:04:01.210087 2017-02-25 20:03:29.275054 3 0 10001 +1803 630 57 2017-02-25 12:04:13.559501 2017-02-25 16:03:35.506941 3 0 10001 +1802 630 56 2017-02-25 08:04:33.547728 2017-02-25 12:03:51.792488 3 0 10001 +1801 630 55 2017-02-25 04:05:00.555497 2017-02-25 08:04:10.753505 3 0 10001 +1800 630 54 2017-02-25 00:05:25.201862 2017-02-25 04:04:32.121487 3 0 10001 +1799 630 53 2017-02-24 20:05:46.374594 2017-02-25 00:05:01.316384 3 0 10001 +1798 630 52 2017-02-24 15:56:18.101386 2017-02-24 20:05:23.175376 3 0 10001 +1797 630 51 2017-02-24 11:25:08.974511 2017-02-24 15:55:56.449148 3 0 10001 +1796 630 50 2017-02-24 07:14:27.081181 2017-02-24 11:24:45.295716 3 0 10001 +1795 630 49 2017-02-24 03:14:51.698608 2017-02-24 07:14:02.942388 3 0 10001 +1794 630 48 2017-02-23 23:15:44.962061 2017-02-24 03:14:27.373818 3 0 10001 +1793 630 47 2017-02-23 19:16:07.989047 2017-02-23 23:15:22.5521 3 0 10001 +1792 630 46 2017-02-23 15:14:07.887495 2017-02-23 19:15:42.422561 3 0 10001 +1791 630 45 2017-02-23 10:42:21.012427 2017-02-23 15:13:44.988151 3 0 10001 +1790 630 44 2017-02-23 06:24:47.925046 2017-02-23 10:42:00.317793 3 0 10001 +1789 630 43 2017-02-23 01:37:48.491889 2017-02-23 06:24:26.116417 3 0 10001 +1788 630 42 2017-02-22 21:38:08.575011 2017-02-23 01:37:23.817642 3 0 10001 +1787 630 41 2017-02-22 17:38:30.781897 2017-02-22 21:37:47.157058 3 0 10001 +1786 630 40 2017-02-22 13:40:12.645999 2017-02-22 17:38:07.236463 3 0 10001 +1785 630 39 2017-02-22 09:45:24.605156 2017-02-22 13:39:50.098797 3 0 10001 +1784 630 38 2017-02-22 05:45:53.467897 2017-02-22 09:45:03.148226 3 0 10001 +1783 630 37 2017-02-22 01:46:22.57583 2017-02-22 05:45:31.88827 3 0 10001 +1782 630 36 2017-02-21 21:46:37.887296 2017-02-22 01:45:57.717351 3 0 10001 +1781 630 35 2017-02-21 17:47:03.117563 2017-02-21 21:46:11.274404 3 0 10001 +1780 630 34 2017-02-21 13:47:15.957855 2017-02-21 17:46:38.400244 3 0 10001 +1779 630 33 2017-02-21 09:48:04.396996 2017-02-21 13:46:48.186235 3 0 10001 +1778 630 32 2017-02-21 05:48:33.387599 2017-02-21 09:47:39.984667 3 0 10001 +1777 630 31 2017-02-21 01:48:57.365622 2017-02-21 05:48:10.878791 3 0 10001 +1776 630 30 2017-02-20 21:49:18.115834 2017-02-21 01:48:31.722172 3 0 10001 +1775 630 29 2017-02-20 17:49:48.127117 2017-02-20 21:48:55.368452 3 0 10001 +1774 630 28 2017-02-20 13:50:14.326933 2017-02-20 17:49:23.809235 3 0 10001 +1773 630 27 2017-02-20 09:09:02.938623 2017-02-20 13:49:52.348675 3 0 10001 +1772 630 26 2017-02-20 05:35:31.021867 2017-02-20 09:08:38.804044 3 0 10001 +1771 630 25 2017-02-20 01:35:56.210066 2017-02-20 05:35:09.467647 3 0 10001 +1770 630 24 2017-02-19 21:36:04.726194 2017-02-20 01:35:28.691458 3 0 10001 +1769 630 23 2017-02-19 17:36:18.216378 2017-02-19 21:35:40.35372 3 0 10001 +1768 630 22 2017-02-19 13:36:31.88903 2017-02-19 17:35:50.820741 3 0 10001 +1767 630 21 2017-02-19 09:36:53.060473 2017-02-19 13:36:08.031856 3 0 10001 +1766 630 20 2017-02-19 05:37:13.151021 2017-02-19 09:36:31.577153 3 0 10001 +1765 630 19 2017-02-19 00:59:50.975832 2017-02-19 05:36:49.854271 3 0 10001 +1764 630 18 2017-02-18 21:00:09.679687 2017-02-19 00:59:27.315581 3 0 10001 +1763 630 17 2017-02-18 17:00:36.675072 2017-02-18 20:59:44.127316 3 0 10001 +1762 630 16 2017-02-18 13:00:56.785462 2017-02-18 17:00:10.83503 3 0 10001 +1761 630 15 2017-02-18 09:01:19.670114 2017-02-18 13:00:30.394546 3 0 10001 +1760 630 14 2017-02-18 05:01:30.6915 2017-02-18 09:00:52.748792 3 0 10001 +1759 630 13 2017-02-18 01:02:00.790585 2017-02-18 05:01:09.321335 3 0 10001 +1758 630 12 2017-02-17 21:02:22.771886 2017-02-18 01:01:36.562235 3 0 10001 +1757 630 11 2017-02-17 17:02:34.816631 2017-02-17 21:01:59.798856 3 0 10001 +1756 630 10 2017-02-17 13:02:58.556125 2017-02-17 17:02:10.440245 3 0 10001 +1755 630 9 2017-02-17 06:19:01.230445 2017-02-17 13:02:32.55329 3 0 10001 +1754 630 8 2017-02-17 02:17:37.615776 2017-02-17 06:18:34.604518 3 0 10001 +1753 630 7 2017-02-16 21:51:00.707919 2017-02-17 02:17:14.213234 3 0 10001 +1752 630 6 2017-02-16 16:08:59.450467 2017-02-16 21:50:35.466081 3 0 10001 +1751 630 5 2017-02-16 12:10:43.3902 2017-02-16 16:08:37.537541 3 0 10001 +1750 630 4 2017-02-16 08:13:50.445116 2017-02-16 12:10:21.673272 3 0 10001 +1749 630 3 2017-02-16 04:16:33.253047 2017-02-16 08:13:28.372949 3 0 10001 +1748 630 2 2017-02-16 00:20:00.218152 2017-02-16 04:16:07.268414 3 0 10001 +1747 630 1 2017-02-15 20:20:29.997939 2017-02-16 00:19:38.352029 3 0 10001 +1746 630 0 2017-02-15 15:46:20.294281 2017-02-15 20:20:04.019427 3 0 10001 +1745 629 2 2017-02-15 08:19:17.008353 2017-02-15 09:00:39.352281 3 0 1716 +1744 629 1 2017-02-15 03:11:26.682643 2017-02-15 08:18:53.734057 3 0 10001 +1743 629 0 2017-02-14 21:08:50.771621 2017-02-15 03:10:59.932704 3 0 10001 +1742 628 4 2017-02-14 21:06:54.135698 2017-02-14 21:07:21.04462 3 0 9 +1741 628 3 2017-02-14 21:05:11.817824 2017-02-14 21:06:31.063588 3 0 35 +1740 628 2 2017-02-14 21:04:21.689527 2017-02-14 21:04:54.790014 3 0 11 +1739 628 1 2017-02-14 21:02:55.746858 2017-02-14 21:03:47.885083 3 0 17 +1738 628 0 2017-02-14 21:01:43.788204 2017-02-14 21:02:30.281758 3 0 20 +1737 627 0 2017-02-14 20:58:31.529876 2017-02-14 20:59:44.408594 3 0 4 +1736 626 2 2017-02-14 17:56:40.626131 2017-02-14 20:54:39.662054 3 0 7438 +1735 626 1 2017-02-14 13:53:26.760857 2017-02-14 17:56:14.680631 3 0 10001 +1734 626 0 2017-02-14 09:21:33.837873 2017-02-14 13:53:01.942056 3 0 10001 +1733 625 0 2017-02-14 09:17:47.607214 2017-02-14 09:18:54.902651 3 0 31 +1732 624 0 2017-02-14 09:04:58.27624 2017-02-14 09:12:48.372315 3 0 280 +1731 623 14 2017-02-14 08:32:38.834535 2017-02-14 08:52:17.092918 3 0 805 +1730 623 13 2017-02-14 04:33:01.186512 2017-02-14 08:32:13.259435 3 0 10001 +1729 623 12 2017-02-14 00:33:24.479242 2017-02-14 04:32:37.803842 3 0 10001 +1728 623 11 2017-02-13 20:33:45.217026 2017-02-14 00:33:01.275479 3 0 10001 +1727 623 10 2017-02-13 16:31:30.984741 2017-02-13 20:33:22.560425 3 0 10001 +1726 623 9 2017-02-13 12:11:58.475596 2017-02-13 16:31:09.384679 3 0 10001 +1725 623 8 2017-02-13 08:12:21.96551 2017-02-13 12:11:36.057272 3 0 10001 +1724 623 7 2017-02-13 04:12:50.749946 2017-02-13 08:11:58.615177 3 0 10001 +1723 623 6 2017-02-13 00:13:17.702924 2017-02-13 04:12:28.009009 3 0 10001 +1722 623 5 2017-02-12 20:13:41.718482 2017-02-13 00:12:54.888455 3 0 10001 +1721 623 4 2017-02-12 16:13:59.804291 2017-02-12 20:13:19.266953 3 0 10001 +1720 623 3 2017-02-12 12:14:15.737052 2017-02-12 16:13:35.789365 3 0 10001 +1719 623 2 2017-02-12 08:14:27.53501 2017-02-12 12:13:52.032996 3 0 10001 +1718 623 1 2017-02-12 04:14:51.636481 2017-02-12 08:14:05.392909 3 0 10001 +1717 623 0 2017-02-12 00:15:21.017426 2017-02-12 04:14:28.821559 3 0 10001 +1716 622 26 2017-02-11 20:22:45.013889 2017-02-12 00:11:17.574701 3 0 9548 +1715 622 25 2017-02-11 16:22:54.610404 2017-02-11 20:22:22.509066 3 0 10001 +1714 622 24 2017-02-11 12:23:17.585012 2017-02-11 16:22:32.984839 3 0 10001 +1713 622 23 2017-02-11 08:23:37.807854 2017-02-11 12:22:51.955069 3 0 10001 +1712 622 22 2017-02-11 04:23:51.681578 2017-02-11 08:23:15.027243 3 0 10001 +1711 622 21 2017-02-11 00:24:22.335894 2017-02-11 04:23:29.376167 3 0 10001 +1710 622 20 2017-02-10 20:24:46.568153 2017-02-11 00:24:00.613182 3 0 10001 +1709 622 19 2017-02-10 16:25:42.494042 2017-02-10 20:24:23.455806 3 0 10001 +1708 622 18 2017-02-10 12:26:43.0996 2017-02-10 16:25:14.51948 3 0 10001 +1707 622 17 2017-02-10 08:28:49.464184 2017-02-10 12:26:15.684821 3 0 10001 +1706 622 16 2017-02-10 04:29:09.336818 2017-02-10 08:28:26.999493 3 0 10001 +1705 622 15 2017-02-10 00:29:34.248814 2017-02-10 04:28:46.58374 3 0 10001 +1704 622 14 2017-02-09 20:30:02.551265 2017-02-10 00:29:09.363413 3 0 10001 +1703 622 13 2017-02-09 16:30:18.704502 2017-02-09 20:29:36.145889 3 0 10001 +1702 622 12 2017-02-09 12:30:33.335477 2017-02-09 16:29:51.354664 3 0 10001 +1701 622 11 2017-02-09 08:30:58.438271 2017-02-09 12:30:08.16704 3 0 10001 +1700 622 10 2017-02-09 04:31:20.008234 2017-02-09 08:30:34.486881 3 0 10001 +1699 622 9 2017-02-09 00:31:44.115331 2017-02-09 04:30:54.083577 3 0 10001 +1698 622 8 2017-02-08 20:32:01.184789 2017-02-09 00:31:22.576105 3 0 10001 +1697 622 7 2017-02-08 16:32:31.004779 2017-02-08 20:31:38.388545 3 0 10001 +1696 622 6 2017-02-08 12:35:41.857113 2017-02-08 16:32:04.267798 3 0 10001 +1695 622 5 2017-02-08 08:44:59.602479 2017-02-08 12:35:14.649083 3 0 10001 +1694 622 4 2017-02-08 04:45:24.006934 2017-02-08 08:44:31.959634 3 0 10001 +1693 622 3 2017-02-08 00:45:37.865432 2017-02-08 04:45:00.03167 3 0 10001 +1692 622 2 2017-02-07 20:45:55.892295 2017-02-08 00:45:16.391321 3 0 10001 +1691 622 1 2017-02-07 16:46:17.933815 2017-02-07 20:45:27.288161 3 0 10001 +1690 622 0 2017-02-07 10:52:51.46514 2017-02-07 16:45:55.898643 3 0 10001 +1689 621 5 2017-02-07 07:34:16.627934 2017-02-07 10:42:48.943286 3 0 4518 +1688 621 4 2017-02-07 03:34:38.617002 2017-02-07 07:33:48.313462 3 0 10001 +1687 621 3 2017-02-06 23:35:02.579461 2017-02-07 03:34:16.910669 3 0 10001 +1686 621 2 2017-02-06 19:35:30.603406 2017-02-06 23:34:42.072718 3 0 10001 +1685 621 1 2017-02-06 15:35:56.484577 2017-02-06 19:35:08.66193 3 0 10001 +1684 621 0 2017-02-06 11:36:15.834466 2017-02-06 15:35:30.452851 3 0 10001 +1683 620 3 2017-02-06 08:19:21.525943 2017-02-06 08:44:37.233965 3 0 1043 +1682 620 2 2017-02-06 04:19:46.526924 2017-02-06 08:18:55.02893 3 0 10001 +1681 620 1 2017-02-06 00:26:53.642833 2017-02-06 04:19:25.168746 3 0 10001 +1680 620 0 2017-02-05 20:27:17.366741 2017-02-06 00:26:31.159593 3 0 10001 +1679 619 0 2017-02-05 20:20:11.53691 2017-02-05 20:21:26.032843 3 0 31 +1678 618 0 2017-02-05 20:15:46.99835 2017-02-05 20:16:04.878189 3 0 3 +1677 617 0 2017-02-05 20:12:55.085939 3 0 +1676 616 0 2017-02-05 20:05:28.7981 3 0 +1675 615 0 2017-02-05 20:03:24.017392 3 0 +1674 614 0 2017-02-05 20:01:51.65058 3 0 +1673 613 0 2017-02-05 19:59:00.408143 2017-02-05 20:00:12.235355 3 0 40 +1672 612 0 2017-02-05 19:46:47.353615 2017-02-05 19:49:59.621778 3 0 123 +1671 611 0 2017-02-05 19:07:59.014743 2017-02-05 19:25:47.989098 3 0 731 +1670 610 1 2017-02-05 18:26:03.696868 2017-02-05 18:55:07.730702 3 0 1200 +1669 610 0 2017-02-05 18:24:53.903486 2017-02-05 18:25:24.818812 3 0 6 +1668 609 0 2017-02-05 18:21:40.428243 2017-02-05 18:22:14.555874 3 0 8 +1667 608 0 2017-02-05 18:03:36.384633 2017-02-05 18:14:14.350094 3 0 427 +1666 607 3 2017-02-05 17:28:01.514757 2017-02-05 17:28:39.729715 3 0 17 +1665 607 2 2017-02-05 13:28:29.245628 2017-02-05 17:27:34.681606 3 0 10001 +1664 607 1 2017-02-05 09:29:00.752492 2017-02-05 13:28:03.110966 3 0 10001 +1663 607 0 2017-02-05 05:29:32.746306 2017-02-05 09:28:38.798696 3 0 10001 +1662 606 0 2017-02-05 05:27:08.173434 2017-02-05 05:28:08.628665 3 0 32 +1661 605 0 2017-02-05 05:17:38.597097 2017-02-05 05:18:36.95342 3 0 33 +1660 604 0 2017-02-05 05:13:11.642676 2017-02-05 05:14:04.733403 3 0 27 +1659 603 0 2017-02-05 05:08:55.723669 2017-02-05 05:10:54.573754 3 0 69 +1658 602 0 2017-02-05 05:06:37.984547 3 0 +1657 601 0 2017-02-05 05:03:08.857142 3 0 +1656 600 0 2017-02-05 05:01:28.794965 3 0 +1655 599 0 2017-02-05 04:58:54.634565 3 0 +1654 598 0 2017-02-05 04:53:51.124478 3 0 +1653 597 0 2017-02-05 04:51:25.084596 3 0 +1652 596 0 2017-02-05 04:45:12.567643 2017-02-05 04:45:58.644564 3 0 20 +1651 595 0 2017-02-05 04:38:19.7888 2017-02-05 04:40:24.028656 3 0 78 +1650 594 0 2017-02-05 02:49:01.124215 2017-02-05 02:50:00.093493 3 0 31 +1649 593 0 2017-02-05 02:47:27.717368 3 0 +1648 592 0 2017-02-05 02:44:44.884182 3 0 +1647 591 0 2017-02-05 02:42:37.533404 3 0 +1646 590 0 2017-02-05 02:40:30.414886 3 0 +1645 589 0 2017-02-05 02:38:43.254084 3 0 +1644 588 0 2017-02-05 02:31:57.394788 2017-02-05 02:32:45.225617 3 0 25 +1643 587 0 2017-02-05 02:28:45.355028 2017-02-05 02:29:36.587937 3 0 27 +1642 586 0 2017-02-05 02:24:50.483846 2017-02-05 02:25:53.037746 3 0 34 +1641 585 0 2017-02-05 02:21:36.093671 2017-02-05 02:22:35.020312 3 0 32 +1640 584 0 2017-02-05 02:15:42.993793 3 0 +1639 583 0 2017-02-05 02:06:54.973262 3 0 +1638 582 0 2017-02-05 02:00:07.318293 3 0 +1637 581 0 2017-02-05 01:59:30.153579 3 0 +1636 580 0 2017-02-05 01:59:19.812839 3 0 +1635 579 0 2017-02-05 01:15:11.517641 2017-02-05 01:16:10.619348 3 0 31 +1634 578 0 2017-02-05 01:12:23.706834 3 0 +1633 577 0 2017-02-05 01:10:13.986284 2017-02-05 01:11:10.282419 3 0 25 +1632 576 0 2017-02-05 01:09:12.325246 3 0 +1631 575 0 2017-02-05 01:04:22.843408 2017-02-05 01:04:58.650552 3 0 16 +1630 574 1 2017-02-05 00:53:56.842797 3 0 +1629 574 0 2017-02-05 00:50:15.76835 2017-02-05 00:51:07.365668 3 0 9 +1628 573 0 2017-02-05 00:46:52.093382 2017-02-05 00:47:25.28053 3 0 16 +1627 572 0 2017-02-05 00:42:36.50064 2017-02-05 00:43:12.445368 3 0 16 +1626 571 0 2017-02-05 00:40:55.845084 2017-02-05 00:41:29.383496 3 0 16 +1625 570 0 2017-02-05 00:28:34.364797 2017-02-05 00:29:13.662075 3 0 17 +1624 569 0 2017-02-05 00:20:11.57508 2017-02-05 00:20:52.412742 3 0 17 +1623 568 0 2017-02-05 00:14:04.635416 2017-02-05 00:14:50.528615 3 0 23 +1622 567 0 2017-02-05 00:07:57.146419 2017-02-05 00:08:40.114841 3 0 24 +1621 566 0 2017-02-05 00:00:32.416865 2017-02-05 00:01:12.132288 3 0 18 +1620 565 0 2017-02-04 23:59:03.48083 3 0 +1619 564 0 2017-02-04 23:55:21.223363 3 0 +1618 563 0 2017-02-04 23:52:02.97443 3 0 +1617 562 0 2017-02-04 23:50:17.569415 3 0 +1616 561 0 2017-02-04 23:48:35.303923 3 0 +1615 560 0 2017-02-04 23:45:22.894828 3 0 +1614 559 0 2017-02-04 23:35:15.03349 2017-02-04 23:35:57.943492 3 0 19 +1613 558 0 2017-02-04 23:28:10.813394 3 0 +1612 557 0 2017-02-04 23:27:16.727457 3 0 +1611 556 0 2017-02-04 23:23:59.703692 3 0 +1610 555 0 2017-02-04 23:22:03.330336 3 0 +1609 554 0 2017-02-04 23:19:26.80366 3 0 +1608 553 0 2017-02-04 23:17:19.213332 3 0 +1607 552 0 2017-02-04 23:15:35.683767 3 0 +1606 551 0 2017-02-04 23:14:02.797632 3 0 +1605 550 0 2017-02-04 23:09:24.172784 3 0 +1604 549 0 2017-02-04 23:01:50.327025 3 0 +1603 548 0 2017-02-04 22:59:33.664606 3 0 +1602 547 0 2017-02-04 22:51:56.400449 3 0 +1601 546 0 2017-02-04 22:48:59.04782 3 0 +1600 545 0 2017-02-04 22:45:29.120616 3 0 +1599 544 0 2017-02-04 22:42:41.184432 3 0 +1598 543 0 2017-02-04 22:41:37.903183 3 0 +1597 542 0 2017-02-04 22:29:40.603893 3 0 +1596 541 0 2017-02-04 21:41:11.27531 2017-02-04 22:26:24.592646 3 0 1887 +1595 540 0 2017-02-04 21:35:32.492505 2017-02-04 21:36:17.081961 3 0 18 +1594 539 0 2017-02-04 21:27:58.6503 2017-02-04 21:28:57.029399 3 0 31 +1593 538 0 2017-02-04 21:20:44.400099 3 0 +1592 537 0 2017-02-04 21:19:45.243236 2017-02-04 21:20:25.949788 3 0 9 +1591 536 0 2017-02-04 21:15:12.924754 2017-02-04 21:19:10.596253 3 0 58 +1590 535 0 2017-02-04 21:13:09.922907 2017-02-04 21:13:51.607524 3 0 20 +1589 534 0 2017-02-04 20:44:19.473106 2017-02-04 20:45:28.642887 3 0 41 +1588 533 0 2017-02-04 20:36:07.326129 2017-02-04 20:37:07.234462 3 0 36 +1587 532 0 2017-02-04 20:27:09.824415 2017-02-04 20:28:22.677299 3 0 32 +1586 531 0 2017-02-04 20:20:34.59535 2017-02-04 20:21:26.585631 3 0 26 +1585 530 0 2017-02-04 20:18:28.204193 3 0 +1584 529 0 2017-02-04 20:15:21.756184 3 0 +1583 528 0 2017-02-04 20:08:54.376911 3 0 +1582 527 0 2017-02-04 20:01:37.087312 3 0 +1581 526 0 2017-02-04 19:23:57.861111 2017-02-04 19:58:56.664833 3 0 1458 +1580 525 0 2017-02-04 18:58:28.453746 2017-02-04 19:09:48.316971 3 0 467 +1579 524 0 2017-02-04 18:55:21.97201 2017-02-04 18:56:18.036835 3 0 30 +1578 523 0 2017-02-04 17:32:01.588508 2017-02-04 18:46:47.818337 3 0 3117 +1577 522 0 2017-02-04 16:13:57.293617 2017-02-04 17:28:34.97961 3 0 3111 +1576 521 0 2017-02-04 02:50:55.776944 3 0 +1575 520 0 2017-02-04 00:55:30.752397 2017-02-04 02:06:11.180131 3 0 2946 +1574 519 0 2017-02-04 00:01:58.213034 2017-02-04 00:45:54.361751 3 0 1830 +1573 518 0 2017-02-03 23:42:08.251914 2017-02-04 00:00:33.668353 3 0 752 +1572 517 0 2017-02-03 23:24:45.601338 2017-02-03 23:34:54.240045 3 0 411 +1571 516 0 2017-02-03 23:09:23.582842 2017-02-03 23:19:33.750224 3 0 408 +1570 515 0 2017-02-03 22:42:47.702397 2017-02-03 22:52:56.481088 3 0 408 +1569 514 0 2017-02-03 22:23:41.124853 2017-02-03 22:33:43.499541 3 0 411 +1568 513 0 2017-02-03 22:06:46.412905 2017-02-03 22:17:02.192354 3 0 408 +1567 512 0 2017-02-03 22:02:40.742944 2017-02-03 22:03:13.309474 3 0 8 +1566 511 0 2017-02-03 21:58:17.21456 2017-02-03 21:58:39.857805 3 0 4 +1565 510 0 2017-02-03 21:56:19.155033 3 0 +1564 509 0 2017-02-03 21:54:28.179665 3 0 +1563 508 0 2017-02-03 21:52:27.499361 3 0 +1562 507 0 2017-02-03 21:52:02.381357 3 0 +1561 506 0 2017-02-03 21:47:16.109011 2017-02-03 21:47:55.232465 3 0 3 +1560 505 0 2017-02-03 21:43:34.024446 2017-02-03 21:44:34.474615 3 0 29 +1559 504 0 2017-02-03 21:38:14.024349 2017-02-03 21:38:53.671402 3 0 3 +1558 503 0 2017-02-03 21:20:34.473037 2017-02-03 21:20:59.641309 3 0 3 +1557 502 0 2017-02-03 21:16:47.6561 2017-02-03 21:17:07.748443 3 0 4 +1556 501 0 2017-02-03 21:10:55.806092 2017-02-03 21:11:25.109546 3 0 5 +1555 500 0 2017-02-03 21:03:51.337402 2017-02-03 21:04:19.599201 3 0 7 +1554 499 0 2017-02-03 20:55:30.682343 2017-02-03 20:56:04.928346 3 0 4 +1553 498 0 2017-02-03 20:50:52.292643 2017-02-03 20:51:37.799587 3 0 4 +1552 497 0 2017-02-03 20:46:36.282073 3 0 +1551 496 0 2017-02-03 20:44:42.297681 3 0 +1550 495 0 2017-02-03 20:44:05.755972 3 0 +1549 494 0 2017-02-03 20:36:43.379367 2017-02-03 20:37:08.994684 3 0 4 +1548 493 0 2017-02-03 20:32:33.084077 2017-02-03 20:33:12.890361 3 0 7 +1547 492 0 2017-02-03 20:28:48.932993 2017-02-03 20:29:45.019699 3 0 5 +1546 491 0 2017-02-03 20:28:36.982033 3 0 +1545 490 0 2017-02-03 19:50:55.612531 2017-02-03 19:51:28.099076 3 0 3 +1544 489 0 2017-02-03 19:43:59.704589 2017-02-03 19:44:36.009244 3 0 6 +1543 488 0 2017-02-03 18:53:14.022909 3 0 +1542 487 0 2017-02-03 18:39:07.333217 2017-02-03 18:49:20.361726 3 0 409 +1541 486 0 2017-02-03 18:35:05.772956 3 0 +1540 485 0 2017-02-03 18:30:44.8473 3 0 +1539 484 0 2017-02-03 18:26:35.399977 3 0 +1538 483 0 2017-02-03 18:24:43.890486 3 0 +1537 482 0 2017-02-03 18:21:56.403786 3 0 +1536 481 0 2017-02-03 18:21:05.68742 3 0 +1535 480 0 2017-02-03 18:19:33.714792 3 0 +1534 479 0 2017-02-03 17:54:55.271432 2017-02-03 18:05:13.610485 3 0 409 +1533 478 0 2017-02-03 16:55:32.355184 2017-02-03 17:46:32.850624 3 0 2122 +1532 477 3 2017-02-03 15:26:29.951972 2017-02-03 15:52:42.645472 1 0 2349 +1531 477 2 2017-02-03 13:35:23.90994 2017-02-03 15:26:02.430883 1 0 10001 +1530 477 1 2017-02-03 11:44:16.253137 2017-02-03 13:35:02.317295 1 0 10001 +1529 477 0 2017-02-03 09:53:01.833828 2017-02-03 11:43:52.569128 1 0 10001 +1528 476 1 2017-02-03 09:45:11.462031 2017-02-03 09:48:34.97177 1 0 275 +1527 476 0 2017-02-03 07:54:05.192482 2017-02-03 09:44:50.088505 1 0 10001 +1526 475 0 2017-02-03 00:53:27.191746 2017-02-03 00:55:25.856316 3 0 34 +1525 474 0 2017-02-03 00:51:53.033409 3 0 +1524 473 0 2017-02-03 00:49:38.904451 3 0 +1523 472 0 2017-02-03 00:48:20.795047 2017-02-03 00:49:08.659303 3 0 21 +1522 471 0 2017-02-03 00:46:47.40327 3 0 +1521 470 0 2017-02-03 00:45:34.943181 3 0 +1520 469 0 2017-02-03 00:40:09.934341 2017-02-03 00:40:57.968092 3 0 15 +1519 468 0 2017-02-03 00:31:07.334416 2017-02-03 00:33:03.735 3 0 68 +1518 467 0 2017-02-03 00:21:48.419981 3 0 +1517 466 0 2017-02-03 00:11:07.201488 3 0 +1516 465 0 2017-02-03 00:03:44.721043 3 0 +1515 464 0 2017-02-02 23:57:45.652263 3 0 +1514 463 0 2017-02-02 23:52:29.441469 3 0 +1513 462 0 2017-02-02 23:36:55.982383 3 0 +1512 461 0 2017-02-02 23:32:29.644792 3 0 +1511 460 0 2017-02-02 23:28:47.881166 2017-02-02 23:29:31.687912 3 0 0 +1510 459 0 2017-02-02 23:18:17.483721 2017-02-02 23:18:48.44948 3 0 0 +1509 458 0 2017-02-02 23:06:25.556388 2017-02-02 23:07:07.421711 3 0 0 +1508 457 0 2017-02-02 22:56:11.44617 3 0 +1507 456 0 2017-02-02 22:51:17.093924 3 0 +1506 455 0 2017-02-02 22:44:49.367141 2017-02-02 22:45:28.642074 3 0 0 +1505 454 0 2017-02-02 21:27:10.144232 2017-02-02 22:39:41.978766 3 0 3022 +1504 453 0 2017-02-02 16:20:37.358031 2017-02-02 20:22:44.138104 3 0 10001 +1503 452 4 2017-02-02 15:11:11.958559 2017-02-02 15:50:00.788698 1 0 3481 +1502 452 3 2017-02-02 13:19:50.835475 2017-02-02 15:10:49.881138 1 0 10001 +1501 452 2 2017-02-02 11:28:22.741189 2017-02-02 13:19:27.077521 1 0 10001 +1500 452 1 2017-02-02 09:36:56.71955 2017-02-02 11:27:57.339875 1 0 10001 +1499 452 0 2017-02-02 07:45:26.135264 2017-02-02 09:36:31.42114 1 0 10001 +1498 451 0 2017-02-02 01:02:49.534728 2017-02-02 01:03:20.487923 3 0 1 +1497 450 0 2017-02-02 00:57:12.925961 3 0 +1496 449 0 2017-02-02 00:48:27.717578 3 0 +1495 448 0 2017-02-02 00:43:37.972963 3 0 +1494 447 0 2017-02-02 00:40:17.742 3 0 +1493 446 0 2017-02-02 00:35:24.669858 3 0 +1492 445 0 2017-02-02 00:29:03.121283 3 0 +1491 444 0 2017-02-02 00:25:21.052654 2017-02-02 00:25:54.220547 3 0 0 +1490 443 0 2017-02-02 00:22:41.721746 2017-02-02 00:23:12.188731 3 0 0 +1489 442 0 2017-02-01 22:37:11.483626 2017-02-01 22:37:41.558189 3 0 0 +1488 441 0 2017-02-01 22:24:22.871211 2017-02-01 22:24:49.669877 3 0 0 +1487 440 0 2017-02-01 22:14:50.241927 3 0 +1486 439 0 2017-02-01 22:11:47.523399 2017-02-01 22:12:14.211057 3 0 0 +1485 438 0 2017-02-01 22:07:33.934348 2017-02-01 22:08:06.447957 3 0 0 +1484 437 0 2017-02-01 19:24:19.995998 2017-02-01 20:53:02.010346 3 0 3704 +1483 436 0 2017-02-01 15:59:51.088621 2017-02-01 19:18:07.638927 3 0 8416 +1482 435 4 2017-02-01 15:28:42.790964 2017-02-01 15:48:01.25133 1 0 1698 +1481 435 3 2017-02-01 13:36:39.552458 2017-02-01 15:28:17.578784 1 0 10001 +1480 435 2 2017-02-01 11:44:57.641578 2017-02-01 13:36:18.166178 1 0 10001 +1479 435 1 2017-02-01 09:53:33.592012 2017-02-01 11:44:36.060197 1 0 10001 +1478 435 0 2017-02-01 08:01:23.794706 2017-02-01 09:53:09.940101 1 0 10001 +1477 434 0 2017-02-01 06:43:58.851625 2017-02-01 06:44:58.857889 1 0 68 +1476 433 0 2017-02-01 00:53:36.442594 3 0 +1475 432 0 2017-02-01 00:49:11.635203 3 0 +1474 431 0 2017-02-01 00:41:25.901322 2017-02-01 00:41:55.619738 3 0 0 +1473 430 0 2017-02-01 00:35:44.031697 3 0 +1472 429 0 2017-02-01 00:30:30.20997 2017-02-01 00:30:58.998618 3 0 0 +1471 428 0 2017-02-01 00:23:24.182316 2017-02-01 00:23:59.731403 3 0 0 +1470 427 0 2017-01-31 20:57:56.251915 2017-01-31 22:04:31.120818 1 0 5999 +1469 426 0 2017-01-31 20:53:47.123295 2017-01-31 20:55:02.318688 1 0 79 +1468 425 0 2017-01-31 20:49:08.432097 2017-01-31 20:49:35.163163 1 0 0 +1467 424 0 2017-01-31 20:42:24.111002 2017-01-31 20:42:55.478577 1 0 0 +1466 423 0 2017-01-31 20:34:25.879593 2017-01-31 20:35:04.069185 1 0 0 +1465 422 0 2017-01-31 20:29:01.164112 2017-01-31 20:29:28.797395 1 0 0 +1464 421 0 2017-01-31 19:35:13.879032 2017-01-31 19:59:43.971632 1 0 0 +1463 420 0 2017-01-31 18:38:58.66437 2017-01-31 19:31:51.627968 1 0 0 +1462 419 0 2017-01-31 18:32:24.970342 2017-01-31 18:32:58.411397 1 0 0 +1461 418 0 2017-01-31 16:03:55.242445 2017-01-31 18:22:32.248936 3 0 5779 +1460 417 1 2017-01-31 15:39:12.471358 2017-01-31 15:46:18.64911 1 0 287 +1459 417 0 2017-01-31 11:23:26.633385 2017-01-31 15:38:49.418156 1 0 10001 +1458 416 0 2017-01-31 07:36:59.83304 2017-01-31 11:10:00.139167 1 0 9388 +1457 415 3 2017-01-31 05:46:00.581687 2017-01-31 07:16:01.119529 3 0 3755 +1456 415 2 2017-01-31 01:46:23.364685 2017-01-31 05:45:35.292489 3 0 10001 +1455 415 1 2017-01-30 21:46:33.474326 2017-01-31 01:46:01.264339 3 0 10001 +1454 415 0 2017-01-30 17:46:57.742016 2017-01-30 21:46:08.878583 3 0 10001 +1453 414 0 2017-01-30 17:42:03.891476 2017-01-30 17:42:34.389368 3 0 0 +1452 413 0 2017-01-30 17:38:01.846737 2017-01-30 17:38:45.267874 3 0 0 +1451 412 1 2017-01-30 15:12:11.601911 2017-01-30 16:22:27.448644 1 0 6266 +1450 412 0 2017-01-30 13:20:12.990991 2017-01-30 15:11:50.588458 1 0 10001 +1449 411 15 2017-01-30 09:55:13.901669 2017-01-30 11:42:27.184166 3 0 4480 +1448 411 14 2017-01-30 05:55:40.512358 2017-01-30 09:54:52.408473 3 0 10001 +1447 411 13 2017-01-30 01:56:02.824202 2017-01-30 05:55:15.314952 3 0 10001 +1446 411 12 2017-01-29 21:56:25.727367 2017-01-30 01:55:39.896852 3 0 10001 +1445 411 11 2017-01-29 17:55:36.070422 2017-01-29 21:55:59.041944 3 0 10001 +1444 411 10 2017-01-29 13:55:51.839945 2017-01-29 17:55:13.036357 3 0 10001 +1443 411 9 2017-01-29 09:55:59.610508 2017-01-29 13:55:29.620128 3 0 10001 +1442 411 8 2017-01-29 05:56:13.805534 2017-01-29 09:55:32.780791 3 0 10001 +1441 411 7 2017-01-29 01:56:22.459342 2017-01-29 05:55:50.887988 3 0 10001 +1440 411 6 2017-01-28 21:56:39.618392 2017-01-29 01:55:55.650427 3 0 10001 +1439 411 5 2017-01-28 17:56:58.359797 2017-01-28 21:56:14.249451 3 0 10001 +1438 411 4 2017-01-28 13:56:22.285308 2017-01-28 17:56:35.945293 3 0 10001 +1437 411 3 2017-01-28 09:56:44.410326 2017-01-28 13:55:58.058863 3 0 10001 +1436 411 2 2017-01-28 05:57:06.14919 2017-01-28 09:56:21.336183 3 0 10001 +1435 411 1 2017-01-28 01:57:37.172295 2017-01-28 05:56:44.059353 3 0 10001 +1434 411 0 2017-01-27 21:58:03.521231 2017-01-28 01:57:16.187782 3 0 10001 +1433 410 0 2017-01-27 21:22:10.99281 2017-01-27 21:54:02.607943 3 0 1037 +1432 409 0 2017-01-27 20:04:44.622063 2017-01-27 20:31:06.538561 3 0 1119 +1431 408 0 2017-01-27 19:49:35.372336 2017-01-27 19:53:12.337937 3 0 134 +1430 407 0 2017-01-27 19:18:13.726481 2017-01-27 19:27:43.168012 3 0 380 +1429 406 0 2017-01-27 19:13:28.90158 2017-01-27 19:14:27.234846 3 0 0 +1428 405 0 2017-01-27 18:59:43.980829 2017-01-27 19:02:05.171962 3 0 0 +1427 404 17 2017-01-27 16:13:51.432995 2017-01-27 18:18:16.595874 3 0 5077 +1426 404 16 2017-01-27 12:13:16.040424 2017-01-27 16:13:29.795312 3 0 10001 +1425 404 15 2017-01-27 08:13:46.396462 2017-01-27 12:12:53.704643 3 0 10001 +1424 404 14 2017-01-27 04:14:15.061825 2017-01-27 08:13:23.132844 3 0 10001 +1423 404 13 2017-01-27 00:14:30.780005 2017-01-27 04:13:50.304019 3 0 10001 +1422 404 12 2017-01-26 20:13:31.297826 2017-01-27 00:14:04.775471 3 0 10001 +1421 404 11 2017-01-26 16:13:44.32933 2017-01-26 20:13:05.1168 3 0 10001 +1420 404 10 2017-01-26 12:09:30.117844 2017-01-26 16:13:18.661024 3 0 10001 +1419 404 9 2017-01-26 08:09:54.949162 2017-01-26 12:09:06.655672 3 0 10001 +1418 404 8 2017-01-26 04:10:18.963249 2017-01-26 08:09:29.767215 3 0 10001 +1417 404 7 2017-01-26 00:10:28.369672 2017-01-26 04:09:54.77875 3 0 10001 +1416 404 6 2017-01-25 20:25:35.939974 2017-01-26 00:10:03.828837 3 0 10001 +1415 404 5 2017-01-25 16:36:28.438 2017-01-25 20:25:12.068692 3 0 10001 +1414 404 4 2017-01-25 12:37:24.848279 2017-01-25 16:36:02.047955 3 0 10001 +1413 404 3 2017-01-25 08:41:07.671901 2017-01-25 12:37:01.578137 3 0 10001 +1412 404 2 2017-01-25 04:42:26.502577 2017-01-25 08:40:41.989628 3 0 10001 +1411 404 1 2017-01-25 00:42:56.851696 2017-01-25 04:42:02.029901 3 0 10001 +1410 404 0 2017-01-24 20:46:52.09271 2017-01-25 00:42:36.337402 3 0 10001 +1409 403 0 2017-01-24 11:59:25.582215 2017-01-24 13:49:18.851462 3 0 4585 +1408 402 14 2017-01-24 06:54:24.611096 2017-01-24 10:45:21.079159 3 0 8623 +1407 402 13 2017-01-24 02:54:47.680902 2017-01-24 06:53:58.564957 3 0 10001 +1406 402 12 2017-01-23 22:58:44.743843 2017-01-24 02:54:25.178915 3 0 10001 +1405 402 11 2017-01-23 18:59:11.66715 2017-01-23 22:58:21.768163 3 0 10001 +1404 402 10 2017-01-23 15:00:52.217114 2017-01-23 18:58:49.784648 3 0 10001 +1403 402 9 2017-01-23 10:52:28.630085 2017-01-23 15:00:28.404598 3 0 10001 +1402 402 8 2017-01-23 06:52:05.324783 2017-01-23 10:52:05.307057 3 0 10001 +1401 402 7 2017-01-23 02:52:33.341229 2017-01-23 06:51:39.448606 3 0 10001 +1400 402 6 2017-01-22 22:52:42.985615 2017-01-23 02:52:07.268222 3 0 10001 +1399 402 5 2017-01-22 18:53:03.243993 2017-01-22 22:52:17.859936 3 0 10001 +1398 402 4 2017-01-22 14:53:27.989352 2017-01-22 18:52:38.950236 3 0 10001 +1397 402 3 2017-01-22 10:53:53.741785 2017-01-22 14:53:05.467722 3 0 10001 +1396 402 2 2017-01-22 06:47:59.863478 2017-01-22 10:53:28.248191 3 0 10001 +1395 402 1 2017-01-22 02:36:33.932421 2017-01-22 06:47:32.517852 3 0 10001 +1394 402 0 2017-01-21 22:39:59.134791 2017-01-22 02:36:11.182336 3 0 10001 +1393 401 13 2017-01-21 20:04:51.886514 2017-01-21 22:34:21.873952 3 0 6240 +1392 401 12 2017-01-21 16:05:13.574958 2017-01-21 20:04:29.464507 3 0 10001 +1391 401 11 2017-01-21 12:05:37.302291 2017-01-21 16:04:46.993355 3 0 10001 +1390 401 10 2017-01-21 08:06:05.99769 2017-01-21 12:05:15.294028 3 0 10001 +1389 401 9 2017-01-21 04:06:32.036873 2017-01-21 08:05:42.340791 3 0 10001 +1388 401 8 2017-01-21 00:06:58.67962 2017-01-21 04:06:10.954703 3 0 10001 +1387 401 7 2017-01-20 20:17:52.800837 2017-01-21 00:06:32.548437 3 0 10001 +1386 401 6 2017-01-20 16:18:19.712708 2017-01-20 20:17:31.458357 3 0 10001 +1385 401 5 2017-01-20 12:22:20.669183 2017-01-20 16:17:56.738995 3 0 10001 +1384 401 4 2017-01-20 08:22:35.668871 2017-01-20 12:21:57.572478 3 0 10001 +1383 401 3 2017-01-20 04:22:59.58021 2017-01-20 08:22:11.216431 3 0 10001 +1382 401 2 2017-01-20 00:23:27.760346 2017-01-20 04:22:36.537739 3 0 10001 +1381 401 1 2017-01-19 20:23:50.208847 2017-01-20 00:23:02.484133 3 0 10001 +1380 401 0 2017-01-19 16:24:10.721949 2017-01-19 20:23:28.331968 3 0 10001 +1379 400 38 2017-01-19 14:52:13.659141 2017-01-19 16:21:48.38734 3 0 3731 +1378 400 37 2017-01-19 10:52:30.5194 2017-01-19 14:51:48.03801 3 0 10001 +1377 400 36 2017-01-19 06:52:48.421909 2017-01-19 10:52:05.615715 3 0 10001 +1376 400 35 2017-01-19 02:53:02.356734 2017-01-19 06:52:22.912473 3 0 10001 +1375 400 34 2017-01-18 22:53:13.949805 2017-01-19 02:52:37.12742 3 0 10001 +1374 400 33 2017-01-18 18:53:44.388369 2017-01-18 22:52:51.263243 3 0 10001 +1373 400 32 2017-01-18 14:54:06.862068 2017-01-18 18:53:19.512836 3 0 10001 +1372 400 31 2017-01-18 10:57:03.28146 2017-01-18 14:53:41.155123 3 0 10001 +1371 400 30 2017-01-18 07:07:56.921607 2017-01-18 10:56:35.639243 3 0 10001 +1370 400 29 2017-01-18 03:24:53.2234 2017-01-18 07:07:33.061996 3 0 10001 +1369 400 28 2017-01-18 00:00:31.269902 2017-01-18 03:24:30.784845 3 0 10001 +1368 400 27 2017-01-17 20:17:34.470319 2017-01-18 00:00:08.05112 3 0 10001 +1367 400 26 2017-01-17 16:51:13.218686 2017-01-17 20:17:10.922911 3 0 10001 +1366 400 25 2017-01-17 13:26:13.360551 2017-01-17 16:50:47.006773 3 0 10001 +1365 400 24 2017-01-17 10:33:40.381141 2017-01-17 13:25:45.996786 3 0 10001 +1364 400 23 2017-01-17 07:46:16.581985 2017-01-17 10:33:12.255546 3 0 10001 +1363 400 22 2017-01-17 04:58:53.052547 2017-01-17 07:45:54.427057 3 0 10001 +1362 400 21 2017-01-17 01:24:03.081795 2017-01-17 04:58:31.749164 3 0 10001 +1361 400 20 2017-01-16 21:41:01.956697 2017-01-17 01:23:40.897901 3 0 10001 +1360 400 19 2017-01-16 17:58:08.95785 2017-01-16 21:40:40.66791 3 0 10001 +1359 400 18 2017-01-16 14:15:12.153547 2017-01-16 17:57:47.079371 3 0 10001 +1358 400 17 2017-01-16 10:32:18.988128 2017-01-16 14:14:46.258085 3 0 10001 +1357 400 16 2017-01-16 06:49:22.530252 2017-01-16 10:31:54.65776 3 0 10001 +1356 400 15 2017-01-16 03:06:20.276158 2017-01-16 06:48:59.286459 3 0 10001 +1355 400 14 2017-01-15 23:23:15.456985 2017-01-16 03:05:57.147736 3 0 10001 +1354 400 13 2017-01-15 19:40:23.417335 2017-01-15 23:22:54.2342 3 0 10001 +1353 400 12 2017-01-15 15:55:42.313074 2017-01-15 19:39:55.60878 3 0 10001 +1352 400 11 2017-01-15 12:00:41.509624 2017-01-15 15:55:18.795713 3 0 10001 +1351 400 10 2017-01-15 08:01:04.429072 2017-01-15 12:00:18.844476 3 0 10001 +1350 400 9 2017-01-15 04:01:28.332394 2017-01-15 08:00:41.202991 3 0 10001 +1349 400 8 2017-01-15 00:05:31.351826 2017-01-15 04:01:03.603393 3 0 10001 +1348 400 7 2017-01-14 20:05:56.170946 2017-01-15 00:05:09.4182 3 0 10001 +1347 400 6 2017-01-14 16:06:21.260947 2017-01-14 20:05:31.926744 3 0 10001 +1346 400 5 2017-01-14 12:06:44.21881 2017-01-14 16:05:57.826701 3 0 10001 +1345 400 4 2017-01-14 08:07:09.032091 2017-01-14 12:06:21.056356 3 0 10001 +1344 400 3 2017-01-14 04:07:31.050195 2017-01-14 08:06:44.867797 3 0 10001 +1343 400 2 2017-01-14 00:09:15.783009 2017-01-14 04:07:05.624007 3 0 10001 +1342 400 1 2017-01-13 20:09:36.887448 2017-01-14 00:08:50.579484 3 0 10001 +1341 400 0 2017-01-13 16:10:00.879216 2017-01-13 20:09:12.907742 3 0 10001 +1340 399 4 2017-01-13 14:50:15.66093 2017-01-13 15:48:20.575815 1 0 5198 +1339 399 3 2017-01-13 12:58:20.720664 2017-01-13 14:49:54.327709 1 0 10001 +1338 399 2 2017-01-13 11:06:23.294744 2017-01-13 12:57:55.010042 1 0 10001 +1337 399 1 2017-01-13 09:14:28.351583 2017-01-13 11:06:01.400418 1 0 10001 +1336 399 0 2017-01-13 07:22:34.585136 2017-01-13 09:14:06.106935 1 0 10001 +1335 398 5 2017-01-13 06:23:23.99097 2017-01-13 06:46:41.985448 3 0 1028 +1334 398 4 2017-01-13 02:35:51.027403 2017-01-13 06:23:00.759688 3 0 10001 +1333 398 3 2017-01-12 22:43:40.978835 2017-01-13 02:35:23.347408 3 0 10001 +1332 398 2 2017-01-12 18:47:40.047538 2017-01-12 22:43:19.695902 3 0 10001 +1331 398 1 2017-01-12 15:01:07.750706 2017-01-12 18:47:15.976177 3 0 10001 +1330 398 0 2017-01-12 11:01:34.850621 2017-01-12 15:00:44.726596 3 0 10001 +1329 397 10 2017-01-12 08:43:48.6991 2017-01-12 10:12:59.664798 2 0 8025 +1328 397 9 2017-01-12 06:52:27.717115 2017-01-12 08:43:27.988989 2 0 10001 +1327 397 8 2017-01-12 05:00:59.92709 2017-01-12 06:52:06.467998 2 0 10001 +1326 397 7 2017-01-12 03:09:42.499695 2017-01-12 05:00:36.705287 2 0 10001 +1325 397 6 2017-01-12 01:18:11.112953 2017-01-12 03:09:20.046862 2 0 10001 +1324 397 5 2017-01-11 23:26:47.807543 2017-01-12 01:17:44.633646 2 0 10001 +1323 397 4 2017-01-11 21:35:11.84113 2017-01-11 23:26:22.1763 2 0 10001 +1322 397 3 2017-01-11 19:43:29.289782 2017-01-11 21:34:46.277297 2 0 10001 +1321 397 2 2017-01-11 17:51:57.187051 2017-01-11 19:43:06.758449 2 0 10001 +1320 397 1 2017-01-11 16:00:17.149405 2017-01-11 17:51:31.322622 2 0 10001 +1319 397 0 2017-01-11 14:08:39.839238 2017-01-11 15:59:49.176809 2 0 10001 +1318 396 0 2017-01-10 16:19:05.360117 2017-01-11 14:05:43.067873 1 0 3192 +1317 395 0 2017-01-10 16:07:09.092306 2017-01-10 16:15:36.779336 2 0 729 +1316 394 1 2017-01-10 15:34:16.400025 2017-01-10 15:57:16.64602 1 0 1897 +1315 394 0 2017-01-10 13:34:14.205062 2017-01-10 15:33:53.128151 1 0 10001 +1314 393 1 2017-01-10 11:54:19.048756 2017-01-10 13:25:12.875374 1 0 7635 +1313 393 0 2017-01-10 09:54:32.530501 2017-01-10 11:53:53.760068 1 0 10001 +1312 392 2 2017-01-10 04:17:06.908191 2017-01-10 07:54:51.247793 3 0 497 +1311 392 1 2017-01-09 23:38:40.779955 2017-01-10 04:16:43.827592 3 0 10001 +1310 392 0 2017-01-09 19:00:15.917731 2017-01-09 23:38:18.28091 3 0 10001 +1309 391 25 2017-01-09 13:43:24.785648 2017-01-09 16:58:46.915329 3 0 7020 +1308 391 24 2017-01-09 09:04:56.098275 2017-01-09 13:42:59.647084 3 0 10001 +1307 391 23 2017-01-09 05:35:00.995433 2017-01-09 09:04:31.485574 3 0 10001 +1306 391 22 2017-01-09 01:52:10.597844 2017-01-09 05:34:39.035181 3 0 10001 +1305 391 21 2017-01-08 22:26:53.767476 2017-01-09 01:51:48.76179 3 0 10001 +1304 391 20 2017-01-08 18:43:58.04128 2017-01-08 22:26:31.878043 3 0 10001 +1303 391 19 2017-01-08 15:00:52.904029 2017-01-08 18:43:29.586698 3 0 10001 +1302 391 18 2017-01-08 11:18:01.858419 2017-01-08 15:00:27.803463 3 0 10001 +1301 391 17 2017-01-08 07:35:07.096339 2017-01-08 11:17:40.737364 3 0 10001 +1300 391 16 2017-01-08 03:52:10.016578 2017-01-08 07:34:45.740308 3 0 10001 +1299 391 15 2017-01-08 00:08:59.91105 2017-01-08 03:51:47.623049 3 0 10001 +1298 391 14 2017-01-07 20:25:57.756105 2017-01-08 00:08:32.476381 3 0 10001 +1297 391 13 2017-01-07 16:42:59.837264 2017-01-07 20:25:30.533267 3 0 10001 +1296 391 12 2017-01-07 13:00:09.581443 2017-01-07 16:42:38.308068 3 0 10001 +1295 391 11 2017-01-07 09:17:18.178298 2017-01-07 12:59:46.172302 3 0 10001 +1294 391 10 2017-01-07 05:57:07.67021 2017-01-07 09:16:52.737506 3 0 10001 +1293 391 9 2017-01-06 23:03:45.609377 2017-01-07 05:56:45.64678 3 0 10001 +1292 391 8 2017-01-06 19:20:53.626305 2017-01-06 23:03:22.873774 3 0 10001 +1291 391 7 2017-01-06 15:36:33.495305 2017-01-06 19:20:29.979332 3 0 10001 +1290 391 6 2017-01-06 11:52:54.567035 2017-01-06 15:36:11.14302 3 0 10001 +1289 391 5 2017-01-06 08:09:59.587092 2017-01-06 11:52:31.967671 3 0 10001 +1288 391 4 2017-01-06 04:27:05.339886 2017-01-06 08:09:31.602307 3 0 10001 +1287 391 3 2017-01-06 00:44:08.411117 2017-01-06 04:26:43.646288 3 0 10001 +1286 391 2 2017-01-05 21:01:16.416331 2017-01-06 00:43:45.916617 3 0 10001 +1285 391 1 2017-01-05 17:18:24.332553 2017-01-05 21:00:54.077123 3 0 10001 +1284 391 0 2017-01-05 13:35:29.250113 2017-01-05 17:18:03.605668 3 0 10001 +1283 390 13 2017-01-05 11:29:33.40619 2017-01-05 13:32:33.332874 3 0 5468 +1282 390 12 2017-01-05 07:46:06.431717 2017-01-05 11:29:10.571247 3 0 10001 +1281 390 11 2017-01-05 04:03:12.637342 2017-01-05 07:45:41.028518 3 0 10001 +1280 390 10 2017-01-05 00:20:12.016018 2017-01-05 04:02:48.479778 3 0 10001 +1279 390 9 2017-01-04 20:29:28.37062 2017-01-05 00:19:48.747297 3 0 10001 +1278 390 8 2017-01-04 16:45:54.179111 2017-01-04 20:28:59.893797 3 0 10001 +1277 390 7 2017-01-04 13:02:40.167934 2017-01-04 16:45:29.104774 3 0 10001 +1276 390 6 2017-01-04 09:19:42.721676 2017-01-04 13:02:18.647516 3 0 10001 +1275 390 5 2017-01-04 05:36:49.949607 2017-01-04 09:19:17.917901 3 0 10001 +1274 390 4 2017-01-04 01:53:58.551123 2017-01-04 05:36:26.942839 3 0 10001 +1273 390 3 2017-01-03 22:11:00.780026 2017-01-04 01:53:34.637095 3 0 10001 +1272 390 2 2017-01-03 18:28:10.730944 2017-01-03 22:10:37.783722 3 0 10001 +1271 390 1 2017-01-03 14:45:11.574425 2017-01-03 18:27:49.425121 3 0 10001 +1270 390 0 2017-01-03 10:41:41.079959 2017-01-03 14:44:44.73056 3 0 10001 +1269 389 38 2017-01-03 09:51:51.96708 2017-01-03 10:37:28.964308 3 0 1699 +1268 389 37 2017-01-03 06:09:01.132277 2017-01-03 09:51:29.567661 3 0 10001 +1267 389 36 2017-01-03 02:26:02.847187 2017-01-03 06:08:39.673367 3 0 10001 +1266 389 35 2017-01-02 22:43:08.033901 2017-01-03 02:25:36.64433 3 0 10001 +1265 389 34 2017-01-02 19:00:16.943295 2017-01-02 22:42:45.326011 3 0 10001 +1264 389 33 2017-01-02 15:17:26.000538 2017-01-02 18:59:53.562369 3 0 10001 +1263 389 32 2017-01-02 11:34:32.322536 2017-01-02 15:17:05.252422 3 0 10001 +1262 389 31 2017-01-02 07:51:26.601717 2017-01-02 11:34:06.942737 3 0 10001 +1261 389 30 2017-01-02 04:08:19.438216 2017-01-02 07:51:03.205694 3 0 10001 +1260 389 29 2017-01-02 00:25:26.213618 2017-01-02 04:07:54.083416 3 0 10001 +1259 389 28 2017-01-01 20:42:25.576518 2017-01-02 00:25:03.028009 3 0 10001 +1258 389 27 2017-01-01 16:59:30.381885 2017-01-01 20:42:03.821613 3 0 10001 +1257 389 26 2017-01-01 13:16:32.948638 2017-01-01 16:59:06.104873 3 0 10001 +1256 389 25 2017-01-01 09:33:36.864072 2017-01-01 13:16:09.48469 3 0 10001 +1255 389 24 2017-01-01 05:50:35.810904 2017-01-01 09:33:15.797903 3 0 10001 +1254 389 23 2017-01-01 02:07:37.245554 2017-01-01 05:50:10.14523 3 0 10001 +1253 389 22 2016-12-31 22:24:34.104513 2017-01-01 02:07:10.402832 3 0 10001 +1252 389 21 2016-12-31 18:41:41.19572 2016-12-31 22:24:11.211677 3 0 10001 +1251 389 20 2016-12-31 14:56:31.291818 2016-12-31 18:41:16.084819 3 0 10001 +1250 389 19 2016-12-31 11:13:31.212303 2016-12-31 14:56:08.596043 3 0 10001 +1249 389 18 2016-12-31 07:30:27.256567 2016-12-31 11:13:04.098318 3 0 10001 +1248 389 17 2016-12-31 03:47:28.271598 2016-12-31 07:30:03.09395 3 0 10001 +1247 389 16 2016-12-31 00:04:16.924193 2016-12-31 03:47:07.327894 3 0 10001 +1246 389 15 2016-12-30 20:21:17.431974 2016-12-31 00:03:53.261709 3 0 10001 +1245 389 14 2016-12-30 16:38:08.009952 2016-12-30 20:20:48.874794 3 0 10001 +1244 389 13 2016-12-30 12:55:09.627701 2016-12-30 16:37:42.142061 3 0 10001 +1243 389 12 2016-12-30 09:12:09.904409 2016-12-30 12:54:46.775856 3 0 10001 +1242 389 11 2016-12-30 05:29:11.30794 2016-12-30 09:11:47.381749 3 0 10001 +1241 389 10 2016-12-30 01:46:11.086706 2016-12-30 05:28:49.776355 3 0 10001 +1240 389 9 2016-12-29 22:03:11.025413 2016-12-30 01:45:48.920339 3 0 10001 +1239 389 8 2016-12-29 18:20:20.720882 2016-12-29 22:02:48.163155 3 0 10001 +1238 389 7 2016-12-29 14:37:08.498391 2016-12-29 18:19:56.883291 3 0 10001 +1237 389 6 2016-12-29 10:54:08.751922 2016-12-29 14:36:42.14524 3 0 10001 +1236 389 5 2016-12-29 07:11:12.061736 2016-12-29 10:53:43.210577 3 0 10001 +1235 389 4 2016-12-29 03:28:13.539507 2016-12-29 07:10:45.535957 3 0 10001 +1234 389 3 2016-12-28 23:45:17.689618 2016-12-29 03:27:49.746777 3 0 10001 +1233 389 2 2016-12-28 20:02:31.339452 2016-12-28 23:44:57.211191 3 0 10001 +1232 389 1 2016-12-28 16:19:22.564751 2016-12-28 20:02:10.221042 3 0 10001 +1231 389 0 2016-12-28 12:08:37.476617 2016-12-28 16:18:59.009839 3 0 10001 +1230 388 0 2016-12-28 10:20:40.94975 2016-12-28 12:06:17.511543 1 0 274 +1229 387 6 2016-12-28 07:39:19.977017 2016-12-28 10:17:38.704025 3 0 7109 +1228 387 5 2016-12-28 03:56:25.962909 2016-12-28 07:38:59.311731 3 0 10001 +1227 387 4 2016-12-28 00:13:31.624858 2016-12-28 03:55:58.936423 3 0 10001 +1226 387 3 2016-12-27 20:29:37.258631 2016-12-28 00:13:04.91964 3 0 10001 +1225 387 2 2016-12-27 16:46:37.271041 2016-12-27 20:29:15.645924 3 0 10001 +1224 387 1 2016-12-27 13:03:43.043089 2016-12-27 16:46:15.314979 3 0 10001 +1223 387 0 2016-12-27 09:20:52.217464 2016-12-27 13:03:20.991031 3 0 10001 +1222 386 37 2016-12-27 09:12:10.760117 2016-12-27 09:17:45.283685 3 0 238 +1221 386 36 2016-12-27 08:58:37.566659 2016-12-27 09:10:49.826005 3 0 534 +1220 386 35 2016-12-27 05:15:41.926625 2016-12-27 08:58:14.783719 3 0 10001 +1219 386 34 2016-12-27 01:32:29.588264 2016-12-27 05:15:17.912052 3 0 10001 +1218 386 33 2016-12-26 21:49:34.880616 2016-12-27 01:32:05.370844 3 0 10001 +1217 386 32 2016-12-26 18:06:37.30667 2016-12-26 21:49:09.973323 3 0 10001 +1216 386 31 2016-12-26 14:23:36.592226 2016-12-26 18:06:12.046051 3 0 10001 +1215 386 30 2016-12-26 10:37:18.26709 2016-12-26 14:23:10.483662 3 0 10001 +1214 386 29 2016-12-26 06:54:28.446489 2016-12-26 10:36:56.228264 3 0 10001 +1213 386 28 2016-12-26 03:11:33.473504 2016-12-26 06:54:07.217104 3 0 10001 +1212 386 27 2016-12-25 23:28:45.899378 2016-12-26 03:11:12.772546 3 0 10001 +1211 386 26 2016-12-25 19:45:54.634413 2016-12-25 23:28:20.99812 3 0 10001 +1210 386 25 2016-12-25 16:03:05.887857 2016-12-25 19:45:32.542868 3 0 10001 +1209 386 24 2016-12-25 12:20:09.123965 2016-12-25 16:02:41.776655 3 0 10001 +1208 386 23 2016-12-25 08:37:21.109278 2016-12-25 12:19:47.731718 3 0 10001 +1207 386 22 2016-12-25 04:54:28.795261 2016-12-25 08:36:56.205188 3 0 10001 +1206 386 21 2016-12-25 01:11:39.530028 2016-12-25 04:54:07.236416 3 0 10001 +1205 386 20 2016-12-24 21:28:39.97539 2016-12-25 01:11:12.638409 3 0 10001 +1204 386 19 2016-12-24 17:45:51.208333 2016-12-24 21:28:19.104883 3 0 10001 +1203 386 18 2016-12-24 14:03:00.988732 2016-12-24 17:45:25.841935 3 0 10001 +1202 386 17 2016-12-24 10:20:12.504549 2016-12-24 14:02:38.565334 3 0 10001 +1201 386 16 2016-12-24 06:37:17.805574 2016-12-24 10:19:46.384927 3 0 10001 +1200 386 15 2016-12-24 02:54:22.783648 2016-12-24 06:36:56.136857 3 0 10001 +1199 386 14 2016-12-23 23:11:22.578653 2016-12-24 02:53:56.417947 3 0 10001 +1198 386 13 2016-12-23 19:28:26.761306 2016-12-23 23:10:55.829266 3 0 10001 +1197 386 12 2016-12-23 15:45:27.782538 2016-12-23 19:28:01.297347 3 0 10001 +1196 386 11 2016-12-23 12:02:31.962562 2016-12-23 15:45:07.405965 3 0 10001 +1195 386 10 2016-12-23 08:19:29.592232 2016-12-23 12:02:04.995265 3 0 10001 +1194 386 9 2016-12-23 04:36:29.837401 2016-12-23 08:19:07.917987 3 0 10001 +1193 386 8 2016-12-23 00:53:29.765576 2016-12-23 04:36:07.206373 3 0 10001 +1192 386 7 2016-12-22 21:10:36.641989 2016-12-23 00:53:05.68512 3 0 10001 +1191 386 6 2016-12-22 17:27:36.74725 2016-12-22 21:10:14.843902 3 0 10001 +1190 386 5 2016-12-22 13:44:41.509419 2016-12-22 17:27:13.2377 3 0 10001 +1189 386 4 2016-12-22 10:01:11.660717 2016-12-22 13:44:18.286682 3 0 10001 +1188 386 3 2016-12-22 06:17:50.403309 2016-12-22 10:00:19.682226 3 0 10001 +1187 386 2 2016-12-22 02:34:56.571564 2016-12-22 06:17:29.205119 3 0 10001 +1186 386 1 2016-12-21 22:52:06.672245 2016-12-22 02:34:34.60109 3 0 10001 +1185 386 0 2016-12-21 19:08:55.646325 2016-12-21 22:51:44.703432 3 0 10001 +1184 385 0 2016-12-21 15:44:01.357261 2016-12-21 18:53:30.717184 3 0 8512 +1183 384 17 2016-12-21 11:51:12.612408 2016-12-21 14:53:15.027778 3 0 8095 +1182 384 16 2016-12-21 08:08:21.138091 2016-12-21 11:50:53.296133 3 0 10001 +1181 384 15 2016-12-21 04:25:32.594066 2016-12-21 08:07:59.01444 3 0 10001 +1180 384 14 2016-12-21 00:42:25.918692 2016-12-21 04:25:10.925809 3 0 10001 +1179 384 13 2016-12-20 20:59:13.59625 2016-12-21 00:42:02.604691 3 0 10001 +1178 384 12 2016-12-20 17:16:12.878779 2016-12-20 20:58:51.651909 3 0 10001 +1177 384 11 2016-12-20 13:33:00.594504 2016-12-20 17:15:51.026473 3 0 10001 +1176 384 10 2016-12-20 09:49:58.642124 2016-12-20 13:32:36.608184 3 0 10001 +1175 384 9 2016-12-20 06:06:54.606776 2016-12-20 09:49:32.443461 3 0 10001 +1174 384 8 2016-12-20 02:23:53.519914 2016-12-20 06:06:28.92519 3 0 10001 +1173 384 7 2016-12-19 22:41:02.806789 2016-12-20 02:23:29.783011 3 0 10001 +1172 384 6 2016-12-19 18:58:05.747964 2016-12-19 22:40:38.575706 3 0 10001 +1171 384 5 2016-12-19 15:15:08.099423 2016-12-19 18:57:43.890991 3 0 10001 +1170 384 4 2016-12-19 11:32:07.178095 2016-12-19 15:14:44.975051 3 0 10001 +1169 384 3 2016-12-19 07:49:09.093911 2016-12-19 11:31:44.272618 3 0 10001 +1168 384 2 2016-12-19 04:06:11.090216 2016-12-19 07:48:47.156823 3 0 10001 +1167 384 1 2016-12-19 00:23:15.167475 2016-12-19 04:05:48.003869 3 0 10001 +1166 384 0 2016-12-18 20:40:24.339611 2016-12-19 00:22:51.697196 3 0 10001 +1165 383 39 2016-12-18 19:05:45.489662 2016-12-18 20:37:09.029198 3 0 4098 +1164 383 38 2016-12-18 15:22:42.170588 2016-12-18 19:05:21.39131 3 0 10001 +1163 383 37 2016-12-18 11:39:45.418582 2016-12-18 15:22:18.51509 3 0 10001 +1162 383 36 2016-12-18 07:56:47.447056 2016-12-18 11:39:23.55423 3 0 10001 +1161 383 35 2016-12-18 04:13:47.653774 2016-12-18 07:56:25.023729 3 0 10001 +1160 383 34 2016-12-18 00:30:46.589157 2016-12-18 04:13:23.53181 3 0 10001 +1159 383 33 2016-12-17 20:47:45.118101 2016-12-18 00:30:23.407776 3 0 10001 +1158 383 32 2016-12-17 17:04:51.183981 2016-12-17 20:47:21.354781 3 0 10001 +1157 383 31 2016-12-17 13:21:49.425216 2016-12-17 17:04:28.0951 3 0 10001 +1156 383 30 2016-12-17 09:38:25.321778 2016-12-17 13:21:17.970882 3 0 10001 +1155 383 29 2016-12-17 05:55:06.855091 2016-12-17 09:37:58.009728 3 0 10001 +1154 383 28 2016-12-17 02:11:46.857528 2016-12-17 05:54:38.500697 3 0 10001 +1153 383 27 2016-12-16 22:27:51.76743 2016-12-17 02:11:18.686658 3 0 10001 +1152 383 26 2016-12-16 18:30:57.021925 2016-12-16 22:27:24.050442 3 0 10001 +1151 383 25 2016-12-16 14:47:44.277239 2016-12-16 18:30:27.703175 3 0 10001 +1150 383 24 2016-12-16 11:04:26.816813 2016-12-16 14:47:22.995616 3 0 10001 +1149 383 23 2016-12-16 07:21:10.727743 2016-12-16 11:03:59.291391 3 0 10001 +1148 383 22 2016-12-16 03:37:50.205808 2016-12-16 07:20:45.077781 3 0 10001 +1147 383 21 2016-12-15 23:54:28.017708 2016-12-16 03:37:22.110147 3 0 10001 +1146 383 20 2016-12-15 20:11:19.049492 2016-12-15 23:54:06.582088 3 0 10001 +1145 383 19 2016-12-15 16:28:06.618459 2016-12-15 20:10:57.245457 3 0 10001 +1144 383 18 2016-12-15 12:44:50.603742 2016-12-15 16:27:38.78895 3 0 10001 +1143 383 17 2016-12-15 09:01:25.751617 2016-12-15 12:44:24.425126 3 0 10001 +1142 383 16 2016-12-15 05:18:05.546574 2016-12-15 09:00:55.001268 3 0 10001 +1141 383 15 2016-12-15 01:34:49.584693 2016-12-15 05:17:36.63764 3 0 10001 +1140 383 14 2016-12-14 21:51:29.422076 2016-12-15 01:34:22.76624 3 0 10001 +1139 383 13 2016-12-14 18:08:03.676972 2016-12-14 21:51:02.868659 3 0 10001 +1138 383 12 2016-12-14 14:24:24.364945 2016-12-14 18:07:37.670134 3 0 10001 +1137 383 11 2016-12-14 10:40:53.548257 2016-12-14 14:23:56.385285 3 0 10001 +1136 383 10 2016-12-14 07:00:07.123415 2016-12-14 10:40:26.032968 3 0 10001 +1135 383 9 2016-12-14 02:23:16.959645 2016-12-14 06:59:36.658091 3 0 10001 +1134 383 8 2016-12-13 22:39:50.407906 2016-12-14 02:22:48.801804 3 0 10001 +1133 383 7 2016-12-13 18:56:33.595313 2016-12-13 22:39:27.314479 3 0 10001 +1132 383 6 2016-12-13 15:13:15.489582 2016-12-13 18:56:10.76538 3 0 10001 +1131 383 5 2016-12-13 11:29:56.728527 2016-12-13 15:12:43.820766 3 0 10001 +1130 383 4 2016-12-13 07:47:03.146833 2016-12-13 11:29:34.905619 3 0 10001 +1129 383 3 2016-12-13 04:03:49.402249 2016-12-13 07:46:36.829456 3 0 10001 +1128 383 2 2016-12-13 00:33:54.070331 2016-12-13 04:03:22.006913 3 0 10001 +1127 383 1 2016-12-12 20:50:37.154717 2016-12-13 00:33:28.476412 3 0 10001 +1126 383 0 2016-12-12 17:07:37.998211 2016-12-12 20:50:09.171914 3 0 10001 +1125 382 11 2016-12-12 12:20:29.984422 2016-12-12 15:47:43.003972 3 0 9284 +1124 382 10 2016-12-12 08:37:03.957767 2016-12-12 12:20:00.236373 3 0 10001 +1123 382 9 2016-12-12 04:53:39.041131 2016-12-12 08:36:33.544579 3 0 10001 +1122 382 8 2016-12-12 01:10:18.796731 2016-12-12 04:53:09.840771 3 0 10001 +1121 382 7 2016-12-11 21:27:02.82205 2016-12-12 01:09:51.489943 3 0 10001 +1120 382 6 2016-12-11 17:43:45.88982 2016-12-11 21:26:32.387105 3 0 10001 +1119 382 5 2016-12-11 14:00:44.26972 2016-12-11 17:43:15.303633 3 0 10001 +1118 382 4 2016-12-11 10:17:20.170907 2016-12-11 14:00:17.593726 3 0 10001 +1117 382 3 2016-12-11 06:34:03.885749 2016-12-11 10:16:53.159929 3 0 10001 +1116 382 2 2016-12-11 02:50:51.767487 2016-12-11 06:33:42.360158 3 0 10001 +1115 382 1 2016-12-10 23:07:46.76027 2016-12-11 02:50:25.918164 3 0 10001 +1114 382 0 2016-12-10 19:24:36.885391 2016-12-10 23:07:19.790486 3 0 10001 +1113 381 0 2016-12-09 19:58:09.426212 2016-12-10 19:22:30.948971 1 0 2566 +1112 380 0 2016-12-09 18:12:19.875559 2016-12-09 19:55:55.178789 3 0 4650 +1111 379 0 2016-12-05 18:49:32.518704 2016-12-06 12:27:05.399221 1 0 5278 +1110 378 0 2016-12-05 17:30:28.694433 2016-12-05 18:36:16.416573 1 0 289 +1109 377 0 2016-12-05 16:32:42.725915 3 0 +1108 376 18 2016-12-05 12:53:03.763206 2016-12-05 15:33:01.917616 3 0 6863 +1107 376 17 2016-12-05 09:10:54.518747 2016-12-05 12:52:37.173978 3 0 10001 +1106 376 16 2016-12-05 05:27:42.513819 2016-12-05 09:10:29.063774 3 0 10001 +1105 376 15 2016-12-05 01:44:21.624979 2016-12-05 05:27:13.689627 3 0 10001 +1104 376 14 2016-12-04 21:53:36.641644 2016-12-05 01:43:54.675467 3 0 10001 +1103 376 13 2016-12-04 17:53:58.614938 2016-12-04 21:53:05.357467 3 0 10001 +1102 376 12 2016-12-04 13:54:31.376956 2016-12-04 17:53:31.577433 3 0 10001 +1101 376 11 2016-12-04 09:57:16.876721 2016-12-04 13:54:01.647052 3 0 10001 +1100 376 10 2016-12-04 06:13:54.863478 2016-12-04 09:56:49.510843 3 0 10001 +1099 376 9 2016-12-04 02:30:35.545895 2016-12-04 06:13:23.267964 3 0 10001 +1098 376 8 2016-12-03 23:04:23.942957 2016-12-04 02:30:08.776486 3 0 10001 +1097 376 7 2016-12-03 19:04:19.829254 2016-12-03 23:03:54.328608 3 0 10001 +1096 376 6 2016-12-03 15:05:33.92617 2016-12-03 19:03:50.564159 3 0 10001 +1095 376 5 2016-12-03 11:05:36.805726 2016-12-03 15:05:07.555278 3 0 10001 +1094 376 4 2016-12-03 07:11:38.450308 2016-12-03 11:05:09.947145 3 0 10001 +1093 376 3 2016-12-03 03:32:17.627401 2016-12-03 07:11:12.484302 3 0 10001 +1092 376 2 2016-12-03 00:44:17.173218 2016-12-03 03:31:48.310748 3 0 10001 +1091 376 1 2016-12-02 21:56:29.680302 2016-12-03 00:43:50.243965 3 0 10001 +1090 376 0 2016-12-02 18:46:57.467885 2016-12-02 21:56:00.852484 3 0 10001 +1089 375 0 2016-12-02 18:22:21.887036 2016-12-02 18:23:46.997716 3 0 0 +1088 374 0 2016-12-02 16:47:18.104563 2016-12-02 16:50:20.370165 3 0 0 +1087 373 0 2016-12-02 16:29:17.098334 2016-12-02 16:36:35.390596 3 0 0 +1086 372 0 2016-12-02 13:36:00.342408 2016-12-02 15:29:29.911739 3 0 1777 +1085 371 4 2016-12-02 10:30:30.686109 2016-12-02 12:39:49.769622 3 0 6879 +1084 371 3 2016-12-02 04:44:32.858199 2016-12-02 10:30:01.899932 3 0 10001 +1083 371 2 2016-12-02 01:29:04.251303 2016-12-02 04:44:06.725324 3 0 10001 +1082 371 1 2016-12-01 22:12:53.75179 2016-12-02 01:28:37.008592 3 0 10001 +1081 371 0 2016-12-01 18:37:02.952903 2016-12-01 22:12:25.13299 3 0 10001 +1080 370 6 2016-12-01 16:29:58.072053 2016-12-01 17:56:58.534423 3 0 4042 +1079 370 5 2016-12-01 13:09:28.434483 2016-12-01 16:29:28.563751 3 0 10001 +1078 370 4 2016-12-01 10:07:58.676817 2016-12-01 13:09:05.69585 3 0 10001 +1077 370 3 2016-12-01 06:32:55.706851 2016-12-01 10:07:37.08875 3 0 10001 +1076 370 2 2016-12-01 02:49:26.535473 2016-12-01 06:32:25.556281 3 0 10001 +1075 370 1 2016-11-30 22:51:16.557138 2016-12-01 02:49:00.156984 3 0 10001 +1074 370 0 2016-11-30 18:53:23.515052 2016-11-30 22:50:46.993699 3 0 10001 +1073 369 3 2016-11-30 14:42:24.575753 2016-11-30 16:44:59.287622 3 0 5179 +1072 369 2 2016-11-30 11:01:14.296885 2016-11-30 14:41:57.559403 3 0 10001 +1071 369 1 2016-11-30 07:41:30.65646 2016-11-30 11:00:47.084353 3 0 10001 +1070 369 0 2016-11-30 03:58:08.124735 2016-11-30 07:41:03.201742 3 0 10001 +1069 368 10 2016-11-30 01:59:31.111792 2016-11-30 03:52:09.655099 3 0 5878 +1068 368 9 2016-11-29 22:24:10.391993 2016-11-30 01:59:09.646788 3 0 10001 +1067 368 8 2016-11-29 18:41:08.302639 2016-11-29 22:23:44.605119 3 0 10001 +1066 368 7 2016-11-29 14:57:44.936288 2016-11-29 18:40:42.375749 3 0 10001 +1065 368 6 2016-11-29 11:14:41.094924 2016-11-29 14:57:14.074603 3 0 10001 +1064 368 5 2016-11-29 07:37:46.711167 2016-11-29 11:14:19.530869 3 0 10001 +1063 368 4 2016-11-29 03:54:21.185905 2016-11-29 07:37:18.298901 3 0 10001 +1062 368 3 2016-11-29 00:11:15.502359 2016-11-29 03:53:54.22436 3 0 10001 +1061 368 2 2016-11-29 00:07:58.385719 2016-11-29 00:09:56.914587 3 0 75 +1060 368 1 2016-11-28 20:13:52.38449 2016-11-29 00:07:36.961077 3 0 10001 +1059 368 0 2016-11-28 16:14:11.247144 2016-11-28 20:13:29.661231 3 0 10001 +1058 367 10 2016-11-28 14:57:53.965276 2016-11-28 16:12:42.038742 3 0 3161 +1057 367 9 2016-11-28 11:05:52.965708 2016-11-28 14:57:22.644568 3 0 10001 +1056 367 8 2016-11-28 07:21:55.697197 2016-11-28 11:05:26.259539 3 0 10001 +1055 367 7 2016-11-28 03:38:44.165966 2016-11-28 07:21:34.213041 3 0 10001 +1054 367 6 2016-11-27 23:55:29.747366 2016-11-28 03:38:18.211367 3 0 10001 +1053 367 5 2016-11-27 20:12:08.850769 2016-11-27 23:55:00.684769 3 0 10001 +1052 367 4 2016-11-27 16:28:43.801864 2016-11-27 20:11:39.766708 3 0 10001 +1051 367 3 2016-11-27 12:45:31.780229 2016-11-27 16:28:22.149407 3 0 10001 +1050 367 2 2016-11-27 09:02:16.675397 2016-11-27 12:45:05.713514 3 0 10001 +1049 367 1 2016-11-27 05:18:54.63698 2016-11-27 09:01:50.288256 3 0 10001 +1048 367 0 2016-11-27 01:35:51.077453 2016-11-27 05:18:23.942145 3 0 10001 +1047 366 9 2016-11-26 23:49:18.636384 2016-11-27 01:33:21.268644 3 0 4652 +1046 366 8 2016-11-26 20:06:04.424413 2016-11-26 23:48:52.068013 3 0 10001 +1045 366 7 2016-11-26 16:14:59.241545 2016-11-26 20:05:34.948064 3 0 10001 +1044 366 6 2016-11-26 13:10:02.644229 2016-11-26 16:13:12.483873 3 0 9391 +1043 366 5 2016-11-26 09:44:27.395289 2016-11-26 13:09:31.500267 3 0 10001 +1042 366 4 2016-11-26 06:01:03.222008 2016-11-26 09:43:57.776276 3 0 10001 +1041 366 3 2016-11-26 02:17:51.915094 2016-11-26 06:00:41.820934 3 0 10001 +1040 366 2 2016-11-25 22:34:23.51594 2016-11-26 02:17:22.748066 3 0 10001 +1039 366 1 2016-11-25 18:51:11.244268 2016-11-25 22:34:01.923977 3 0 10001 +1038 366 0 2016-11-25 15:08:14.72516 2016-11-25 18:50:45.273892 3 0 10001 +1037 365 8 2016-11-25 11:34:13.331291 2016-11-25 14:55:37.654102 3 0 9033 +1036 365 7 2016-11-25 05:49:04.876039 2016-11-25 11:33:43.261594 3 0 10001 +1035 365 6 2016-11-25 02:05:38.14277 2016-11-25 05:48:34.648031 3 0 10001 +1034 365 5 2016-11-24 22:22:18.111583 2016-11-25 02:05:12.079699 3 0 10001 +1033 365 4 2016-11-24 18:38:59.013439 2016-11-24 22:21:52.044998 3 0 10001 +1032 365 3 2016-11-24 14:55:43.028569 2016-11-24 18:38:28.324636 3 0 10001 +1031 365 2 2016-11-24 11:12:39.284436 2016-11-24 14:55:16.574412 3 0 10001 +1030 365 1 2016-11-24 07:26:45.261994 2016-11-24 11:12:16.73277 3 0 10001 +1029 365 0 2016-11-24 03:43:51.4502 2016-11-24 07:26:23.719756 3 0 10001 +1028 364 0 2016-11-23 21:38:20.884118 2016-11-24 01:21:39.734713 3 0 10000 +1027 363 0 2016-11-23 17:47:31.38684 2016-11-23 21:30:50.692237 3 0 10000 +1026 362 0 2016-11-23 15:15:12.860672 2016-11-23 17:44:17.323403 3 0 6972 +1025 361 1 2016-11-23 12:24:13.416892 2016-11-23 15:12:50.084001 1 0 14280 +1024 361 0 2016-11-23 10:24:31.618438 2016-11-23 12:23:11.073747 1 0 10587 +1023 360 6 2016-11-22 21:43:11.731099 2016-11-23 09:58:21.286916 3 0 32908 +1022 360 5 2016-11-22 17:05:25.472471 2016-11-22 21:41:47.953642 3 0 11600 +1021 360 4 2016-11-22 14:16:48.244815 2016-11-22 17:04:38.546998 3 0 10044 +1020 360 3 2016-11-22 10:48:46.399652 2016-11-22 14:15:38.533721 3 0 10578 +1019 360 2 2016-11-21 23:54:02.164253 2016-11-22 10:47:57.047617 3 0 30761 +1018 360 1 2016-11-21 19:15:03.985124 2016-11-21 23:51:52.527157 3 0 12395 +1017 360 0 2016-11-21 15:22:25.360111 2016-11-21 19:14:21.687076 3 0 10091 +1016 359 1 2016-11-21 11:52:58.023387 2016-11-21 12:26:05.263592 3 0 1252 +1015 359 0 2016-11-20 23:47:32.074896 2016-11-21 11:52:10.671 3 0 26238 +1014 358 9 2016-11-20 21:33:09.267445 2016-11-20 23:45:40.343942 3 0 4758 +1013 358 8 2016-11-20 16:10:10.227642 2016-11-20 21:31:37.739997 3 0 11561 +1012 358 7 2016-11-20 11:29:20.767334 2016-11-20 16:07:37.342914 3 0 10009 +1011 358 6 2016-11-20 00:03:37.845658 2016-11-20 11:28:18.503731 3 0 24636 +1010 358 5 2016-11-19 22:25:21.344351 2016-11-20 00:02:50.042276 3 0 3496 +1009 358 4 2016-11-19 16:35:08.82189 2016-11-19 22:24:06.634806 3 0 12551 +1008 358 3 2016-11-19 11:44:17.66542 2016-11-19 16:34:18.456521 3 0 10426 +1007 358 2 2016-11-19 00:27:47.512476 2016-11-19 11:43:35.318672 3 0 24221 +1006 358 1 2016-11-18 22:05:43.013502 2016-11-19 00:27:09.721563 3 0 5052 +1005 358 0 2016-11-18 17:27:04.651881 2016-11-18 22:01:59.357828 3 0 9607 +1004 357 0 2016-11-18 13:55:00.058545 2016-11-18 16:05:15.878063 3 0 5041 +1003 356 1 2016-11-18 00:21:54.981384 2016-11-18 08:26:20.491073 3 0 17427 +1002 356 0 2016-11-17 19:44:42.575723 2016-11-18 00:21:03.99989 3 0 9729 +1001 355 0 2016-11-17 08:22:09.586978 2016-11-17 11:06:22.983577 3 0 7374 +1000 354 2 2016-11-17 00:04:35.918279 2016-11-17 08:14:57.403718 3 0 17835 +999 354 1 2016-11-16 22:38:28.495631 2016-11-17 00:03:43.122539 3 0 3064 +998 354 0 2016-11-16 17:46:28.891543 2016-11-16 22:37:50.194938 3 0 10478 +997 353 9 2016-11-16 15:45:45.269498 2016-11-16 16:05:05.101984 3 0 688 +996 353 8 2016-11-16 09:49:22.555857 2016-11-16 15:13:54.662379 3 0 14822 +995 353 7 2016-11-15 23:57:15.891992 2016-11-16 09:48:17.866692 3 0 22123 +994 353 6 2016-11-15 19:40:45.911355 2016-11-15 23:56:34.107965 3 0 9200 +993 353 5 2016-11-15 14:49:25.036786 2016-11-15 19:39:56.413348 3 0 10073 +992 353 4 2016-11-15 09:22:53.934595 2016-11-15 14:48:30.517523 3 0 12049 +991 353 3 2016-11-15 09:18:57.394807 2016-11-15 09:21:58.997538 3 0 134 +990 353 2 2016-11-14 23:58:45.454926 2016-11-15 08:48:28.057866 3 0 19494 +989 353 1 2016-11-14 21:42:36.326349 2016-11-14 23:57:47.092014 3 0 4853 +988 353 0 2016-11-14 17:34:20.374803 2016-11-14 21:40:50.675629 3 0 10007 +987 352 0 2016-11-14 17:29:09.876582 3 0 +986 351 1 2016-11-14 17:25:57.818415 3 0 +985 351 0 2016-11-14 13:19:07.212292 2016-11-14 17:22:22.272521 3 0 10198 +984 350 12 2016-11-14 09:16:08.546281 2016-11-14 13:14:28.437627 3 0 12722 +983 350 11 2016-11-13 21:12:55.986201 2016-11-14 09:13:12.493619 3 0 24830 +982 350 10 2016-11-13 15:29:44.8387 2016-11-13 20:56:06.112277 3 0 11047 +981 350 9 2016-11-13 10:32:07.340405 2016-11-13 15:17:52.492552 3 0 10242 +980 350 8 2016-11-12 22:12:42.447361 2016-11-13 10:31:13.748837 3 0 26567 +979 350 7 2016-11-12 17:29:57.567148 2016-11-12 22:11:44.10719 3 0 10124 +978 350 6 2016-11-12 12:41:40.191673 2016-11-12 17:29:00.110553 3 0 10026 +977 350 5 2016-11-12 07:52:12.313832 2016-11-12 12:38:54.756477 3 0 10225 +976 350 4 2016-11-11 21:20:36.674813 2016-11-12 07:51:11.001814 3 0 22676 +975 350 3 2016-11-11 13:16:27.060804 2016-11-11 21:19:13.075084 3 0 20013 +974 350 2 2016-11-11 08:24:46.522952 2016-11-11 13:14:16.251723 3 0 16327 +973 350 1 2016-11-10 23:45:18.335336 2016-11-11 08:23:55.247939 3 0 18141 +972 350 0 2016-11-10 21:07:54.159008 2016-11-10 23:44:17.061737 3 0 5450 +971 349 1 2016-11-10 19:39:29.088347 2016-11-10 20:57:27.82478 3 0 2709 +970 349 0 2016-11-10 17:01:40.834985 2016-11-10 19:38:29.758391 3 0 7514 +969 348 0 2016-11-10 16:43:40.873819 3 0 +968 347 0 2016-11-10 11:49:25.805305 2016-11-10 16:42:13.744965 1 0 26491 +967 346 0 2016-11-10 11:44:31.850243 1 0 +966 345 0 2016-11-10 10:05:02.836685 1 0 +965 344 0 2016-11-10 09:02:07.938506 1 0 +964 343 0 2016-11-10 08:49:42.754266 1 0 +963 342 1 2016-11-10 08:46:05.020346 1 0 +962 342 0 2016-11-10 06:22:08.442275 2016-11-10 08:45:01.581784 1 0 12934 +961 341 0 2016-11-10 06:18:52.452525 1 0 +960 340 1 2016-11-10 05:44:55.255494 2016-11-10 06:14:06.023376 3 0 1711 +959 340 0 2016-11-09 20:30:35.676588 2016-11-10 05:43:17.462294 3 0 32662 +958 339 2 2016-11-09 20:27:07.259202 3 0 +957 339 1 2016-11-09 14:41:11.097929 2016-11-09 20:26:17.727489 3 0 20504 +956 339 0 2016-11-09 10:58:29.35335 2016-11-09 14:40:14.163489 3 0 12384 +955 338 2 2016-11-09 07:44:54.36128 2016-11-09 08:13:21.597893 3 0 1436 +954 338 1 2016-11-08 21:44:00.468657 2016-11-09 07:32:45.655494 3 0 29369 +953 338 0 2016-11-08 16:14:17.819548 2016-11-08 21:42:58.402676 3 0 15649 +952 337 7 2016-11-08 10:09:44.93854 2016-11-08 16:09:27.176048 3 0 17465 +951 337 6 2016-11-08 05:34:33.997729 2016-11-08 10:08:49.446473 3 0 10964 +950 337 5 2016-11-07 21:12:24.614472 2016-11-08 05:33:43.927044 3 0 17243 +949 337 4 2016-11-07 15:50:51.344511 2016-11-07 21:04:27.9656 3 0 11062 +948 337 3 2016-11-07 07:03:54.561788 2016-11-07 15:49:50.49059 3 0 19432 +947 337 2 2016-11-06 22:44:42.352778 2016-11-07 07:02:53.32015 3 0 17927 +946 337 1 2016-11-06 18:03:15.228252 2016-11-06 22:44:06.664901 3 0 10750 +945 337 0 2016-11-06 14:58:38.805384 2016-11-06 18:02:32.349173 3 0 10091 +944 336 5 2016-11-06 12:20:55.379478 2016-11-06 14:35:51.563914 3 0 7412 +943 336 4 2016-11-06 09:05:01.001966 2016-11-06 12:17:45.354895 3 0 10436 +942 336 3 2016-11-06 00:19:37.328379 2016-11-06 09:03:29.730527 3 0 29859 +941 336 2 2016-11-05 18:06:29.77967 2016-11-06 00:18:45.844381 3 0 15457 +940 336 1 2016-11-05 13:56:14.233876 2016-11-05 18:05:47.643733 3 0 11891 +939 336 0 2016-11-05 09:50:59.703951 2016-11-05 13:54:40.468094 3 0 10231 +938 335 6 2016-11-04 22:47:44.047419 2016-11-05 09:47:13.953285 3 0 26384 +937 335 5 2016-11-04 19:33:09.911765 2016-11-04 22:46:02.901184 3 0 10326 +936 335 4 2016-11-04 15:38:54.718772 2016-11-04 19:31:40.671379 3 0 11314 +935 335 3 2016-11-04 11:54:57.059518 2016-11-04 15:37:58.244163 3 0 10626 +934 335 2 2016-11-04 07:40:31.692012 2016-11-04 11:04:00.361418 3 0 11203 +933 335 1 2016-11-03 20:37:31.06016 2016-11-04 07:39:55.811367 3 0 36421 +932 335 0 2016-11-03 16:31:10.436243 2016-11-03 20:36:43.128808 3 0 11639 +931 334 1 2016-11-03 14:55:37.584523 2016-11-03 16:23:28.577234 1 0 7958 +930 334 0 2016-11-03 12:52:33.072551 2016-11-03 14:50:53.769459 1 0 10721 +929 333 1 2016-11-03 12:42:20.622983 2016-11-03 12:43:05.042174 3 0 0 +928 333 0 2016-11-03 11:07:06.746423 2016-11-03 12:41:43.647608 3 0 0 +927 332 0 2016-11-03 10:55:31.789875 2016-11-03 11:02:53.923546 1 0 645 +926 331 0 2016-11-02 22:28:25.754529 3 0 +925 330 0 2016-11-02 22:22:51.331107 3 0 +924 329 6 2016-11-02 22:16:12.894973 3 0 +923 329 5 2016-11-02 16:53:35.288879 2016-11-02 22:15:15.695794 3 0 17345 +922 329 4 2016-11-02 12:18:20.351697 2016-11-02 16:52:47.675993 3 0 12805 +921 329 3 2016-11-02 07:23:16.175993 2016-11-02 12:17:20.539341 3 0 11004 +920 329 2 2016-11-01 20:31:29.022523 2016-11-02 07:20:25.081046 3 0 31020 +919 329 1 2016-11-01 16:16:54.148951 2016-11-01 20:30:55.089303 3 0 10007 +918 329 0 2016-11-01 11:56:30.804214 2016-11-01 16:16:14.220748 3 0 10424 +917 328 4 2016-11-01 11:42:38.881919 3 0 +916 328 3 2016-11-01 06:45:59.0593 2016-11-01 11:36:31.357261 3 0 10451 +915 328 2 2016-10-31 22:52:52.007035 2016-11-01 06:45:08.182374 3 0 16987 +914 328 1 2016-10-31 20:49:09.165152 2016-10-31 22:51:43.096978 3 0 4403 +913 328 0 2016-10-31 15:01:40.049793 2016-10-31 20:48:09.997121 3 0 12463 +912 327 0 2016-10-31 10:08:03.779192 2016-10-31 14:52:00.151361 3 0 10382 +911 326 3 2016-10-30 23:37:48.772249 2016-10-31 07:39:45.025561 3 0 17339 +910 326 2 2016-10-30 19:52:33.9172 2016-10-30 23:35:33.41168 3 0 8018 +909 326 1 2016-10-30 15:13:18.728965 2016-10-30 19:51:35.394048 3 0 10010 +908 326 0 2016-10-30 10:27:20.930901 2016-10-30 15:12:12.632675 3 0 10243 +907 325 2 2016-10-29 23:34:19.533504 2016-10-30 10:22:33.251794 3 0 23483 +906 325 1 2016-10-29 20:00:57.918602 2016-10-29 23:33:10.120618 3 0 8337 +905 325 0 2016-10-29 14:38:08.879286 2016-10-29 19:59:37.122135 3 0 11335 +904 324 0 2016-10-27 16:38:42.020454 2016-10-27 16:42:10.287139 1 0 0 +903 323 0 2016-10-27 09:48:53.927789 2016-10-27 10:25:57.486266 1 0 0 +902 322 1 2016-10-27 08:24:20.895391 2016-10-27 09:42:55.516442 3 0 3533 +901 322 0 2016-10-26 21:30:55.471987 2016-10-27 08:23:40.356072 3 0 29367 +900 321 5 2016-10-26 18:12:13.718482 2016-10-26 21:26:05.145506 3 0 8722 +899 321 4 2016-10-26 13:01:39.618483 2016-10-26 18:10:35.833241 3 0 13067 +898 321 3 2016-10-26 09:25:21.061913 2016-10-26 12:50:10.302392 3 0 11015 +897 321 2 2016-10-25 22:46:07.487295 2016-10-26 09:24:42.675939 3 0 34292 +896 321 1 2016-10-25 19:15:52.713937 2016-10-25 22:45:35.474138 3 0 11284 +895 321 0 2016-10-25 15:59:14.853307 2016-10-25 19:15:09.433751 3 0 10514 +894 320 2 2016-10-25 14:14:33.74884 2016-10-25 15:49:39.415656 3 0 5123 +893 320 1 2016-10-24 16:20:33.597206 2016-10-25 14:11:51.144988 3 0 73040 +892 320 0 2016-10-24 14:38:53.577946 2016-10-24 16:20:07.010549 3 0 5544 +891 319 0 2016-10-20 13:56:38.629329 2016-10-20 13:58:22.960878 3 0 0 +890 318 0 2016-10-20 13:54:07.98849 3 0 +889 317 0 2016-10-20 13:51:23.638312 3 0 +888 316 0 2016-10-20 13:48:45.749099 3 0 +887 315 0 2016-10-20 13:41:11.093741 2016-10-20 13:47:43.361038 3 0 0 +886 314 1 2016-10-18 17:38:18.102709 2016-10-19 16:04:51.536521 3 0 0 +885 314 0 2016-10-18 16:11:03.057887 2016-10-18 17:37:34.836273 3 0 0 +884 313 0 2016-10-18 15:56:38.00854 2016-10-18 16:07:37.930939 3 0 0 +883 312 0 2016-10-18 06:47:31.533051 2016-10-18 13:21:38.799702 3 0 35748 +882 311 0 2016-10-17 23:06:59.658532 3 0 +881 310 1 2016-10-17 22:40:38.599643 2016-10-17 23:03:06.571357 3 0 2019 +880 310 0 2016-10-17 17:39:06.742938 2016-10-17 22:39:50.915386 3 0 27264 +879 309 0 2016-10-17 17:35:50.548486 3 0 +878 308 0 2016-10-17 16:43:34.807054 2016-10-17 17:34:54.249903 3 0 4631 +877 307 0 2016-10-17 16:40:40.940281 3 0 +876 306 1 2016-10-16 10:53:01.59144 2016-10-16 16:10:23.826673 3 0 0 +875 306 0 2016-10-16 10:25:47.958362 2016-10-16 10:52:31.662189 3 0 0 +874 305 1 2016-10-16 08:47:14.227176 2016-10-16 10:02:53.791106 1 0 6850 +873 305 0 2016-10-15 22:07:27.558865 2016-10-16 08:43:53.371311 1 0 57726 +872 304 1 2016-10-15 21:57:35.097657 2016-10-15 22:04:01.973791 3 0 547 +871 304 0 2016-10-15 21:45:08.168814 2016-10-15 21:46:16.905388 3 0 79 +870 303 0 2016-10-15 21:04:16.11303 2016-10-15 21:05:02.115467 3 0 44 +869 302 0 2016-10-15 20:34:07.877478 2016-10-15 20:35:12.124751 3 0 76 +868 301 0 2016-10-15 20:28:51.859431 3 0 +867 300 0 2016-10-15 20:25:06.077907 2016-10-15 20:25:35.923993 3 0 23 +866 299 1 2016-10-15 20:21:04.896868 2016-10-15 20:22:48.221138 3 0 133 +865 299 0 2016-10-15 20:20:00.001347 2016-10-15 20:20:39.947033 3 0 44 +864 298 0 2016-10-15 18:46:15.398721 2016-10-15 20:17:45.548592 1 0 8278 +863 297 0 2016-10-15 18:13:27.428234 2016-10-15 18:22:08.160846 3 0 0 +862 296 0 2016-10-15 18:08:42.407956 1 0 +861 295 0 2016-10-15 18:06:26.73882 3 0 +860 294 0 2016-10-15 18:03:41.32837 2016-10-15 18:04:13.044756 3 0 0 +859 293 0 2016-10-15 18:00:38.787353 3 0 +858 292 0 2016-10-15 17:40:39.971318 2016-10-15 17:54:57.374518 1 0 1277 +857 291 0 2016-10-15 17:36:36.933823 2016-10-15 17:39:16.330372 1 0 91 +856 290 0 2016-10-15 17:19:48.326879 2016-10-15 17:21:26.508331 3 0 0 +855 289 0 2016-10-15 17:18:33.656081 2016-10-15 17:19:04.813884 3 0 0 +854 288 1 2016-10-15 17:17:32.542536 2016-10-15 17:18:04.470516 3 0 0 +853 288 0 2016-10-15 17:16:43.327674 2016-10-15 17:17:09.410214 3 0 0 +852 287 1 2016-10-15 17:15:14.495481 2016-10-15 17:15:51.771064 3 0 0 +851 287 0 2016-10-15 17:13:56.458603 2016-10-15 17:14:53.994458 3 0 0 +850 286 0 2016-10-15 17:12:30.302369 3 0 +849 285 2 2016-10-15 17:12:06.382154 3 0 +848 285 1 2016-10-15 17:11:09.397021 2016-10-15 17:11:39.380596 3 0 0 +847 285 0 2016-10-15 17:09:30.052184 2016-10-15 17:10:19.754615 3 0 0 +846 284 0 2016-10-15 17:08:26.171589 3 0 +845 283 0 2016-10-15 17:06:33.652225 2016-10-15 17:08:49.605678 3 0 0 +844 282 0 2016-10-15 17:03:57.175961 2016-10-15 17:04:43.964034 3 0 0 +843 281 0 2016-10-15 16:56:09.601105 2016-10-15 17:03:02.250423 3 0 0 +842 280 0 2016-10-15 16:50:32.166675 2016-10-15 16:54:11.469528 3 0 0 +841 279 0 2016-10-15 16:22:51.25652 2016-10-15 16:29:58.954014 3 0 609 +840 278 0 2016-10-15 16:15:24.948502 3 0 +839 277 0 2016-10-15 09:09:34.502813 2016-10-15 09:15:07.661692 3 0 477 +838 276 0 2016-10-14 23:10:54.677416 2016-10-14 23:17:09.232214 3 0 538 +837 275 0 2016-10-14 22:39:48.669726 2016-10-14 22:53:28.752441 3 0 1218 +836 274 0 2016-10-14 22:23:51.627943 2016-10-14 22:32:59.100079 3 0 804 +835 273 0 2016-10-14 22:21:16.186488 3 0 +834 272 0 2016-10-14 22:02:00.777117 2016-10-14 22:12:32.54331 3 0 927 +833 271 0 2016-10-14 21:40:04.427839 2016-10-14 21:53:54.362767 3 0 1237 +832 270 0 2016-10-14 21:08:19.24163 2016-10-14 21:32:55.452727 3 0 2193 +831 269 0 2016-10-14 21:01:15.236088 2016-10-14 21:07:12.203015 3 0 520 +830 268 0 2016-10-14 16:18:40.537928 2016-10-14 21:00:16.320446 3 0 25587 +829 267 2 2016-10-14 11:51:22.161388 2016-10-14 16:11:23.451802 1 0 23674 +828 267 1 2016-10-14 09:30:50.026571 2016-10-14 11:49:35.322235 1 0 12618 +827 267 0 2016-10-14 02:21:48.597519 2016-10-14 09:06:22.610373 1 0 36762 +826 266 17 2016-10-13 21:54:06.852241 2016-10-14 02:18:58.508548 1 0 23999 +825 266 16 2016-10-13 18:37:46.786313 2016-10-13 21:53:23.071979 1 0 17744 +824 266 15 2016-10-13 15:01:29.685907 2016-10-13 18:36:21.753366 1 0 19510 +823 266 14 2016-10-13 09:52:39.641737 2016-10-13 14:33:56.522736 1 0 25512 +822 266 13 2016-10-12 22:38:27.384067 2016-10-13 09:51:11.020874 1 0 61021 +821 266 12 2016-10-12 10:53:02.945828 2016-10-12 22:36:54.046133 1 0 63930 +820 266 11 2016-10-12 00:43:46.114652 2016-10-12 10:52:14.783175 1 0 55277 +819 266 10 2016-10-11 23:01:17.342551 2016-10-12 00:42:42.181988 1 0 9205 +818 266 9 2016-10-11 18:42:02.226095 2016-10-11 22:59:32.272921 1 0 23386 +817 266 8 2016-10-11 13:05:17.285557 2016-10-11 18:34:34.697034 1 0 29910 +816 266 7 2016-10-11 10:26:18.990455 2016-10-11 13:04:16.354852 1 0 14351 +815 266 6 2016-10-11 01:33:33.664969 2016-10-11 10:25:18.728547 1 0 48358 +814 266 5 2016-10-10 12:29:39.00519 2016-10-11 01:31:44.719398 1 0 70834 +813 266 4 2016-10-10 01:10:21.183114 2016-10-10 12:27:12.34087 1 0 61366 +812 266 3 2016-10-09 19:57:31.555519 2016-10-10 01:08:54.771899 1 0 28280 +811 266 2 2016-10-09 16:15:43.314847 2016-10-09 19:56:34.812075 1 0 20061 +810 266 1 2016-10-09 10:36:27.354518 2016-10-09 16:14:34.432723 1 0 30702 +809 266 0 2016-10-09 02:50:33.78683 2016-10-09 10:35:30.491966 1 0 42198 +808 265 9 2016-10-09 02:41:06.065501 1 0 +807 265 8 2016-10-08 18:29:09.94368 2016-10-09 02:40:13.990039 1 0 44524 +806 265 7 2016-10-08 13:28:09.942236 2016-10-08 18:28:26.482151 1 0 27223 +805 265 6 2016-10-07 22:05:02.784045 2016-10-08 13:27:18.710068 1 0 83631 +804 265 5 2016-10-07 18:28:22.095 2016-10-07 22:04:15.819318 1 0 19561 +803 265 4 2016-10-07 12:05:02.211512 2016-10-07 18:26:59.271891 1 0 34630 +802 265 3 2016-10-07 10:01:23.554566 2016-10-07 12:03:40.73872 1 0 11094 +801 265 2 2016-10-07 00:30:04.76419 2016-10-07 09:59:51.000005 1 0 51668 +800 265 1 2016-10-06 21:44:19.737936 2016-10-07 00:27:40.872721 1 0 14804 +799 265 0 2016-10-06 19:49:39.947352 2016-10-06 21:40:11.161531 1 0 10016 +798 264 16 2016-10-06 16:06:23.558205 2016-10-06 19:44:50.921441 1 0 19845 +797 264 15 2016-10-06 12:26:47.572403 2016-10-06 16:03:01.349594 1 0 19641 +796 264 14 2016-10-06 10:14:04.362337 2016-10-06 12:21:59.779602 1 0 11605 +795 264 13 2016-10-05 23:09:46.53448 2016-10-06 10:13:20.773518 1 0 60304 +794 264 12 2016-10-05 20:42:29.010369 2016-10-05 23:08:48.719622 1 0 13300 +793 264 11 2016-10-05 18:36:08.290783 2016-10-05 20:41:30.081564 1 0 11382 +792 264 10 2016-10-05 16:32:35.529901 2016-10-05 18:35:32.552752 1 0 11164 +791 264 9 2016-10-05 13:46:34.549968 2016-10-05 16:30:31.823718 1 0 14898 +790 264 8 2016-10-05 11:07:38.23096 2016-10-05 13:06:44.019433 1 0 10813 +789 264 7 2016-10-04 23:11:02.093506 2016-10-05 11:06:10.64777 1 0 64910 +788 264 6 2016-10-04 21:27:57.056193 2016-10-04 23:10:00.350042 1 0 9267 +787 264 5 2016-10-04 19:12:41.681601 2016-10-04 21:16:53.769448 1 0 11279 +786 264 4 2016-10-04 13:06:06.933317 2016-10-04 19:11:46.845731 1 0 33214 +785 264 3 2016-10-04 10:13:47.93334 2016-10-04 13:00:49.211772 1 0 15166 +784 264 2 2016-10-03 23:45:48.043212 2016-10-04 10:12:54.221074 1 0 56947 +783 264 1 2016-10-03 21:46:38.954423 2016-10-03 23:45:09.835005 1 0 10751 +782 264 0 2016-10-03 19:25:48.300522 2016-10-03 21:45:51.900572 1 0 12692 +781 263 4 2016-10-03 19:16:25.410914 1 0 +780 263 3 2016-10-03 13:08:38.784824 2016-10-03 19:15:33.819485 1 0 33364 +779 263 2 2016-10-03 10:44:16.633899 2016-10-03 13:07:59.950901 1 0 13068 +778 263 1 2016-10-02 23:53:20.933188 2016-10-03 10:43:32.850908 1 0 59068 +777 263 0 2016-10-02 22:31:43.496953 2016-10-02 23:51:59.861402 1 0 7276 +776 262 16 2016-10-02 00:59:14.011361 2016-10-02 22:26:19.838881 1 0 116869 +775 262 15 2016-10-01 22:36:34.262803 2016-10-02 00:58:22.141751 1 0 12868 +774 262 14 2016-10-01 20:32:13.17151 2016-10-01 22:35:52.41015 1 0 11228 +773 262 13 2016-10-01 17:51:14.160873 2016-10-01 20:31:06.618529 1 0 14508 +772 262 12 2016-10-01 15:21:46.373974 2016-10-01 17:50:32.682472 1 0 13513 +771 262 11 2016-09-30 20:18:40.721581 2016-10-01 15:20:53.213112 1 0 103632 +770 262 10 2016-09-30 11:41:47.120426 2016-09-30 20:17:54.271902 1 0 46871 +769 262 9 2016-09-30 09:42:35.048547 2016-09-30 11:41:01.074048 1 0 10739 +768 262 8 2016-09-30 00:14:06.213288 2016-09-30 09:41:40.000937 1 0 51509 +767 262 7 2016-09-29 22:54:18.782471 2016-09-30 00:12:25.821057 1 0 7076 +766 262 6 2016-09-29 20:50:12.55002 2016-09-29 22:45:04.043253 1 0 10403 +765 262 5 2016-09-29 18:34:45.460695 2016-09-29 20:49:07.050456 1 0 12195 +764 262 4 2016-09-29 16:21:28.203233 2016-09-29 18:32:54.064355 1 0 11918 +763 262 3 2016-09-29 13:23:10.432985 2016-09-29 16:18:16.07946 1 0 15893 +762 262 2 2016-09-29 10:31:04.681502 2016-09-29 13:21:02.821846 1 0 15434 +761 262 1 2016-09-28 23:58:34.849754 2016-09-29 10:30:00.408597 1 0 57298 +760 262 0 2016-09-28 23:52:09.521495 2016-09-28 23:57:50.712198 1 0 115 +759 261 0 2016-09-28 23:14:07.91502 2016-09-28 23:27:32.669543 1 0 1177 +758 260 0 2016-09-28 22:57:36.664986 2016-09-28 23:12:20.448929 1 0 1305 +757 259 0 2016-09-28 22:46:32.776519 2016-09-28 22:55:43.600125 1 0 792 +756 258 1 2016-09-28 22:28:30.810812 2016-09-28 22:36:57.879283 1 0 737 +755 258 0 2016-09-28 22:10:45.994425 2016-09-28 22:25:52.238522 1 0 1246 +754 257 0 2016-09-28 13:45:43.052341 2016-09-28 13:50:42.658444 1 0 178 +753 256 0 2016-09-28 13:06:55.28637 1 0 +752 255 1 2016-09-28 12:54:27.049121 2016-09-28 13:03:41.60902 1 0 493 +751 255 0 2016-09-28 12:32:34.175985 2016-09-28 12:53:36.651466 1 0 504 +750 254 1 2016-09-28 11:45:28.502038 2016-09-28 11:52:17.199103 1 0 599 +749 254 0 2016-09-28 11:17:19.149666 2016-09-28 11:27:09.638686 1 0 873 +748 253 0 2016-09-28 10:37:46.142684 1 0 +747 252 5 2016-09-27 22:52:32.662357 1 0 +746 252 4 2016-09-27 19:40:20.824957 2016-09-27 22:47:34.85147 1 0 17024 +745 252 3 2016-09-27 16:57:52.650103 2016-09-27 19:39:31.748603 1 0 14687 +744 252 2 2016-09-27 12:25:10.654741 2016-09-27 16:56:39.503074 1 0 24678 +743 252 1 2016-09-27 10:13:13.182815 2016-09-27 12:12:30.040891 1 0 10834 +742 252 0 2016-09-26 20:38:19.708036 2016-09-27 10:10:32.811322 1 0 73911 +741 251 7 2016-09-26 15:41:52.173888 2016-09-26 20:33:57.724434 1 0 26552 +740 251 6 2016-09-26 13:10:55.580425 2016-09-26 15:36:59.038738 1 0 13297 +739 251 5 2016-09-26 10:56:08.939819 2016-09-26 13:09:59.668952 1 0 12163 +738 251 4 2016-09-25 21:56:21.201696 2016-09-26 10:55:25.448933 1 0 70918 +737 251 3 2016-09-25 01:10:17.08896 2016-09-25 21:55:34.158761 1 0 113372 +736 251 2 2016-09-24 16:27:52.905332 2016-09-25 01:09:08.561474 1 0 47460 +735 251 1 2016-09-24 12:41:32.583009 2016-09-24 16:26:58.429047 1 0 20536 +734 251 0 2016-09-23 23:53:39.51082 2016-09-24 12:40:47.640542 1 0 69852 +733 250 12 2016-09-23 18:41:10.763055 2016-09-23 23:46:55.285066 1 0 27833 +732 250 11 2016-09-23 16:45:35.062849 2016-09-23 18:39:09.219875 1 0 10318 +731 250 10 2016-09-23 14:06:17.725501 2016-09-23 16:44:11.93928 1 0 14359 +730 250 9 2016-09-23 10:14:07.484687 2016-09-23 14:01:56.459811 1 0 20746 +729 250 8 2016-09-22 21:22:44.803877 2016-09-23 10:12:22.328107 1 0 70007 +728 250 7 2016-09-22 19:19:29.89298 2016-09-22 21:21:27.988511 1 0 11102 +727 250 6 2016-09-22 13:45:27.130532 2016-09-22 19:18:41.319182 1 0 30331 +726 250 5 2016-09-22 11:15:39.540092 2016-09-22 13:44:53.119869 1 0 13560 +725 250 4 2016-09-22 01:02:14.62989 2016-09-22 11:14:26.419381 1 0 55669 +724 250 3 2016-09-21 23:12:18.328352 2016-09-22 01:00:45.830561 1 0 9864 +723 250 2 2016-09-21 21:08:58.933015 2016-09-21 23:10:57.320984 1 0 11087 +722 250 1 2016-09-21 15:47:46.353913 2016-09-21 17:38:48.929948 1 0 10095 +721 250 0 2016-09-21 13:07:47.680121 2016-09-21 15:43:21.450484 1 0 14134 +720 249 12 2016-09-21 10:53:12.753123 2016-09-21 12:53:11.088083 1 0 10924 +719 249 11 2016-09-20 21:54:36.253978 2016-09-21 10:49:29.34746 1 0 70490 +718 249 10 2016-09-20 19:54:01.402668 2016-09-20 21:53:49.87868 1 0 10889 +717 249 9 2016-09-20 17:51:15.107189 2016-09-20 19:50:59.438764 1 0 10903 +716 249 8 2016-09-20 15:49:58.258185 2016-09-20 17:47:50.700464 1 0 10713 +715 249 7 2016-09-20 09:32:55.279472 2016-09-20 15:49:11.61692 1 0 34255 +714 249 6 2016-09-19 23:59:56.989986 2016-09-20 09:32:20.326079 1 0 52126 +713 249 5 2016-09-19 21:22:21.542932 2016-09-19 23:59:17.450273 1 0 14287 +712 249 4 2016-09-19 18:03:27.304398 2016-09-19 20:05:31.939657 1 0 11093 +711 249 3 2016-09-19 16:02:16.303033 2016-09-19 18:02:17.015552 1 0 10914 +710 249 2 2016-09-19 13:52:42.805659 2016-09-19 16:00:10.928771 1 0 11589 +709 249 1 2016-09-19 11:57:37.579953 2016-09-19 13:49:17.449295 1 0 10168 +708 249 0 2016-09-19 10:13:04.584946 2016-09-19 11:56:44.50927 1 0 9429 +707 248 14 2016-09-16 14:23:23.723304 2016-09-16 15:40:53.04808 1 0 7049 +706 248 13 2016-09-16 12:29:06.04102 2016-09-16 14:22:14.300437 1 0 10282 +705 248 12 2016-09-16 10:29:53.637292 2016-09-16 12:24:56.368165 1 0 10466 +704 248 11 2016-09-16 08:04:30.923672 2016-09-16 10:29:09.406441 1 0 13142 +703 248 10 2016-09-15 22:53:18.88708 2016-09-16 07:55:16.777535 1 0 49164 +702 248 9 2016-09-15 19:50:29.748704 2016-09-15 22:32:40.709126 1 0 14749 +701 248 8 2016-09-15 17:56:28.314512 2016-09-15 19:48:45.879015 1 0 10215 +700 248 7 2016-09-15 15:56:50.44519 2016-09-15 17:55:45.848538 1 0 10794 +699 248 6 2016-09-15 13:23:10.064753 2016-09-15 15:46:37.208757 1 0 13041 +698 248 5 2016-09-15 11:17:01.983651 2016-09-15 13:08:01.660817 1 0 10079 +697 248 4 2016-09-15 06:29:24.114082 2016-09-15 11:16:20.276172 1 0 26106 +696 248 3 2016-09-15 06:27:29.771422 2016-09-15 06:29:00.302256 1 0 114 +695 248 2 2016-09-14 23:58:47.555363 2016-09-15 06:25:07.504795 1 0 35145 +694 248 1 2016-09-14 22:25:06.729412 2016-09-14 23:57:46.568295 1 0 8428 +693 248 0 2016-09-14 20:27:17.402614 2016-09-14 22:23:03.683884 1 0 10522 +692 247 2 2016-09-14 01:11:37.910995 2016-09-14 08:06:45.610221 1 0 37788 +691 247 1 2016-09-13 19:41:43.119832 2016-09-14 01:11:09.765386 1 0 29977 +690 247 0 2016-09-13 17:43:55.263244 2016-09-13 19:41:23.911479 1 0 10692 +689 246 0 2016-09-13 00:22:31.352191 2016-09-13 05:17:15.887215 1 0 26816 +688 245 18 2016-09-12 21:06:44.495651 2016-09-13 00:15:43.824978 1 0 17219 +687 245 17 2016-09-12 17:21:54.99175 2016-09-12 21:05:02.125918 1 0 20329 +686 245 16 2016-09-12 13:21:16.311724 2016-09-12 17:21:03.997314 1 0 21830 +685 245 15 2016-09-12 10:11:01.625354 2016-09-12 13:21:02.376294 1 0 17295 +684 245 14 2016-09-12 07:48:09.823035 2016-09-12 10:08:57.029654 1 0 12817 +683 245 13 2016-09-12 01:11:54.232215 2016-09-12 07:47:56.772052 1 0 36046 +682 245 12 2016-09-11 20:30:11.865641 2016-09-12 01:10:32.586896 1 0 25525 +681 245 11 2016-09-11 17:55:28.614038 2016-09-11 20:28:15.665633 1 0 13922 +680 245 10 2016-09-11 14:57:03.917841 2016-09-11 17:55:06.225333 1 0 16231 +679 245 9 2016-09-11 10:32:52.179609 2016-09-11 14:56:33.994833 1 0 24007 +678 245 8 2016-09-11 07:05:34.146514 2016-09-11 10:32:26.924284 1 0 18838 +677 245 7 2016-09-10 23:54:47.83057 2016-09-11 07:05:13.459989 1 0 39156 +676 245 6 2016-09-10 22:05:02.624472 2016-09-10 23:54:28.93211 1 0 9966 +675 245 5 2016-09-10 19:15:40.353567 2016-09-10 22:04:44.590989 1 0 15407 +674 245 4 2016-09-10 14:37:32.886474 2016-09-10 19:14:58.274973 1 0 25287 +673 245 3 2016-09-10 12:29:21.73228 2016-09-10 14:37:17.508916 1 0 11581 +672 245 2 2016-09-10 09:33:59.279799 2016-09-10 12:28:54.272685 1 0 15826 +671 245 1 2016-09-10 01:06:53.27207 2016-09-10 09:33:39.128621 1 0 45965 +670 245 0 2016-09-09 18:49:11.36372 2016-09-09 21:46:43.445798 1 0 16158 +669 244 7 2016-09-09 00:58:36.135371 2016-09-09 04:56:34.842131 1 0 21669 +668 244 6 2016-09-08 19:32:08.374211 2016-09-09 00:57:20.245708 1 0 29600 +667 244 5 2016-09-08 15:54:48.148632 2016-09-08 19:31:10.73722 1 0 19717 +666 244 4 2016-09-08 11:48:01.038822 2016-09-08 15:54:15.69228 1 0 22433 +665 244 3 2016-09-08 08:14:03.992635 2016-09-08 11:47:35.099046 1 0 19432 +664 244 2 2016-09-08 01:07:26.252473 2016-09-08 08:13:42.050093 1 0 38807 +663 244 1 2016-09-07 22:38:50.98366 2016-09-08 01:06:27.2905 1 0 13436 +662 244 0 2016-09-07 18:56:54.998426 2016-09-07 22:38:20.948184 1 0 20156 +661 243 37 2016-09-07 17:02:00.698877 2016-09-07 18:53:53.068185 1 0 10187 +660 243 36 2016-09-07 14:28:36.301753 2016-09-07 17:01:41.967104 1 0 13936 +659 243 35 2016-09-07 11:02:59.195676 2016-09-07 14:28:11.987765 1 0 18697 +658 243 34 2016-09-07 08:48:43.04741 2016-09-07 11:02:32.596948 1 0 12194 +657 243 33 2016-09-07 00:02:00.895517 2016-09-07 08:48:22.863265 1 0 47973 +656 243 32 2016-09-06 20:49:08.742315 2016-09-07 00:00:29.708849 1 0 17445 +655 243 31 2016-09-06 18:31:45.474872 2016-09-06 20:48:50.270516 1 0 12483 +654 243 30 2016-09-06 16:03:32.409212 2016-09-06 18:31:03.481141 1 0 13428 +653 243 29 2016-09-06 12:54:06.93083 2016-09-06 16:03:10.908828 1 0 17207 +652 243 28 2016-09-06 10:10:45.353614 2016-09-06 12:53:33.357495 1 0 14816 +651 243 27 2016-09-06 07:58:44.218988 2016-09-06 10:10:25.47947 1 0 12006 +650 243 26 2016-09-05 23:53:03.99613 2016-09-06 07:58:24.990506 1 0 44224 +649 243 25 2016-09-05 21:02:40.463162 2016-09-05 23:52:16.76861 1 0 15455 +648 243 24 2016-09-05 18:59:46.113309 2016-09-05 21:01:50.140839 1 0 11119 +647 243 23 2016-09-05 15:52:47.763071 2016-09-05 18:59:24.125011 1 0 16979 +646 243 22 2016-09-05 13:17:56.548125 2016-09-05 15:52:25.797427 1 0 14062 +645 243 21 2016-09-05 08:01:39.815341 2016-09-05 13:16:25.844739 1 0 28593 +644 243 20 2016-09-04 23:46:09.997185 2016-09-05 08:00:46.293143 1 0 44829 +643 243 19 2016-09-04 21:36:33.173127 2016-09-04 23:45:50.556556 1 0 11773 +642 243 18 2016-09-04 19:32:44.013906 2016-09-04 21:36:14.951815 1 0 11250 +641 243 17 2016-09-04 17:37:16.350318 2016-09-04 19:32:26.787159 1 0 10484 +640 243 16 2016-09-04 15:41:01.300391 2016-09-04 17:36:58.328403 1 0 10562 +639 243 15 2016-09-04 11:03:12.766021 2016-09-04 15:40:44.2649 1 0 25283 +638 243 14 2016-09-04 08:14:18.736094 2016-09-04 11:02:57.646214 1 0 15356 +637 243 13 2016-09-04 03:10:33.855097 2016-09-04 08:13:33.93263 1 0 27575 +636 243 12 2016-09-03 23:55:45.252129 2016-09-04 03:09:52.542681 1 0 17655 +635 243 11 2016-09-03 20:04:19.257586 2016-09-03 23:55:25.088067 1 0 21046 +634 243 10 2016-09-03 18:06:30.888297 2016-09-03 20:03:58.226508 1 0 10697 +633 243 9 2016-09-03 15:59:13.578799 2016-09-03 18:05:20.29195 1 0 11464 +632 243 8 2016-09-03 14:04:51.048283 2016-09-03 15:58:55.09464 1 0 10385 +631 243 7 2016-09-03 10:30:56.740653 2016-09-03 14:03:43.645042 1 0 19387 +630 243 6 2016-09-03 08:07:59.00254 2016-09-03 10:29:12.955862 1 0 12858 +629 243 5 2016-09-02 23:55:15.931683 2016-09-03 08:06:30.224929 1 0 44720 +628 243 4 2016-09-02 21:50:49.671213 2016-09-02 23:54:58.815708 1 0 11303 +627 243 3 2016-09-02 19:57:02.778854 2016-09-02 21:50:25.202296 1 0 10323 +626 243 2 2016-09-02 17:45:30.946047 2016-09-02 19:56:40.077872 1 0 11930 +625 243 1 2016-09-02 15:47:53.968314 2016-09-02 17:45:10.535625 1 0 10684 +624 243 0 2016-09-02 09:22:13.245659 2016-09-02 15:47:36.047327 1 0 35068 +623 242 0 2016-08-31 21:49:45.28052 1 0 +622 241 0 2016-08-31 21:41:36.585818 1 0 +621 240 0 2016-08-31 19:42:54.417074 1 0 +620 239 0 2016-08-31 19:32:49.147572 1 0 +619 238 19 2016-08-31 13:22:36.280478 1 0 +618 238 18 2016-08-31 10:13:53.286137 2016-08-31 13:20:49.240302 1 0 17017 +617 238 17 2016-08-31 07:31:34.680832 2016-08-31 10:13:16.336108 1 0 14715 +616 238 16 2016-08-31 01:23:08.20073 2016-08-31 07:29:45.255394 1 0 33398 +615 238 15 2016-08-30 22:49:56.929514 2016-08-31 01:22:48.312571 1 0 13924 +614 238 14 2016-08-30 19:07:12.237052 2016-08-30 22:49:34.132525 1 0 20259 +613 238 13 2016-08-30 16:13:59.234436 2016-08-30 19:05:26.154189 1 0 15627 +612 238 12 2016-08-30 09:19:14.006319 2016-08-30 16:12:23.00971 1 0 37634 +611 238 11 2016-08-30 00:14:12.90151 2016-08-30 09:18:54.973826 1 0 49608 +610 238 10 2016-08-29 22:04:15.801004 2016-08-30 00:13:35.128184 1 0 11782 +609 238 9 2016-08-29 19:11:50.914176 2016-08-29 22:03:22.067373 1 0 15625 +608 238 8 2016-08-29 16:38:56.901608 2016-08-29 19:11:27.477337 1 0 13899 +607 238 7 2016-08-29 13:43:09.961269 2016-08-29 16:38:32.538481 1 0 15989 +606 238 6 2016-08-29 11:46:12.913774 2016-08-29 13:42:46.948391 1 0 10631 +605 238 5 2016-08-29 07:51:21.19249 2016-08-29 11:44:36.98564 1 0 21233 +604 238 4 2016-08-28 23:43:20.533002 2016-08-29 07:50:50.778734 1 0 44426 +603 238 3 2016-08-28 19:54:49.759927 2016-08-28 23:40:18.242072 1 0 20550 +602 238 2 2016-08-28 14:25:39.959153 2016-08-28 19:48:19.378087 1 0 29419 +601 238 1 2016-08-28 12:02:12.606863 2016-08-28 14:25:16.451496 1 0 13034 +600 238 0 2016-08-28 07:28:54.442064 2016-08-28 11:59:16.118733 1 0 24631 +599 237 4 2016-08-28 00:40:22.577628 2016-08-28 07:14:56.35737 1 0 35497 +598 237 3 2016-08-27 19:42:57.539943 2016-08-28 00:39:07.501895 1 0 26978 +597 237 2 2016-08-27 16:39:51.754684 2016-08-27 19:41:44.441921 1 0 16578 +596 237 1 2016-08-27 13:00:01.060097 2016-08-27 16:35:02.931999 1 0 19593 +595 237 0 2016-08-27 09:18:06.536493 2016-08-27 12:59:32.628764 1 0 20140 +594 236 10 2016-08-26 16:22:03.563536 2016-08-26 17:29:08.088476 1 0 6113 +593 236 9 2016-08-26 13:56:33.284872 2016-08-26 16:21:36.915712 1 0 13212 +592 236 8 2016-08-26 11:40:50.271243 2016-08-26 13:56:15.438438 1 0 12326 +591 236 7 2016-08-26 09:17:48.650092 2016-08-26 11:40:27.824391 1 0 12982 +590 236 6 2016-08-25 20:14:40.366988 2016-08-26 09:17:26.169887 1 0 71181 +589 236 5 2016-08-25 15:41:09.028345 2016-08-25 20:14:15.080655 1 0 24884 +588 236 4 2016-08-25 13:34:44.771134 2016-08-25 15:40:46.520288 1 0 11483 +587 236 3 2016-08-25 11:37:09.542709 2016-08-25 13:34:07.252872 1 0 10658 +586 236 2 2016-08-25 03:59:42.319511 2016-08-25 11:36:46.284211 1 0 41642 +585 236 1 2016-08-24 18:56:27.616428 2016-08-25 03:59:24.485845 1 0 49482 +584 236 0 2016-08-24 14:31:55.236909 2016-08-24 18:56:06.052096 1 0 24051 +583 235 1 2016-08-23 16:29:16.426037 2016-08-24 04:37:52.639504 1 0 66287 +582 235 0 2016-08-23 11:53:34.761749 2016-08-23 16:28:56.196339 1 0 25100 +581 234 2 2016-08-22 15:13:18.618319 1 0 +580 234 1 2016-08-22 11:16:37.967119 2016-08-22 15:13:03.930987 1 0 21552 +579 234 0 2016-08-22 09:23:56.833278 2016-08-22 11:16:19.046826 1 0 10225 +578 233 5 2016-08-21 20:57:11.427201 2016-08-22 04:29:06.539347 1 0 41070 +577 233 4 2016-08-21 17:15:14.023128 2016-08-21 20:56:49.040882 1 0 20159 +576 233 3 2016-08-21 12:29:04.358888 2016-08-21 17:14:54.277119 1 0 26035 +575 233 2 2016-08-21 10:25:40.808635 2016-08-21 12:28:50.535495 1 0 11208 +574 233 1 2016-08-21 00:47:20.697539 2016-08-21 10:25:24.514436 1 0 52550 +573 233 0 2016-08-20 22:22:09.761691 2016-08-21 00:46:55.485897 1 0 13172 +572 232 14 2016-08-20 16:57:17.729631 2016-08-20 22:19:07.243145 1 0 29283 +571 232 13 2016-08-20 13:21:08.798306 2016-08-20 16:56:47.748765 1 0 19637 +570 232 12 2016-08-20 10:51:38.885482 2016-08-20 13:20:43.4648 1 0 13581 +569 232 11 2016-08-19 23:55:52.379064 2016-08-20 10:51:24.488735 1 0 59729 +568 232 10 2016-08-19 22:01:48.540355 2016-08-19 23:55:38.899075 1 0 10363 +567 232 9 2016-08-19 20:06:36.615711 2016-08-19 22:01:31.40817 1 0 10460 +566 232 8 2016-08-19 18:04:24.403233 2016-08-19 20:05:47.060433 1 0 11067 +565 232 7 2016-08-19 15:47:17.890562 2016-08-19 18:03:46.938148 1 0 12445 +564 232 6 2016-08-19 10:05:37.916924 2016-08-19 15:46:40.579124 1 0 31077 +563 232 5 2016-08-19 07:14:49.128685 2016-08-19 10:04:42.443528 1 0 15324 +562 232 4 2016-08-18 23:49:48.055474 2016-08-19 07:12:59.839664 1 0 40360 +561 232 3 2016-08-18 21:07:56.971002 2016-08-18 23:49:22.899275 1 0 14712 +560 232 2 2016-08-18 16:12:42.69213 2016-08-18 21:07:38.620252 1 0 26853 +559 232 1 2016-08-18 14:12:51.035834 2016-08-18 16:12:14.938326 1 0 10879 +558 232 0 2016-08-18 12:01:53.580964 2016-08-18 14:12:08.391716 1 0 11864 +557 231 5 2016-08-18 00:45:14.509057 2016-08-18 03:53:55.653224 1 0 17185 +556 231 4 2016-08-17 22:50:43.412141 2016-08-18 00:44:52.384323 1 0 10401 +555 231 3 2016-08-17 19:55:58.632694 2016-08-17 22:50:26.288949 1 0 15884 +554 231 2 2016-08-17 17:16:14.139554 2016-08-17 19:55:36.588137 1 0 14513 +553 231 1 2016-08-17 15:03:19.905113 2016-08-17 17:15:56.25077 1 0 12077 +552 231 0 2016-08-17 11:37:59.990549 2016-08-17 15:02:58.7234 1 0 18680 +551 230 9 2016-08-16 23:37:48.52035 2016-08-17 05:00:15.637266 1 0 29380 +550 230 8 2016-08-16 21:31:21.51848 2016-08-16 23:37:28.66562 1 0 11491 +549 230 7 2016-08-16 19:36:00.718313 2016-08-16 21:31:05.089497 1 0 10490 +548 230 6 2016-08-16 17:28:01.569642 2016-08-16 19:35:30.011836 1 0 11627 +547 230 5 2016-08-16 15:37:12.75768 2016-08-16 17:27:42.359034 1 0 10067 +546 230 4 2016-08-15 23:33:04.700752 2016-08-16 15:36:57.276028 1 0 87756 +545 230 3 2016-08-15 21:24:07.288855 2016-08-15 23:32:34.856058 1 0 11701 +544 230 2 2016-08-15 19:32:29.127635 2016-08-15 21:23:38.630743 1 0 10121 +543 230 1 2016-08-15 17:18:24.867669 2016-08-15 19:32:09.09534 1 0 12183 +542 230 0 2016-08-15 15:25:25.708075 2016-08-15 17:18:05.586774 1 0 10257 +541 229 0 2016-08-13 14:21:29.246166 2016-08-13 14:22:30.476781 1 0 92 +540 228 2 2016-08-08 10:25:26.957062 2016-08-11 04:50:24.093453 1 0 362577 +539 228 1 2016-08-08 10:02:18.98437 2016-08-08 10:25:16.41033 1 0 2069 +538 228 0 2016-08-08 09:53:06.907461 2016-08-08 10:01:11.026003 1 0 731 +537 227 2 2016-08-08 09:51:40.676869 1 0 +536 227 1 2016-08-08 09:45:48.28728 2016-08-08 09:50:58.745044 1 0 470 +535 227 0 2016-08-08 09:35:53.719976 2016-08-08 09:43:03.338201 1 0 648 +534 226 0 2016-08-08 09:20:50.231742 2016-08-08 09:34:56.310763 1 0 1280 +533 225 0 2016-08-08 08:13:02.110318 1 0 +532 224 0 2016-08-08 08:06:50.876835 1 0 +531 223 0 2016-08-08 08:03:35.338451 2016-08-08 08:03:50.724429 1 0 18 +530 222 0 2016-08-08 07:58:27.640072 1 0 +529 221 0 2016-08-08 07:56:28.691095 1 0 +528 220 0 2016-08-08 07:55:52.153359 1 0 +527 219 0 2016-08-08 07:16:43.872639 2016-08-08 07:35:01.033064 1 0 1645 +526 218 0 2016-08-01 07:36:27.15202 2016-08-01 07:37:38.249516 0 0 14 +525 217 0 2016-08-01 07:34:49.865477 2016-08-01 07:36:05.022815 0 0 0 +524 216 0 2016-08-01 07:15:25.006316 0 0 +523 215 0 2016-08-01 07:07:20.156702 0 0 +522 214 0 2016-08-01 07:04:19.583402 0 0 +521 213 0 2016-08-01 07:03:46.864344 0 0 +520 212 0 2016-08-01 07:00:55.203447 0 0 +519 211 0 2016-08-01 06:53:25.4337 0 0 +518 210 2 2016-08-01 06:51:21.342425 0 0 +517 210 1 2016-08-01 06:51:03.211792 2016-08-01 06:51:18.163239 0 0 3 +516 210 0 2016-08-01 06:50:08.117733 2016-08-01 06:50:59.631139 0 0 10 +515 209 0 2016-08-01 06:47:53.475305 0 0 +514 208 0 2016-08-01 06:35:32.223371 0 0 +513 207 1 2016-08-01 06:33:39.211141 2016-08-01 06:34:40.472506 0 0 12 +512 207 0 2016-08-01 06:31:59.194975 2016-08-01 06:33:34.821979 0 0 18 +511 206 0 2016-08-01 06:25:14.179542 0 0 +510 205 2 2016-07-29 12:51:44.7666 2016-07-29 15:00:49.228356 3 0 2919 +509 205 1 2016-07-29 08:04:55.070627 2016-07-29 12:51:27.80003 3 0 6243 +508 205 0 2016-07-29 00:13:54.570503 2016-07-29 08:03:59.471342 3 0 9839 +507 204 2 2016-07-28 12:38:36.010804 2016-07-29 00:02:38.17348 3 0 14313 +506 204 1 2016-07-28 08:08:29.018964 2016-07-28 12:37:58.103513 3 0 5600 +505 204 0 2016-07-27 23:52:13.880581 2016-07-28 08:08:14.338957 3 0 10383 +504 203 3 2016-07-27 15:58:50.575331 2016-07-27 23:42:34.284753 3 0 9706 +503 203 2 2016-07-27 12:07:47.845183 2016-07-27 15:58:22.3419 3 0 4588 +502 203 1 2016-07-27 08:04:15.055694 2016-07-27 12:07:24.950342 3 0 5148 +501 203 0 2016-07-27 00:38:48.71708 2016-07-27 08:03:57.73789 3 0 9317 +500 202 0 2016-07-27 00:36:36.015577 3 0 +499 201 0 2016-07-27 00:32:54.803321 3 0 +498 200 1 2016-07-26 14:36:30.828885 2016-07-27 00:23:31.057567 3 0 12270 +497 200 0 2016-07-26 10:50:39.469246 2016-07-26 14:36:09.644992 3 0 4719 +496 199 1 2016-07-26 08:03:12.045028 2016-07-26 10:26:40.10112 3 0 2982 +495 199 0 2016-07-26 00:33:03.509465 2016-07-26 08:02:46.676333 3 0 9412 +494 198 1 2016-07-25 20:50:07.890612 2016-07-26 00:28:29.498748 3 0 4570 +493 198 0 2016-07-25 15:45:46.023402 2016-07-25 20:48:10.922981 3 0 6325 +492 197 3 2016-07-25 14:01:26.142018 2016-07-25 15:38:01.185445 3 0 2018 +491 197 2 2016-07-25 09:58:20.741767 2016-07-25 14:01:09.026695 3 0 5082 +490 197 1 2016-07-25 08:09:12.803863 2016-07-25 09:57:56.284028 3 0 1059 +489 197 0 2016-07-25 00:09:28.783209 2016-07-25 08:08:43.52191 3 0 9712 +488 196 4 2016-07-24 20:31:25.019258 2016-07-25 00:03:23.512531 3 0 4438 +487 196 3 2016-07-24 16:02:50.898654 2016-07-24 20:30:56.889117 3 0 5611 +486 196 2 2016-07-24 12:07:08.200593 2016-07-24 16:02:24.998718 3 0 4923 +485 196 1 2016-07-24 08:08:03.550954 2016-07-24 12:06:42.527773 3 0 4994 +484 196 0 2016-07-24 00:06:40.64911 2016-07-24 08:07:08.68192 3 0 10056 +483 195 4 2016-07-23 20:32:29.74776 2016-07-24 00:02:08.310919 3 0 4388 +482 195 3 2016-07-23 16:49:21.492398 2016-07-23 20:32:02.52473 3 0 4202 +481 195 2 2016-07-23 12:44:32.215439 2016-07-23 16:49:04.557559 3 0 5117 +480 195 1 2016-07-23 08:04:08.059734 2016-07-23 12:44:17.531413 3 0 5863 +479 195 0 2016-07-23 00:08:23.528541 2016-07-23 08:03:37.076373 3 0 9947 +478 194 4 2016-07-22 21:03:49.033115 2016-07-23 00:01:19.562097 3 0 3715 +477 194 3 2016-07-22 15:38:54.910917 2016-07-22 21:03:27.259708 3 0 6791 +476 194 2 2016-07-22 11:48:15.103427 2016-07-22 15:38:33.192251 3 0 4844 +475 194 1 2016-07-22 08:02:16.47314 2016-07-22 11:47:49.850638 3 0 4716 +474 194 0 2016-07-22 00:07:09.63482 2016-07-22 08:01:40.210095 3 0 9930 +473 193 0 2016-07-22 00:04:24.597321 3 0 +472 192 2 2016-07-21 23:08:42.41326 2016-07-21 23:56:06.114089 3 0 992 +471 192 1 2016-07-21 19:12:16.245059 2016-07-21 23:08:05.19866 3 0 4935 +470 192 0 2016-07-21 15:03:56.211221 2016-07-21 19:11:57.090727 3 0 5187 +469 191 0 2016-07-21 13:41:45.59572 1 0 +468 190 0 2016-07-21 13:41:09.685543 2016-07-21 13:41:28.489454 1 0 3 +467 189 0 2016-07-21 13:39:52.783478 1 0 +466 188 0 2016-07-21 13:37:15.061305 1 0 +465 187 0 2016-07-21 13:35:34.241403 1 0 +464 186 0 2016-07-21 13:34:20.682053 1 0 +463 185 0 2016-07-21 13:33:10.444258 1 0 +462 184 0 2016-07-21 13:23:52.154309 1 0 +461 183 0 2016-07-21 13:19:54.017072 1 0 +460 182 0 2016-07-21 13:16:04.527256 1 0 +459 181 0 2016-07-21 13:09:33.683779 2016-07-21 13:14:38.666381 1 0 462 +458 180 1 2016-07-21 13:06:30.824567 2016-07-21 13:09:05.248789 1 0 233 +457 180 0 2016-07-21 13:06:14.474841 2016-07-21 13:06:25.637636 1 0 2 +456 179 0 2016-07-21 13:00:59.089004 1 0 +455 178 0 2016-07-21 12:08:28.616244 2016-07-21 12:55:02.877081 3 0 969 +454 177 0 2016-07-21 11:57:23.846667 1 0 +453 176 0 2016-07-21 11:50:00.22501 1 0 +452 175 0 2016-07-21 11:42:51.624688 1 0 +451 174 0 2016-07-21 08:38:58.696123 2016-07-21 10:56:45.666676 3 0 3452 +450 173 0 2016-07-21 08:12:28.429081 3 0 +449 172 0 2016-07-21 00:14:26.802304 2016-07-21 08:04:01.406673 3 0 9829 +448 171 0 2016-07-21 00:11:14.704587 3 0 +447 170 0 2016-07-21 00:09:39.183959 3 0 +446 169 1 2016-07-20 20:45:53.233169 2016-07-21 00:02:55.899644 3 0 3754 +445 169 0 2016-07-20 16:45:02.497027 2016-07-20 20:45:22.291622 3 0 5030 +444 168 0 2016-07-20 16:39:09.207739 2016-07-20 16:39:34.661607 0 0 6 +443 167 0 2016-07-20 16:14:48.77659 2016-07-20 16:15:03.838906 0 0 4 +442 166 1 2016-07-20 13:53:51.002617 2016-07-20 16:04:30.202615 3 0 2730 +441 166 0 2016-07-20 10:11:30.157863 2016-07-20 13:53:35.528649 3 0 4648 +440 165 0 2016-07-19 23:11:48.111782 2016-07-20 05:23:24.927115 3 0 6083 +439 164 5 2016-07-19 22:39:09.70037 2016-07-19 23:01:52.174118 3 0 471 +438 164 4 2016-07-19 17:38:09.965296 2016-07-19 22:38:44.623363 3 0 6413 +437 164 3 2016-07-19 14:49:22.433688 2016-07-19 17:37:45.005245 3 0 5294 +436 164 2 2016-07-19 11:53:09.473654 2016-07-19 14:49:07.357996 3 0 5007 +435 164 1 2016-07-19 08:08:24.984096 2016-07-19 11:52:45.902268 3 0 5218 +434 164 0 2016-07-18 23:56:56.288799 2016-07-19 08:07:47.751335 3 0 10274 +433 163 4 2016-07-18 20:04:19.654907 2016-07-18 23:52:46.731417 3 0 4781 +432 163 3 2016-07-18 16:04:22.704102 2016-07-18 20:03:23.810347 3 0 4999 +431 163 2 2016-07-18 12:05:26.352906 2016-07-18 16:04:04.444144 3 0 4994 +430 163 1 2016-07-18 08:00:58.635873 2016-07-18 12:05:09.585175 3 0 5111 +429 163 0 2016-07-17 23:21:25.050225 2016-07-18 08:00:22.151495 3 0 10861 +428 162 4 2016-07-17 21:38:07.051352 2016-07-17 23:15:16.668098 3 0 2033 +427 162 3 2016-07-17 17:38:30.104822 2016-07-17 21:37:49.58182 3 0 5009 +426 162 2 2016-07-17 12:58:29.381766 2016-07-17 17:38:13.677446 3 0 5853 +425 162 1 2016-07-17 08:55:34.746756 2016-07-17 12:58:11.714367 3 0 5077 +424 162 0 2016-07-16 23:16:51.437789 2016-07-17 08:55:14.679406 3 0 12106 +423 161 3 2016-07-16 19:09:33.995574 2016-07-16 23:12:46.50245 3 0 5086 +422 161 2 2016-07-16 12:36:38.936827 2016-07-16 19:09:07.789088 3 0 8393 +421 161 1 2016-07-16 09:06:19.364103 2016-07-16 12:36:09.81583 3 0 5017 +420 161 0 2016-07-15 23:14:23.231456 2016-07-16 09:05:54.547918 3 0 14149 +419 160 6 2016-07-15 21:48:47.016195 3 0 +418 160 5 2016-07-15 18:14:31.353865 2016-07-15 21:48:31.424667 3 0 5119 +417 160 4 2016-07-15 14:44:44.895127 2016-07-15 18:14:12.193056 3 0 5008 +416 160 3 2016-07-15 11:09:51.324883 2016-07-15 14:44:24.910426 3 0 5171 +415 160 2 2016-07-15 07:21:34.422058 2016-07-15 11:09:33.232949 3 0 5554 +414 160 1 2016-07-15 03:38:52.41536 2016-07-15 07:21:13.008075 3 0 5319 +413 160 0 2016-07-15 00:04:12.440989 2016-07-15 03:38:34.627856 3 0 5128 +412 159 2 2016-07-14 23:09:39.921304 2016-07-14 23:58:24.842779 3 0 1163 +411 159 1 2016-07-14 19:39:23.119927 2016-07-14 23:09:22.904145 3 0 5025 +410 159 0 2016-07-14 16:06:06.179999 2016-07-14 19:38:59.948081 3 0 5092 +409 158 2 2016-07-14 15:54:36.951346 3 0 +408 158 1 2016-07-14 11:33:32.267432 2016-07-14 15:54:12.092169 3 0 6930 +407 158 0 2016-07-14 08:24:35.944247 2016-07-14 11:33:15.344727 3 0 5083 +406 157 3 2016-07-14 05:34:41.435993 2016-07-14 08:16:09.178812 3 0 3862 +405 157 2 2016-07-14 01:09:26.430955 2016-07-14 05:34:21.311202 3 0 6337 +404 157 1 2016-07-13 21:37:05.869721 2016-07-14 01:09:10.150393 3 0 5071 +403 157 0 2016-07-13 17:48:37.368286 2016-07-13 21:36:41.846254 3 0 5319 +402 156 5 2016-07-13 15:19:34.788966 3 0 +401 156 4 2016-07-13 10:48:48.725298 2016-07-13 15:19:12.783264 3 0 6080 +400 156 3 2016-07-13 04:22:03.872151 2016-07-13 10:46:21.904597 3 0 8043 +399 156 2 2016-07-13 00:10:02.44057 2016-07-13 04:21:40.142236 3 0 5266 +398 156 1 2016-07-12 20:10:28.384397 2016-07-13 00:09:28.190205 3 0 5003 +397 156 0 2016-07-12 16:08:44.044358 2016-07-12 20:09:34.65378 3 0 5040 +396 155 2 2016-07-12 14:28:59.955957 2016-07-12 16:03:55.172177 3 0 2207 +395 155 1 2016-07-12 08:45:05.009964 2016-07-12 14:24:35.206503 3 0 7878 +394 155 0 2016-07-12 00:46:40.108626 2016-07-12 08:44:49.347023 3 0 10007 +393 154 4 2016-07-11 20:49:01.913108 2016-07-12 00:42:01.138368 3 0 4954 +392 154 3 2016-07-11 16:49:31.406868 2016-07-11 20:48:24.272456 3 0 5011 +391 154 2 2016-07-11 12:36:15.430183 2016-07-11 16:49:05.06566 3 0 5014 +390 154 1 2016-07-11 08:22:49.407402 2016-07-11 12:35:55.653129 3 0 5296 +389 154 0 2016-07-11 00:05:46.973518 2016-07-11 08:22:32.028347 3 0 10394 +388 153 5 2016-07-10 20:42:05.750293 2016-07-11 00:01:58.55713 3 0 4184 +387 153 4 2016-07-10 16:48:32.233616 2016-07-10 20:41:46.983171 3 0 4881 +386 153 3 2016-07-10 12:49:17.519118 2016-07-10 16:48:15.553918 3 0 5001 +385 153 2 2016-07-10 08:40:11.000271 2016-07-10 12:49:00.224577 3 0 5207 +384 153 1 2016-07-10 03:19:37.27964 2016-07-10 08:39:48.204082 3 0 6701 +383 153 0 2016-07-10 00:03:39.440563 2016-07-10 03:19:06.642232 3 0 5109 +382 152 4 2016-07-09 19:37:16.185007 2016-07-09 23:58:42.110728 3 0 5471 +381 152 3 2016-07-09 14:18:02.900963 2016-07-09 19:36:57.364018 3 0 6674 +380 152 2 2016-07-09 10:31:40.870122 2016-07-09 14:17:44.542058 3 0 4730 +379 152 1 2016-07-09 06:27:14.485109 2016-07-09 10:31:07.63822 3 0 5103 +378 152 0 2016-07-09 00:05:58.262981 2016-07-09 06:25:29.176514 3 0 7944 +377 151 1 2016-07-08 20:45:03.85948 2016-07-09 00:00:09.957884 3 0 4083 +376 151 0 2016-07-08 16:12:40.758952 2016-07-08 20:44:42.544734 3 0 5693 +375 150 4 2016-07-08 13:07:03.015751 2016-07-08 16:04:16.907913 3 0 3732 +374 150 3 2016-07-08 09:04:26.931058 2016-07-08 13:06:23.400657 3 0 5074 +373 150 2 2016-07-08 05:00:11.635431 2016-07-08 09:04:03.333777 3 0 5103 +372 150 1 2016-07-08 00:58:38.335185 2016-07-08 04:59:37.384402 3 0 5043 +371 150 0 2016-07-07 22:09:03.253551 2016-07-08 00:58:15.555461 3 0 3540 +370 149 5 2016-07-07 21:09:40.908867 3 0 +369 149 4 2016-07-07 17:53:24.61126 2016-07-07 21:09:23.570222 3 0 4881 +368 149 3 2016-07-07 14:32:27.784141 2016-07-07 17:53:11.099926 3 0 5001 +367 149 2 2016-07-07 11:09:04.783929 2016-07-07 14:32:07.077052 3 0 5296 +366 149 1 2016-07-07 08:13:53.756629 2016-07-07 11:05:16.984912 3 0 4507 +365 149 0 2016-07-07 00:20:10.392365 2016-07-07 08:13:33.377275 3 0 11796 +364 148 7 2016-07-06 21:19:30.034677 2016-07-07 00:06:36.508298 3 0 4167 +363 148 6 2016-07-06 16:40:46.001122 2016-07-06 21:17:15.275173 3 0 6889 +362 148 5 2016-07-06 13:26:01.945509 2016-07-06 15:56:29.974485 3 0 3649 +361 148 4 2016-07-06 13:01:51.641948 2016-07-06 13:06:48.626205 3 0 124 +360 148 3 2016-07-06 11:38:50.919214 2016-07-06 11:51:15.392411 3 0 307 +359 148 2 2016-07-06 08:04:05.977308 2016-07-06 11:05:31.250377 3 0 3886 +358 148 1 2016-07-06 08:03:36.169143 2016-07-06 08:03:39.918383 3 0 1 +357 148 0 2016-07-06 03:14:05.886504 2016-07-06 08:03:14.405317 3 0 6052 +356 147 5 2016-07-05 19:38:37.211961 2016-07-06 03:04:25.072985 3 0 7505 +355 147 4 2016-07-05 15:37:18.568563 2016-07-05 19:38:08.341745 3 0 5040 +354 147 3 2016-07-05 11:56:00.428044 2016-07-05 15:09:13.340269 3 0 4040 +353 147 2 2016-07-05 08:27:39.923725 2016-07-05 10:59:22.897282 3 0 3175 +352 147 1 2016-07-05 04:15:02.694045 2016-07-05 08:27:18.980682 3 0 5280 +351 147 0 2016-07-05 00:11:30.703261 2016-07-05 04:14:38.429686 3 0 5089 +350 146 3 2016-07-04 20:03:46.990817 2016-07-05 00:06:46.670789 3 0 5086 +349 146 2 2016-07-04 13:01:07.792098 2016-07-04 20:03:19.776425 3 0 10031 +348 146 1 2016-07-04 04:59:31.507751 2016-07-04 13:00:52.69864 3 0 10074 +347 146 0 2016-07-04 00:09:10.657855 2016-07-04 04:59:07.958176 3 0 6069 +346 145 3 2016-07-03 23:19:30.850962 2016-07-04 00:04:29.522846 3 0 941 +345 145 2 2016-07-03 15:21:21.35732 2016-07-03 23:19:15.749092 3 0 10003 +344 145 1 2016-07-03 08:10:29.2583 2016-07-03 15:21:04.179129 3 0 9012 +343 145 0 2016-07-03 00:07:02.376902 2016-07-03 08:10:07.156932 3 0 9821 +342 144 0 2016-07-02 15:40:15.411418 2016-07-03 00:01:55.206101 3 0 10005 +341 143 0 2016-07-02 11:26:53.386129 3 0 +340 142 1 2016-07-02 08:04:18.614506 3 0 +339 142 0 2016-07-02 00:01:44.74616 2016-07-02 08:03:45.674871 3 0 10090 +338 141 1 2016-07-01 22:31:49.380567 2016-07-01 23:55:34.357664 3 0 1752 +337 141 0 2016-07-01 14:29:48.252554 2016-07-01 22:31:06.15376 3 0 10040 +336 140 0 2016-07-01 12:32:39.70248 2016-07-01 14:28:20.670371 3 0 7260 +335 139 0 2016-07-01 00:16:30.922434 2016-07-01 08:00:59.795142 3 0 6971 +334 138 1 2016-06-30 22:43:20.464133 2016-07-01 00:05:54.686313 3 0 1728 +333 138 0 2016-06-30 19:33:16.868317 2016-06-30 22:41:58.094174 3 0 3949 +332 137 0 2016-06-30 15:08:10.086003 2016-06-30 15:14:32.365009 3 0 0 +331 136 0 2016-06-30 14:30:58.6591 2016-06-30 14:55:42.250048 3 0 0 +330 135 0 2016-06-30 12:10:06.203938 2016-06-30 12:51:54.708512 3 0 18 +329 134 1 2016-06-30 11:22:03.213479 2016-06-30 11:51:49.520796 3 0 317 +328 134 0 2016-06-30 10:08:23.568625 2016-06-30 11:20:19.129463 3 0 1577 +327 133 0 2016-06-30 08:16:04.054168 2016-06-30 10:01:00.689928 0 0 2302 +326 132 0 2016-06-30 06:14:20.284126 2016-06-30 08:15:38.882058 0 0 2552 +325 131 0 2016-06-30 06:11:53.08596 0 0 +324 130 0 2016-06-30 05:13:14.474563 2016-06-30 05:26:24.297708 0 0 269 +323 129 0 2016-06-30 04:08:19.454632 2016-06-30 05:09:51.93345 0 0 1198 +322 128 0 2016-06-30 03:50:01.457656 2016-06-30 04:03:38.487374 0 0 265 +321 127 0 2016-06-29 23:49:38.035594 3 0 +320 126 0 2016-06-29 20:50:09.718202 2016-06-29 21:03:48.215909 3 0 100 +319 125 0 2016-06-29 20:07:40.797024 2016-06-29 20:21:44.461948 3 0 100 +318 124 0 2016-06-29 06:45:53.235002 2016-06-29 06:49:55.081408 3 0 0 +317 123 0 2016-06-29 06:27:15.73131 0 0 +316 122 0 2016-06-29 06:20:06.920515 0 0 +315 121 0 2016-06-29 00:06:56.262777 2016-06-29 06:16:41.214422 3 0 5364 +314 120 1 2016-06-28 20:58:09.758958 2016-06-28 23:56:32.020685 3 0 5868 +313 120 0 2016-06-28 15:22:25.83873 2016-06-28 20:56:36.377644 3 0 10007 +312 119 0 2016-06-28 14:54:48.328181 2016-06-28 15:21:14.040582 3 0 765 +311 118 0 2016-06-28 14:48:20.185336 0 0 +310 117 0 2016-06-28 14:45:46.754126 0 0 +309 116 0 2016-06-28 12:07:46.945432 2016-06-28 14:35:28.064008 3 0 4575 +308 115 0 2016-06-28 12:06:35.871014 3 0 +307 114 0 2016-06-28 08:08:36.349333 2016-06-28 12:03:04.228999 3 0 7488 +306 113 0 2016-06-28 06:48:25.838082 2016-06-28 08:03:42.125168 0 0 2475 +305 112 1 2016-06-27 15:57:18.825822 2016-06-27 23:53:58.564118 3 0 10115 +304 112 0 2016-06-27 08:05:21.716558 2016-06-27 15:56:56.564982 3 0 10002 +303 111 3 2016-06-27 00:17:05.981929 3 0 +302 111 2 2016-06-26 19:19:07.00342 2016-06-27 00:12:17.242028 3 0 5114 +301 111 1 2016-06-26 09:43:18.747112 2016-06-26 19:18:52.1756 3 0 10038 +300 111 0 2016-06-26 00:09:37.205954 2016-06-26 09:43:02.442563 3 0 10001 +299 110 3 2016-06-25 20:11:24.188113 2016-06-26 00:02:50.525491 3 0 5141 +298 110 2 2016-06-25 10:06:24.008779 2016-06-25 20:11:07.658553 3 0 10548 +297 110 1 2016-06-25 00:17:14.884254 2016-06-25 10:00:35.50865 3 0 10180 +296 110 0 2016-06-24 20:35:21.470699 2016-06-25 00:16:57.705612 3 0 3840 +295 109 3 2016-06-24 18:16:05.430253 3 0 +294 109 2 2016-06-24 08:40:51.368518 2016-06-24 18:15:51.572761 3 0 10015 +293 109 1 2016-06-23 22:50:15.398907 2016-06-24 08:37:25.28725 3 0 10243 +292 109 0 2016-06-23 13:16:06.588426 2016-06-23 22:49:36.365824 3 0 10032 +291 108 0 2016-06-23 12:52:11.177421 3 0 +290 107 0 2016-06-23 12:46:43.683716 3 0 +289 106 2 2016-06-23 11:21:10.796697 2016-06-23 12:43:21.750723 3 0 1374 +288 106 1 2016-06-23 01:38:35.46909 2016-06-23 11:20:41.661858 3 0 10152 +287 106 0 2016-06-22 15:37:33.575212 2016-06-23 01:37:40.475462 3 0 10216 +286 105 3 2016-06-22 12:57:04.700752 3 0 +285 105 2 2016-06-22 03:21:18.368816 2016-06-22 12:56:47.338352 3 0 10037 +284 105 1 2016-06-21 17:45:54.550692 2016-06-22 03:21:01.455201 3 0 10032 +283 105 0 2016-06-21 08:12:19.230043 2016-06-21 17:45:12.380396 3 0 10024 +282 104 3 2016-06-21 06:02:42.776153 3 0 +281 104 2 2016-06-20 18:23:01.093355 2016-06-21 06:02:17.227044 3 0 10673 +280 104 1 2016-06-20 08:32:38.313671 2016-06-20 18:21:57.386183 3 0 10005 +279 104 0 2016-06-19 21:23:17.527231 2016-06-20 08:32:25.224102 3 0 9989 +278 103 3 2016-06-19 12:34:39.932263 3 0 +277 103 2 2016-06-19 00:05:51.540451 2016-06-19 12:34:06.036025 3 0 11185 +276 103 1 2016-06-18 19:44:40.507561 2016-06-19 00:05:35.065392 3 0 3901 +275 103 0 2016-06-18 08:30:02.039556 2016-06-18 19:44:20.972359 3 0 10000 +274 102 4 2016-06-18 00:03:45.805715 3 0 +273 102 3 2016-06-17 14:55:20.197362 2016-06-18 00:03:27.830601 3 0 8194 +272 102 2 2016-06-17 10:40:40.575651 2016-06-17 14:34:24.871652 3 0 3494 +271 102 1 2016-06-16 23:28:46.695107 2016-06-17 10:40:03.118742 3 0 10035 +270 102 0 2016-06-16 19:25:42.790001 2016-06-16 23:28:12.343162 3 0 3625 +269 101 6 2016-06-16 14:45:43.4213 3 0 +268 101 5 2016-06-16 11:35:47.051007 2016-06-16 14:45:24.736624 3 0 2835 +267 101 4 2016-06-16 11:13:18.491731 2016-06-16 11:35:24.723835 3 0 331 +266 101 3 2016-06-16 10:36:40.888982 2016-06-16 11:12:56.926519 3 0 544 +265 101 2 2016-06-15 23:43:37.569705 2016-06-16 10:36:11.938832 3 0 10020 +264 101 1 2016-06-15 19:49:15.677098 2016-06-15 23:42:48.888082 3 0 5083 +263 101 0 2016-06-15 11:58:49.352855 2016-06-15 19:48:41.580153 3 0 9980 +262 100 3 2016-06-14 20:22:27.405055 1 0 +261 100 2 2016-06-14 17:22:43.161484 2016-06-14 19:19:18.943799 1 0 10055 +260 100 1 2016-06-14 15:26:11.534529 2016-06-14 17:22:19.525062 1 0 10067 +259 100 0 2016-06-14 14:13:44.675596 2016-06-14 15:19:06.405196 1 0 4391 +258 99 0 2016-06-13 23:30:21.074185 2016-06-13 23:43:00.778302 1 0 1103 +257 98 3 2016-06-13 22:12:15.064975 1 0 +256 98 2 2016-06-13 20:15:43.787692 2016-06-13 22:11:55.091073 1 0 10076 +255 98 1 2016-06-13 18:20:07.412476 2016-06-13 20:15:09.929539 1 0 9980 +254 98 0 2016-06-13 16:20:10.528495 2016-06-13 18:19:48.367158 1 0 10423 +253 97 2 2016-06-13 14:17:50.531238 1 0 +252 97 1 2016-06-13 12:12:52.481886 2016-06-13 14:17:30.410529 1 0 10831 +251 97 0 2016-06-13 09:54:51.616628 2016-06-13 12:12:34.927628 1 0 11985 +250 96 3 2016-06-12 21:37:19.884129 1 0 +249 96 2 2016-06-12 19:41:45.337741 2016-06-12 21:37:07.671683 1 0 10006 +248 96 1 2016-06-12 17:45:44.973511 2016-06-12 19:41:27.705559 1 0 10028 +247 96 0 2016-06-12 15:46:32.01014 2016-06-12 17:45:32.359441 1 0 10359 +246 95 2 2016-06-12 13:01:49.427161 1 0 +245 95 1 2016-06-12 10:27:03.73801 2016-06-12 13:01:11.871697 1 0 13344 +244 95 0 2016-06-12 08:31:52.692468 2016-06-12 10:26:50.564359 1 0 10011 +243 94 1 2016-06-11 21:10:25.202355 2016-06-11 23:07:58.301455 1 0 10194 +242 94 0 2016-06-11 19:12:27.631597 2016-06-11 21:10:03.832428 1 0 10239 +241 93 4 2016-06-11 18:56:06.40121 1 0 +240 93 3 2016-06-11 17:36:20.038653 2016-06-11 17:50:33.620457 1 0 1220 +239 93 2 2016-06-11 15:30:51.11454 2016-06-11 17:36:00.403019 1 0 10777 +238 93 1 2016-06-11 13:30:46.5181 2016-06-11 15:30:21.588187 1 0 10368 +237 93 0 2016-06-11 11:34:54.922913 2016-06-11 13:29:47.404323 1 0 10003 +236 92 2 2016-06-10 22:24:08.608088 2016-06-10 23:49:45.171315 1 0 7428 +235 92 1 2016-06-10 20:28:17.455795 2016-06-10 22:23:37.105911 1 0 9994 +234 92 0 2016-06-10 18:27:42.838596 2016-06-10 20:23:33.66088 1 0 10077 +233 91 3 2016-06-10 17:58:35.082261 2016-06-10 18:17:50.162876 1 0 1652 +232 91 2 2016-06-10 15:57:14.103046 2016-06-10 17:58:20.905515 1 0 10434 +231 91 1 2016-06-10 13:54:39.002246 2016-06-10 15:56:55.937714 1 0 10031 +230 91 0 2016-06-10 11:50:10.651594 2016-06-10 13:52:16.39267 1 0 10584 +229 90 2 2016-06-10 11:41:58.249538 2016-06-10 11:43:53.91078 1 0 166 +228 90 1 2016-06-10 10:03:25.602977 2016-06-10 11:41:24.09332 1 0 8468 +227 90 0 2016-06-10 08:01:31.180985 2016-06-10 10:03:05.93583 1 0 10536 +226 89 0 2016-06-09 22:25:10.994984 2016-06-10 00:00:45.206878 1 0 8282 +225 88 2 2016-06-09 21:30:38.951717 2016-06-09 21:58:34.755631 1 0 2372 +224 88 1 2016-06-09 19:33:55.833398 2016-06-09 21:30:22.462292 1 0 10000 +223 88 0 2016-06-09 17:37:45.312676 2016-06-09 19:33:42.969021 1 0 9999 +222 87 0 2016-06-09 12:53:30.445123 2016-06-09 13:38:15.131516 3 0 266 +221 86 0 2016-06-09 10:59:50.256298 2016-06-09 12:49:36.331533 1 0 10057 +220 85 1 2016-06-09 10:41:25.649244 2016-06-09 10:53:41.892277 1 0 1124 +219 85 0 2016-06-09 09:17:47.609591 2016-06-09 10:40:48.823815 1 0 7607 +218 84 3 2016-06-08 23:36:06.758024 2016-06-08 23:43:44.341158 1 0 678 +217 84 2 2016-06-08 21:46:26.815508 2016-06-08 23:35:50.051559 1 0 10012 +216 84 1 2016-06-08 19:39:19.204897 2016-06-08 21:46:10.93619 1 0 11619 +215 84 0 2016-06-08 17:45:20.065591 2016-06-08 19:38:53.854037 1 0 10400 +214 83 3 2016-06-08 15:45:11.95074 1 0 +213 83 2 2016-06-08 13:54:03.827673 2016-06-08 15:44:52.316787 1 0 10111 +212 83 1 2016-06-08 12:01:24.713469 2016-06-08 13:53:39.971488 1 0 10286 +211 83 0 2016-06-08 10:11:01.130476 2016-06-08 12:01:02.995263 1 0 10085 +210 82 2 2016-06-07 22:31:38.035277 2016-06-07 23:28:15.681533 1 0 5183 +209 82 1 2016-06-07 20:19:18.712553 2016-06-07 22:31:11.455416 1 0 12061 +208 82 0 2016-06-07 18:04:17.8176 2016-06-07 20:18:52.695391 1 0 12335 +207 81 0 2016-06-07 17:57:52.580982 1 0 +206 80 2 2016-06-07 12:27:09.566683 1 0 +205 80 1 2016-06-07 10:29:40.639011 2016-06-07 12:26:47.641831 1 0 10148 +204 80 0 2016-06-07 08:18:45.633722 2016-06-07 10:29:19.104712 1 0 11773 +203 79 0 2016-06-06 22:17:06.635245 2016-06-06 22:38:01.01255 1 0 1918 +202 78 2 2016-06-06 20:57:54.493109 1 0 +201 78 1 2016-06-06 18:19:02.147924 2016-06-06 20:57:35.370402 1 0 13642 +200 78 0 2016-06-06 16:15:41.092955 2016-06-06 18:18:28.53623 1 0 10616 +199 77 0 2016-06-06 08:37:39.910022 2016-06-06 16:14:11.083529 3 0 2408 +198 76 0 2016-06-03 04:48:49.041027 2016-06-03 18:20:14.4308 3 0 4851 +197 75 0 2016-06-03 04:44:22.282956 2016-06-03 04:46:54.291077 2 0 14 +196 74 2 2016-06-03 03:29:59.450719 2016-06-03 04:41:19.79859 3 0 426 +195 74 1 2016-06-02 07:01:18.638497 2016-06-03 03:29:39.527215 3 0 10022 +194 74 0 2016-06-02 02:57:33.21761 2016-06-02 07:00:07.642588 3 0 10155 +193 73 3 2016-06-01 20:06:06.913621 3 0 +192 73 2 2016-06-01 16:05:46.381562 2016-06-01 20:05:44.133383 3 0 10044 +191 73 1 2016-06-01 12:05:46.921206 2016-06-01 16:05:10.273837 3 0 10016 +190 73 0 2016-06-01 08:05:35.712122 2016-06-01 12:05:24.919747 3 0 10037 +189 72 0 2016-06-01 06:05:11.269254 2016-06-01 07:32:47.110128 3 0 3668 +188 71 1 2016-06-01 03:15:08.048251 2016-06-01 06:00:29.940067 3 0 6922 +187 71 0 2016-05-31 23:13:50.797341 2016-06-01 03:14:28.297465 3 0 10075 +186 70 3 2016-05-31 21:32:41.770639 3 0 +185 70 2 2016-05-31 17:32:49.815206 2016-05-31 21:32:24.179166 3 0 10029 +184 70 1 2016-05-31 13:32:58.582329 2016-05-31 17:32:28.698427 3 0 10027 +183 70 0 2016-05-31 09:32:45.792779 2016-05-31 13:32:40.714844 3 0 10042 +182 69 0 2016-05-31 09:24:59.713083 3 0 +181 68 0 2016-05-31 09:22:15.794311 3 0 +180 67 3 2016-05-30 23:53:52.698822 2016-05-31 00:07:28.872722 3 0 568 +179 67 2 2016-05-30 19:52:01.09384 2016-05-30 23:51:36.401906 3 0 10029 +178 67 1 2016-05-30 16:16:36.618042 2016-05-30 19:51:25.328156 3 0 9979 +177 67 0 2016-05-30 13:29:51.076146 2016-05-30 16:16:15.659651 3 0 9976 +176 66 0 2016-05-30 10:11:26.223755 3 0 +175 65 0 2016-05-30 10:09:13.771205 3 0 +174 64 2 2016-05-30 08:09:51.409442 3 0 +173 64 1 2016-05-30 03:07:28.10617 2016-05-30 08:09:18.524034 3 0 12491 +172 64 0 2016-05-29 22:01:34.73858 2016-05-30 03:07:10.47263 3 0 10065 +171 63 0 2016-05-29 20:38:45.452172 3 0 +170 62 0 2016-05-29 20:26:06.71416 3 0 +169 61 0 2016-05-29 20:18:08.454342 3 0 +168 60 0 2016-05-29 20:07:38.298931 3 0 +167 59 0 2016-05-29 16:58:39.223558 3 0 +166 58 1 2016-05-29 12:27:01.435807 2016-05-29 16:54:50.415325 3 0 11210 +165 58 0 2016-05-29 08:27:28.637942 2016-05-29 12:26:42.833158 3 0 10015 +164 57 1 2016-05-29 04:23:26.081787 2016-05-29 08:22:47.084717 3 0 10021 +163 57 0 2016-05-29 00:14:08.162622 2016-05-29 04:23:09.992667 3 0 10425 +162 56 2 2016-05-28 12:51:26.938374 3 0 +161 56 1 2016-05-28 08:42:39.167065 2016-05-28 12:51:08.851123 3 0 10402 +160 56 0 2016-05-28 04:39:39.009956 2016-05-28 08:42:21.215463 3 0 10156 +159 55 3 2016-05-28 03:38:52.666278 3 0 +158 55 2 2016-05-27 23:30:35.202506 2016-05-28 03:38:37.891104 3 0 10383 +157 55 1 2016-05-27 20:06:14.02051 2016-05-27 23:30:09.900544 3 0 10003 +156 55 0 2016-05-27 16:15:30.065753 2016-05-27 20:05:40.429819 3 0 10098 +155 54 4 2016-05-27 14:48:29.853331 2016-05-27 15:44:08.841301 3 0 2331 +154 54 3 2016-05-27 10:29:09.012656 2016-05-27 14:48:07.118613 3 0 10995 +153 54 2 2016-05-27 09:33:21.575443 2016-05-27 10:27:28.454412 3 0 1349 +152 54 1 2016-05-27 06:31:44.846315 2016-05-27 09:32:52.439265 3 0 6751 +151 54 0 2016-05-27 02:27:47.208924 2016-05-27 06:31:24.986082 3 0 10199 +150 53 1 2016-05-26 22:54:38.638545 3 0 +149 53 0 2016-05-26 18:30:42.006549 2016-05-26 22:48:01.321183 3 0 10774 +148 52 1 2016-05-26 13:05:29.985464 2016-05-26 15:32:48.486369 3 0 6165 +147 52 0 2016-05-26 09:04:03.610065 2016-05-26 13:04:54.733157 3 0 10082 +146 51 9 2016-05-26 01:39:55.028928 2016-05-26 03:24:50.376194 0 0 8469 +145 51 8 2016-05-25 23:31:01.931876 2016-05-26 01:39:09.464383 0 0 10474 +144 51 7 2016-05-25 21:14:13.755672 2016-05-25 23:30:30.68352 0 0 11255 +143 51 6 2016-05-25 18:50:34.428213 2016-05-25 21:08:58.828793 0 0 11556 +142 51 5 2016-05-25 16:50:28.18607 2016-05-25 18:49:42.258973 0 0 10145 +141 51 4 2016-05-25 14:51:02.011215 2016-05-25 16:49:31.276612 0 0 10023 +140 51 3 2016-05-25 12:51:03.184016 2016-05-25 14:50:32.988656 0 0 10116 +139 51 2 2016-05-25 11:40:05.861501 2016-05-25 12:50:39.512448 0 0 5978 +138 51 1 2016-05-25 09:38:05.061715 2016-05-25 11:39:22.594528 0 0 10112 +137 51 0 2016-05-25 07:41:30.372412 2016-05-25 09:37:19.446988 0 0 9353 +136 50 0 2016-05-25 06:30:00.378562 2016-05-25 06:31:59.759691 0 0 72 +135 49 0 2016-05-25 06:23:38.769309 0 0 +134 48 5 2016-05-25 03:25:50.137914 2016-05-25 04:03:31.112716 0 0 3158 +133 48 4 2016-05-25 01:21:00.276866 2016-05-25 03:24:17.306007 0 0 10326 +132 48 3 2016-05-24 23:10:17.507167 2016-05-25 01:19:04.577729 0 0 10786 +131 48 2 2016-05-24 20:55:15.514196 2016-05-24 23:09:14.421926 0 0 11232 +130 48 1 2016-05-24 18:51:44.1728 2016-05-24 20:54:24.573796 0 0 10283 +129 48 0 2016-05-24 15:53:24.02056 2016-05-24 18:51:08.895981 0 0 14892 +128 47 1 2016-05-24 15:32:32.807941 2016-05-24 15:35:09.339955 0 +127 47 0 2016-05-24 12:19:33.351769 2016-05-24 15:30:23.409956 0 0 +126 46 0 2016-05-24 12:15:42.648561 3 0 +125 45 0 2016-05-24 12:00:38.529634 2016-05-24 12:01:03.206 3 0 18 +124 44 0 2016-05-24 11:52:33.351429 2016-05-24 11:52:37.2524 3 0 3 +123 43 0 2016-05-24 11:48:56.059534 2016-05-24 11:49:23.081761 3 0 20 +122 42 0 2016-05-24 08:25:58.671708 3 0 +121 41 6 2016-05-24 03:38:51.909374 2016-05-24 05:52:11.384913 0 0 10035 +120 41 5 2016-05-24 01:25:20.653632 2016-05-24 03:38:07.940505 0 0 10334 +119 41 4 2016-05-23 23:11:45.827146 2016-05-24 01:24:24.652437 0 0 10551 +118 41 3 2016-05-23 21:07:16.526156 2016-05-23 23:11:07.151946 0 0 9983 +117 41 2 2016-05-23 19:12:43.396594 2016-05-23 21:04:43.282403 0 0 9231 +116 41 1 2016-05-23 16:35:04.920225 2016-05-23 19:11:58.368503 0 0 13132 +115 41 0 2016-05-23 14:22:50.790441 2016-05-23 16:34:30.929902 0 0 11006 +114 40 6 2016-05-22 18:45:10.817764 2016-05-22 20:09:23.349296 0 0 7201 +113 40 5 2016-05-22 16:48:30.189866 2016-05-22 18:40:05.440314 0 0 9540 +112 40 4 2016-05-22 15:14:53.129297 2016-05-22 16:40:47.564858 0 0 7343 +111 40 3 2016-05-22 15:04:14.936327 2016-05-22 15:14:15.548675 0 0 855 +110 40 2 2016-05-22 13:54:19.005574 2016-05-22 15:02:35.538092 0 0 5830 +109 40 1 2016-05-22 11:12:15.647362 2016-05-22 13:49:16.783984 0 0 13408 +108 40 0 2016-05-22 10:40:33.128528 2016-05-22 11:11:51.850002 0 0 2671 +107 39 3 2016-05-21 17:16:17.685069 2016-05-21 20:39:43.659399 0 0 17371 +106 39 2 2016-05-21 14:44:48.439653 2016-05-21 17:10:29.551181 0 0 12440 +105 39 1 2016-05-21 12:18:08.53985 2016-05-21 14:39:50.990253 0 0 12099 +104 39 0 2016-05-21 11:12:13.877928 2016-05-21 12:16:43.398118 0 0 5065 +103 38 0 2016-05-20 19:04:10.106316 2016-05-20 19:15:37.815191 0 0 611 +102 37 0 2016-05-20 16:33:39.582966 2016-05-20 18:18:43.872974 0 0 6637 +101 36 9 2016-05-20 13:52:21.752376 2016-05-20 16:31:40.276397 0 0 9998 +100 36 8 2016-05-20 10:58:55.590429 2016-05-20 13:51:55.543689 0 0 10232 +99 36 7 2016-05-20 07:37:18.898156 2016-05-20 10:58:29.065344 0 0 11271 +98 36 6 2016-05-20 04:23:14.752727 2016-05-20 07:36:52.426421 0 0 10964 +97 36 5 2016-05-20 01:03:38.831035 2016-05-20 04:22:50.165542 0 0 12062 +96 36 4 2016-05-19 22:20:22.150653 2016-05-20 01:02:41.559234 0 0 10173 +95 36 3 2016-05-19 19:43:55.499073 2016-05-19 22:19:54.794539 0 0 10248 +94 36 2 2016-05-19 17:02:05.757894 2016-05-19 19:43:27.575186 0 0 10773 +93 36 1 2016-05-19 14:37:36.722063 2016-05-19 17:01:35.778208 0 0 9768 +92 36 0 2016-05-19 11:51:06.989966 2016-05-19 14:35:55.421089 0 0 10570 +91 35 2 2016-05-19 11:19:22.028726 2016-05-19 11:47:19.463556 0 0 1734 +90 35 1 2016-05-19 11:08:42.927144 2016-05-19 11:12:28.806686 0 0 312 +89 35 0 2016-05-19 11:00:33.840401 2016-05-19 11:03:53.259937 0 0 207 +88 34 5 2016-05-19 05:30:30.396843 2016-05-19 10:41:04.230995 0 0 16142 +87 34 4 2016-05-19 02:09:40.252581 2016-05-19 05:29:32.805683 0 0 10073 +86 34 3 2016-05-18 23:13:35.822736 2016-05-19 02:09:11.336051 0 0 10112 +85 34 2 2016-05-18 20:30:51.915559 2016-05-18 23:12:54.066014 0 0 10041 +84 34 1 2016-05-18 17:50:17.568833 2016-05-18 20:30:21.308909 0 0 10045 +83 34 0 2016-05-18 14:45:35.360795 2016-05-18 17:49:50.640576 0 0 11341 +82 33 7 2016-05-18 10:37:05.549067 2016-05-18 14:38:12.52469 0 0 14198 +81 33 6 2016-05-18 06:14:40.632105 2016-05-18 10:36:42.651064 0 0 12472 +80 33 5 2016-05-18 02:54:50.009455 2016-05-18 06:13:46.101436 0 0 9076 +79 33 4 2016-05-17 23:36:21.481475 2016-05-18 02:54:04.31247 0 0 10407 +78 33 3 2016-05-17 20:40:37.075997 2016-05-17 23:35:51.994223 0 0 10303 +77 33 2 2016-05-17 17:54:58.006968 2016-05-17 20:40:05.707951 0 0 10059 +76 33 1 2016-05-17 15:03:11.358836 2016-05-17 17:54:32.25868 0 0 10601 +75 33 0 2016-05-17 13:26:55.268016 2016-05-17 15:00:22.467905 0 0 5876 +74 32 8 2016-05-17 11:57:24.494573 2016-05-17 13:25:03.719424 0 0 5608 +73 32 7 2016-05-17 06:17:00.386118 2016-05-17 11:56:48.901627 0 0 20675 +72 32 6 2016-05-17 03:28:39.196184 2016-05-17 06:15:21.227673 0 0 10233 +71 32 5 2016-05-16 22:38:56.48323 2016-05-17 03:27:20.25312 0 0 18182 +70 32 4 2016-05-16 20:03:37.222629 2016-05-16 22:38:31.082104 0 0 10126 +69 32 3 2016-05-16 17:25:23.357252 2016-05-16 20:03:04.362314 0 0 10086 +68 32 2 2016-05-16 14:27:57.336207 2016-05-16 17:24:59.516093 0 0 10993 +67 32 1 2016-05-16 11:35:27.568292 2016-05-16 14:27:30.439801 0 0 10251 +66 32 0 2016-05-16 08:25:22.103646 2016-05-16 11:35:13.627256 0 0 9886 +65 31 0 2016-05-15 17:42:40.671957 2016-05-15 23:09:46.158239 0 0 16154 +64 30 0 2016-05-15 17:23:24.703813 2016-05-15 17:23:43.881186 0 0 24 +63 29 2 2016-05-14 19:31:33.570239 2016-05-14 22:30:22.083639 0 0 7669 +62 29 1 2016-05-14 14:45:15.040724 2016-05-14 19:31:12.901991 0 0 12630 +61 29 0 2016-05-14 11:23:45.289362 2016-05-14 14:44:45.559094 0 0 8720 +60 28 3 2016-05-13 19:30:26.022356 2016-05-13 22:47:11.169912 0 0 10941 +59 28 2 2016-05-13 15:57:43.681911 2016-05-13 19:29:51.51761 0 0 13664 +58 28 1 2016-05-13 13:48:49.623573 2016-05-13 15:51:54.84614 0 0 7088 +57 28 0 2016-05-13 10:09:26.179909 2016-05-13 13:48:11.146121 0 0 9056 +56 27 4 2016-05-12 19:25:55.614979 2016-05-12 23:17:29.561911 0 0 13890 +55 27 3 2016-05-12 16:57:51.99417 2016-05-12 19:25:20.878962 0 0 9657 +54 27 2 2016-05-12 14:30:50.451962 2016-05-12 16:57:25.927617 0 0 9725 +53 27 1 2016-05-12 12:15:35.953015 2016-05-12 14:30:19.352109 0 0 8254 +52 27 0 2016-05-12 09:02:36.645135 2016-05-12 12:15:07.024471 0 0 11506 +51 26 1 2016-05-11 20:44:13.789662 2016-05-11 23:22:43.356574 0 0 10424 +50 26 0 2016-05-11 18:16:55.62915 2016-05-11 20:43:43.792193 0 0 10388 +49 25 0 2016-05-11 17:48:34.591773 2016-05-11 18:12:43.50752 0 0 2015 +48 24 1 2016-05-10 23:27:00.372748 2016-05-11 00:48:16.012305 0 0 2214 +47 24 0 2016-05-10 16:42:39.483555 2016-05-10 23:25:43.890419 0 0 11637 +46 23 0 2016-05-10 14:06:28.56647 2016-05-10 16:41:01.8988 0 0 4116 +45 22 0 2016-05-10 11:38:38.651115 2016-05-10 14:01:58.37402 0 0 2843 +44 21 0 2016-05-10 11:02:29.21943 2016-05-10 11:35:56.372651 0 0 720 +43 20 1 2016-05-09 19:28:00.673664 2016-05-09 21:39:20.722227 0 0 7293 +42 20 0 2016-05-09 18:14:37.135821 2016-05-09 19:26:05.332569 0 0 3889 +41 19 0 2016-05-04 21:07:25.358498 2016-05-05 02:07:53.973066 0 0 10961 +40 18 0 2016-05-04 20:16:04.403837 2016-05-04 20:47:48.611427 0 0 1158 +39 17 1 2016-05-04 14:46:07.471137 2016-05-04 19:53:30.405752 0 0 11245 +38 17 0 2016-05-04 10:42:39.922499 2016-05-04 14:45:42.792689 0 0 8908 +37 16 1 2016-05-03 14:07:05.82874 2016-05-03 18:32:21.041293 0 0 9676 +36 16 0 2016-05-03 10:24:18.66907 2016-05-03 14:06:40.794905 0 0 7973 +35 15 1 2016-05-02 15:38:33.000143 2016-05-02 18:31:16.487707 0 0 6301 +34 15 0 2016-05-02 11:17:26.85596 2016-05-02 15:38:04.664196 0 0 9506 +33 14 2 2016-04-29 15:25:15.392007 2016-04-29 18:32:02.246131 0 0 6879 +32 14 1 2016-04-29 14:26:06.271164 2016-04-29 15:24:50.166753 0 0 2978 +31 14 0 2016-04-29 11:52:39.465936 2016-04-29 14:25:38.869814 0 0 5580 +30 13 1 2016-04-28 15:12:05.158402 2016-04-28 19:20:14.724253 0 0 9074 +29 13 0 2016-04-28 14:34:28.061766 2016-04-28 14:53:59.756818 0 0 720 +28 12 6 2016-04-28 12:25:56.011196 2016-04-28 14:22:37.234846 0 0 9855 +27 12 5 2016-04-28 10:36:53.480954 2016-04-28 12:18:01.319345 0 0 8500 +26 12 4 2016-04-27 16:51:57.088463 2016-04-27 18:20:41.167382 0 0 7498 +25 12 3 2016-04-27 15:08:07.251064 2016-04-27 16:42:35.287035 0 0 7972 +24 12 2 2016-04-27 12:49:26.660989 2016-04-27 15:06:29.007772 0 0 8580 +23 12 1 2016-04-27 12:37:58.125829 2016-04-27 12:47:11.960434 0 0 569 +22 12 0 2016-04-27 10:24:27.170081 2016-04-27 12:20:08.817012 0 0 9768 +21 11 3 2016-04-26 17:49:51.642298 2016-04-26 18:20:34.331013 0 0 1804 +20 11 2 2016-04-26 17:12:58.402159 2016-04-26 17:48:04.601868 0 0 2966 +19 11 1 2016-04-26 16:50:04.242586 2016-04-26 17:07:57.940159 0 0 1510 +18 11 0 2016-04-26 16:00:31.6924 2016-04-26 16:26:49.830104 0 0 2217 +17 10 0 2016-04-26 09:35:38.481366 2016-04-26 09:55:50.765771 0 0 0 +16 9 0 2016-04-26 05:10:39.316487 2016-04-26 05:11:55.029318 0 0 0 +15 8 0 2016-04-25 17:26:38.143027 2016-04-25 18:34:56.999301 0 0 0 +14 7 1 2016-04-17 08:44:27.210053 2016-04-17 08:59:27.096122 0 0 627 +13 7 0 2016-04-16 10:07:32.242394 2016-04-16 21:50:44.218957 0 0 29224 +12 6 0 2016-04-16 09:53:57.997992 2016-04-16 10:04:01.605403 0 0 422 +11 5 0 2016-04-16 09:46:34.850404 2016-04-16 09:52:52.728552 0 0 262 +10 4 0 2016-04-16 09:33:24.910606 2016-04-16 09:45:38.877933 0 0 513 +9 3 1 2016-04-15 14:34:30.621283 2016-04-15 18:57:51.067297 0 0 11023 +8 3 0 2016-04-15 14:13:06.012877 2016-04-15 14:33:57.29442 0 0 874 +7 2 0 2016-04-15 12:23:44.523089 0 0 +6 1 4 2016-04-14 18:23:05.530959 2016-04-14 18:26:46.676785 0 0 305 +5 1 3 2016-04-14 17:47:56.109177 2016-04-14 18:22:42.902513 0 0 2880 +4 1 2 2016-04-14 16:38:43.780336 2016-04-14 17:47:42.847734 0 0 5713 +3 1 1 2016-04-14 16:06:37.438656 2016-04-14 16:37:40.1732 0 0 2571 +2 1 0 2016-04-14 15:49:48.229376 2016-04-14 16:06:16.627172 0 0 1365 + diff --git a/configfiles/BeamFetcher/BeamFetcherConfig b/configfiles/BeamFetcher/BeamFetcherConfig index 36c6fb4d8..fe9b256f6 100644 --- a/configfiles/BeamFetcher/BeamFetcherConfig +++ b/configfiles/BeamFetcher/BeamFetcherConfig @@ -2,8 +2,8 @@ verbose 5 OutputFile ./2369_beamdb TimestampMode DB #Options: MSEC / LOCALDATE / DB -DaylightSavings 0 -RunNumber 2280 +DaylightSavings 1 +RunNumber 4314 StartDate ./configfiles/BeamFetcher/my_start_date.txt EndDate ./configfiles/BeamFetcher/my_end_date.txt #StartMillisecondsSinceEpoch 1498246528696 diff --git a/configfiles/BeamFetcher/LoadRunInfoConfig b/configfiles/BeamFetcher/LoadRunInfoConfig index 58e7fa730..3d7217a28 100644 --- a/configfiles/BeamFetcher/LoadRunInfoConfig +++ b/configfiles/BeamFetcher/LoadRunInfoConfig @@ -1,4 +1,4 @@ #LoadRunInfo Config verbosity 1 -RunInfoFile /pnfs/annie/persistent/users/mnieslon/data/runinfo/ANNIE_RunInformation_PSQL.txt +RunInfoFile ./configfiles/BeamFetcher/ANNIE_RunInformation_PSQL.txt diff --git a/configfiles/EventBuilder/ANNIEEventBuilderConfig b/configfiles/EventBuilder/ANNIEEventBuilderConfig new file mode 100644 index 000000000..6d59474bf --- /dev/null +++ b/configfiles/EventBuilder/ANNIEEventBuilderConfig @@ -0,0 +1,20 @@ +verbosity 0 + +BuildType TankAndMRDAndCTC +ProcessedFilesBasename ProcessedRawData +NumEventsPerPairing 200 +SavePath ./ + +MinNumWavesInSet 134 # 1=Just throw any waveforms into ANNIE events if you got em + +ExecutesPerBuild 10 +OrphanOldTankTimestamps 1 +OldTimestampThreshold 1000 +OrphanFileBase OrphanStore +MaxStreamMatchingTimeSeparation 60 # seconds. If one stream is ahead of the others, pause reading + +SaveRawData 0 +StoreBeamStatus 0 + +BuildStage1Data 0 +SaveSeparatePartfiles 1 diff --git a/configfiles/EventBuilder/BeamDecoderConfig b/configfiles/EventBuilder/BeamDecoderConfig new file mode 100644 index 000000000..3866c2b30 --- /dev/null +++ b/configfiles/EventBuilder/BeamDecoderConfig @@ -0,0 +1,17 @@ +# BeamDecoder config file +verbosity 0 +# Names of devices needed for beam quality cuts +HornCurrentDevice E:THCURR +# The "first" toroid is the one farther upstream from the target +FirstToroid E:TOR860 +SecondToroid E:TOR875 +# POT window +CutPOTMin 5e11 +CutPOTMax 8e12 +# Peak horn current window (in kA) +CutPeakHornCurrentMin 172 +CutPeakHornCurrentMax 176 +# Toroid agreement tolerance (fractional error) +CutToroidAgreement 0.05 +# DB vs DAQ timestamp agreement tolerance (ms) +CutTimestampAgreement 100 diff --git a/configfiles/EventBuilder/DefaultTriggerMask.txt b/configfiles/EventBuilder/DefaultTriggerMask.txt new file mode 100644 index 000000000..398850355 --- /dev/null +++ b/configfiles/EventBuilder/DefaultTriggerMask.txt @@ -0,0 +1,10 @@ +#Triggers are given by Jonathan; place one number per line. Values are index + 1 +#4+1: Delayed beam. 32+1: LED trigger. 34+1: AmBe and Cosmic trigger. 35+1: MRD_CR_Trigger. 30+1: LED_Start. 45+1, 46+1: Laser. 14+1: AmBe external trigger +5 +15 +36 +31 +33 +35 +46 +47 diff --git a/configfiles/EventBuilder/LoadGeometryConfig b/configfiles/EventBuilder/LoadGeometryConfig new file mode 100644 index 000000000..c64227136 --- /dev/null +++ b/configfiles/EventBuilder/LoadGeometryConfig @@ -0,0 +1,8 @@ +verbosity 0 +LAPPDChannelCount 60 +FACCMRDGeoFile ./configfiles/LoadGeometry/FullMRDGeometry.csv +DetectorGeoFile ./configfiles/LoadGeometry/DetectorGeometrySpecs.csv +LAPPDGeoFile ./configfiles/LoadGeometry/LAPPDGeometry.csv +TankPMTGeoFile ./configfiles/LoadGeometry/FullTankPMTGeometry.csv +TankPMTGainFile ./configfiles/LoadGeometry/ChannelSPEGains2023.csv +AuxiliaryChannelFile ./configfiles/LoadGeometry/AuxChannels.csv diff --git a/configfiles/EventBuilder/LoadRawDataConfig b/configfiles/EventBuilder/LoadRawDataConfig new file mode 100644 index 000000000..658744545 --- /dev/null +++ b/configfiles/EventBuilder/LoadRawDataConfig @@ -0,0 +1,9 @@ +verbosity 0 +BuildType TankAndMRDAndCTC +#BuildType CTC +Mode FileList +InputFile ./configfiles/EventBuilder/my_files.txt +DummyRunInfo 1 +StoreTrigOverlap 0 +ReadTrigOverlap 1 +StoreRawData 0 diff --git a/configfiles/EventBuilder/MRDDataDecoderConfig b/configfiles/EventBuilder/MRDDataDecoderConfig new file mode 100644 index 000000000..4f4260f01 --- /dev/null +++ b/configfiles/EventBuilder/MRDDataDecoderConfig @@ -0,0 +1,2 @@ +verbosity 2 +DaylightSavingsSpring 1 diff --git a/configfiles/EventBuilder/PMTDataDecoderConfig b/configfiles/EventBuilder/PMTDataDecoderConfig new file mode 100644 index 000000000..19e946601 --- /dev/null +++ b/configfiles/EventBuilder/PMTDataDecoderConfig @@ -0,0 +1,5 @@ +verbosity 0 +ADCCountsToBuildWaves 0 +Mode Offline +OffsetVME03 0 +OffsetVME01 0 diff --git a/configfiles/EventBuilder/PhaseIIADCCalibratorConfig b/configfiles/EventBuilder/PhaseIIADCCalibratorConfig new file mode 100644 index 000000000..158dc6ed1 --- /dev/null +++ b/configfiles/EventBuilder/PhaseIIADCCalibratorConfig @@ -0,0 +1,15 @@ +# PhaseIIADCCalibrator config file + +verbosity 0 + +BaselineEstimationType ze3ra_multi +NumBaselineSamples 15 +NumSubWaveforms 10 + +SamplesPerBaselineEstimate 2000 +BaselineUncertaintyTolerance 2 +PCritical 0.01 +MakeCalLEDWaveforms 0 + +EventBuilding 1 +ExecutesPerBuild 10 diff --git a/configfiles/EventBuilder/PhaseIIADCHitFinderConfig b/configfiles/EventBuilder/PhaseIIADCHitFinderConfig new file mode 100644 index 000000000..d183b7b27 --- /dev/null +++ b/configfiles/EventBuilder/PhaseIIADCHitFinderConfig @@ -0,0 +1,10 @@ +verbosity 0 + +UseLEDWaveforms 0 + +PulseFindingApproach threshold +PulseWindowType dynamic +DefaultADCThreshold 7 +DefaultThresholdType relative + +EventBuilding 1 diff --git a/configfiles/EventBuilder/SaveConfigInfoConfig b/configfiles/EventBuilder/SaveConfigInfoConfig new file mode 100644 index 000000000..a65d2aab4 --- /dev/null +++ b/configfiles/EventBuilder/SaveConfigInfoConfig @@ -0,0 +1,3 @@ +verbosity 5 +OutFileName config_info.txt +FullDepth 1 diff --git a/configfiles/EventBuilder/ToolChainConfig b/configfiles/EventBuilder/ToolChainConfig new file mode 100644 index 000000000..f812795c9 --- /dev/null +++ b/configfiles/EventBuilder/ToolChainConfig @@ -0,0 +1,23 @@ +#ToolChain dynamic setup file + +##### Runtime Paramiters ##### +verbose 1 +error_level 0 # 0= do not exit, 1= exit on unhandeled errors only, 2= exit on unhandeled errors and handeled errors +attempt_recover 1 + +###### Logging ##### +log_mode Interactive # Interactive=cout , Remote= remote logging system "serservice_name Remote_Logging" , Local = local file log; +log_local_path ./log +log_service LogStore + +###### Service discovery ##### +service_publish_sec -1 +service_kick_sec -1 + +##### Tools To Add ##### +Tools_File ./configfiles/EventBuilder/ToolsConfig + +##### Run Type ##### +Inline -1 +Interactive 0 + diff --git a/configfiles/EventBuilder/ToolsConfig b/configfiles/EventBuilder/ToolsConfig new file mode 100644 index 000000000..95cc19f24 --- /dev/null +++ b/configfiles/EventBuilder/ToolsConfig @@ -0,0 +1,9 @@ +LoadGeometry LoadGeometry ./configfiles/LoadGeometry/LoadGeometryConfig +LoadRawData LoadRawData ./configfiles/EventBuilder/LoadRawDataConfig +PMTDataDecoder PMTDataDecoder ./configfiles/EventBuilder/PMTDataDecoderConfig +MRDDataDecoder MRDDataDecoder ./configfiles/EventBuilder/MRDDataDecoderConfig +TriggerDataDecoder TriggerDataDecoder ./configfiles/EventBuilder/TriggerDataDecoderConfig +PhaseIIADCCalibrator PhaseIIADCCalibrator ./configfiles/EventBuilder/PhaseIIADCCalibratorConfig +PhaseIIADCHitFinder PhaseIIADCHitFinder ./configfiles/EventBuilder/PhaseIIADCHitFinderConfig +SaveConfigInfo SaveConfigInfo ./configfiles/EventBuilder/SaveConfigInfoConfig +ANNIEEventBuilder ANNIEEventBuilder ./configfiles/EventBuilder/ANNIEEventBuilderConfig diff --git a/configfiles/EventBuilder/TriggerDataDecoderConfig b/configfiles/EventBuilder/TriggerDataDecoderConfig new file mode 100644 index 000000000..e81c70f34 --- /dev/null +++ b/configfiles/EventBuilder/TriggerDataDecoderConfig @@ -0,0 +1,4 @@ +verbosity 0 +TriggerMaskFile ./configfiles/EventBuilder/DefaultTriggerMask.txt +StoreTrigOverlap 0 +ReadTrigOverlap 0 diff --git a/configfiles/EventBuilder/my_files.txt b/configfiles/EventBuilder/my_files.txt new file mode 100644 index 000000000..8c8399ef2 --- /dev/null +++ b/configfiles/EventBuilder/my_files.txt @@ -0,0 +1,2 @@ +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p0 +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p1 diff --git a/configfiles/LoadGeometry/ChannelSPEGains2023.csv b/configfiles/LoadGeometry/ChannelSPEGains2023.csv new file mode 100644 index 000000000..a54a43f7b --- /dev/null +++ b/configfiles/LoadGeometry/ChannelSPEGains2023.csv @@ -0,0 +1,125 @@ +#Offline_Tubes: 333,346,349,352,431,444 +#Dead_Tubes: 337,342,345,416,445 +#Sinusoidal_Tubes +#Channelkey,SPE_Gain +332,0.001345 +334,0.001421 +335,0.001375 +336,0.001222 +338,0.001387 +339,0.001038 +340,0.001248 +341,0.001543 +343,0.000267 +344,0.001334 +347,0.001570 +348,0.001478 +350,0.001290 +351,0.001455 +353,0.000380 +354,0.001767 +355,0.001198 +356,0.000478 +357,0.001922 +358,0.000923 +359,0.000281 +360,0.001380 +361,0.000748 +362,0.001344 +363,0.001367 +364,0.001223 +365,0.001003 +366,0.000631 +367,0.001649 +368,0.001776 +369,0.000722 +370,0.001148 +371,0.001657 +372,0.001653 +373,0.001443 +374,0.001435 +375,0.001382 +376,0.001476 +377,0.001466 +378,0.001382 +379,0.001521 +380,0.001265 +381,0.001465 +382,0.001248 +383,0.001465 +384,0.001618 +385,0.001540 +386,0.001438 +387,0.001528 +388,0.001353 +389,0.001616 +390,0.001268 +391,0.001271 +392,0.001406 +393,0.001628 +394,0.001487 +395,0.001701 +396,0.001678 +397,0.001547 +398,0.001368 +399,0.001428 +400,0.001328 +401,0.001480 +402,0.001311 +403,0.001130 +404,0.001569 +405,0.000906 +406,0.001542 +407,0.001491 +408,0.001396 +409,0.001414 +410,0.001386 +411,0.001278 +412,0.001401 +413,0.001499 +414,0.001488 +415,0.001217 +417,0.001468 +418,0.001457 +419,0.001248 +420,0.001744 +421,0.001398 +422,0.001409 +423,0.001324 +424,0.001548 +425,0.001455 +426,0.001274 +427,0.001316 +428,0.001420 +429,0.001338 +430,0.001515 +432,0.001307 +433,0.001279 +434,0.001357 +435,0.001416 +436,0.001345 +437,0.001448 +438,0.001350 +439,0.001398 +440,0.001487 +441,0.001459 +442,0.001291 +443,0.001236 +446,0.001495 +447,0.001373 +448,0.001353 +449,0.001375 +450,0.001321 +451,0.001302 +452,0.001618 +453,0.001466 +454,0.001241 +455,0.001388 +456,0.001535 +457,0.001650 +458,0.001478 +459,0.001360 +460,0.001463 +461,0.001375 +462,0.001420 +463,0.001396 diff --git a/configfiles/LoadGeometry/LoadGeometryConfig b/configfiles/LoadGeometry/LoadGeometryConfig index 3d8ce96bc..693f546d2 100644 --- a/configfiles/LoadGeometry/LoadGeometryConfig +++ b/configfiles/LoadGeometry/LoadGeometryConfig @@ -5,5 +5,5 @@ FACCMRDGeoFile ./configfiles/LoadGeometry/FullMRDGeometry_09_29_20.csv DetectorGeoFile ./configfiles/LoadGeometry/DetectorGeometrySpecs.csv LAPPDGeoFile ./configfiles/LoadGeometry/LAPPDGeometry.csv TankPMTGeoFile ./configfiles/LoadGeometry/FullTankPMTGeometry.csv -TankPMTGainFile ./configfiles/LoadGeometry/ChannelSPEGains_BeamRun20192020.csv +TankPMTGainFile ./configfiles/LoadGeometry/ChannelSPEGains2023.csv AuxiliaryChannelFile ./configfiles/LoadGeometry/AuxChannels.csv diff --git a/configfiles/PreProcessTrigOverlap/TriggerDataDecoderConfig b/configfiles/PreProcessTrigOverlap/TriggerDataDecoderConfig index abfe77896..00b6bc1e6 100644 --- a/configfiles/PreProcessTrigOverlap/TriggerDataDecoderConfig +++ b/configfiles/PreProcessTrigOverlap/TriggerDataDecoderConfig @@ -1,5 +1,5 @@ verbosity 2 -TriggerMaskFile ./configfiles/DataDecoder/DefaultTriggerMask.txt +TriggerMaskFile ./configfiles/EventBuilder/DefaultTriggerMask.txt StoreTrigOverlap 1 ReadTrigOverlap 0 UseCStore 0 diff --git a/configfiles/PreProcessTrigOverlap/my_files.txt b/configfiles/PreProcessTrigOverlap/my_files.txt index 67e6767d1..8c8399ef2 100644 --- a/configfiles/PreProcessTrigOverlap/my_files.txt +++ b/configfiles/PreProcessTrigOverlap/my_files.txt @@ -1,96 +1,2 @@ -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p0 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p1 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p2 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p3 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p4 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p5 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p6 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p7 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p8 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p9 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p10 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p11 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p12 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p13 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p14 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p15 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p16 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p17 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p18 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p19 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p20 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p21 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p22 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p23 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p24 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p25 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p26 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p27 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p28 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p29 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p30 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p31 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p32 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p33 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p34 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p35 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p36 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p37 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p38 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p39 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p40 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p41 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p42 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p43 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p44 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p45 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p46 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p47 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p48 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p49 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p50 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p51 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p52 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p53 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p54 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p55 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p56 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p57 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p58 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p59 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p60 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p61 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p62 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p63 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p64 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p65 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p66 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p67 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p68 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p69 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p70 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p71 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p72 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p73 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p74 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p75 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p76 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p77 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p78 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p79 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p80 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p81 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p82 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p83 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p84 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p85 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p86 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p87 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p88 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p89 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p90 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p91 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p92 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p93 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p94 -/pnfs/annie/raw/raw/2421//RAWDataR2421S0p95 +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p0 +/pnfs/annie/persistent/raw/raw/4314/RAWDataR4314S0p1 From addad85d534b088e04f4202bf62c37c6812d9ebf Mon Sep 17 00:00:00 2001 From: marc1uk Date: Tue, 6 Feb 2024 15:56:50 +0000 Subject: [PATCH 15/31] update CI workflow for extra disk space test removal of potentially unneeded packages to maximize available disk space --- .github/workflows/tempbuild.yml | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index 932992cd3..e36f1aefc 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -19,6 +19,13 @@ jobs: - name: prerequisits run: yum install -y git make gcc-c++ which wget - name: build - run: echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make + run: + # Workaround to provide additional free space for testing. + # https://github.com/actions/virtual-environments/issues/2840 + sudo rm -rf /usr/share/dotnet + sudo rm -rf /opt/ghc + sudo rm -rf "/usr/local/share/boost" + sudo rm -rf "$AGENT_TOOLSDIRECTORY" + echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make - name: test run : source ./Setup.sh && ./Analyse From 78d62f50f4b742079c92433172181384e5dbd465 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Tue, 6 Feb 2024 16:07:01 +0000 Subject: [PATCH 16/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index e36f1aefc..f47cc8bce 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -22,10 +22,12 @@ jobs: run: # Workaround to provide additional free space for testing. # https://github.com/actions/virtual-environments/issues/2840 - sudo rm -rf /usr/share/dotnet - sudo rm -rf /opt/ghc - sudo rm -rf "/usr/local/share/boost" - sudo rm -rf "$AGENT_TOOLSDIRECTORY" + df -h + rm -rf /usr/share/dotnet + rm -rf /opt/ghc + rm -rf "/usr/local/share/boost" + rm -rf "$AGENT_TOOLSDIRECTORY" + df -h echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make - name: test run : source ./Setup.sh && ./Analyse From 84db4a88bff667f8e69942c0ac4a1f52dcf5d523 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Tue, 6 Feb 2024 16:58:36 +0000 Subject: [PATCH 17/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index f47cc8bce..d8b0889d6 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -22,12 +22,12 @@ jobs: run: # Workaround to provide additional free space for testing. # https://github.com/actions/virtual-environments/issues/2840 - df -h - rm -rf /usr/share/dotnet - rm -rf /opt/ghc - rm -rf "/usr/local/share/boost" - rm -rf "$AGENT_TOOLSDIRECTORY" - df -h + df -h; + rm -rf /usr/share/dotnet; + rm -rf /opt/ghc; + rm -rf "/usr/local/share/boost"; + rm -rf "$AGENT_TOOLSDIRECTORY"; + df -h; echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make - name: test run : source ./Setup.sh && ./Analyse From 799ff5f98f3243a31d233095017cc2cfc18e833b Mon Sep 17 00:00:00 2001 From: marc1uk Date: Tue, 6 Feb 2024 22:10:15 +0000 Subject: [PATCH 18/31] Update docker-image.yml --- .github/workflows/docker-image.yml | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/.github/workflows/docker-image.yml b/.github/workflows/docker-image.yml index e8c7a9205..c4eb2f8c0 100644 --- a/.github/workflows/docker-image.yml +++ b/.github/workflows/docker-image.yml @@ -17,7 +17,6 @@ jobs: - uses: actions/checkout@v2 - name: Build the Docker image run: docker build . --file Dockerfile --tag anniesoft/toolanalysis:latest - - name: docker login uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 with: @@ -25,4 +24,18 @@ jobs: password: ${{ secrets.DOCKER_PASSWORD }} - name: push docker images - run: docker push anniesoft/toolanalysis:latest \ No newline at end of file + run: docker push anniesoft/toolanalysis:latest + + - name: cleanup + run: + # Workaround to provide additional free space for testing. + # https://github.com/actions/virtual-environments/issues/2840 + sudo rm -rf /usr/share/dotnet; + sudo rm -rf /opt/ghc; + sudo rm -rf "/usr/local/share/boost"; + sudo rm -rf "$AGENT_TOOLSDIRECTORY"; + docker rmi $(docker image ls -aq) || true; + swapoff /swapfile || true; + rm -rf /swapfile /usr/share/dotnet /usr/local/lib/android /opt/ghc || true; + apt-get autoremove -y >/dev/null 2>&1 || true; + apt-get autoclean -y >/dev/null 2>&1 || true; From 08bec19642560843e116cb517a498c13a080c42b Mon Sep 17 00:00:00 2001 From: marc1uk Date: Wed, 7 Feb 2024 13:39:47 +0000 Subject: [PATCH 19/31] Update docker-image.yml --- .github/workflows/docker-image.yml | 29 +++++++++++++++++------------ 1 file changed, 17 insertions(+), 12 deletions(-) diff --git a/.github/workflows/docker-image.yml b/.github/workflows/docker-image.yml index c4eb2f8c0..634c9c540 100644 --- a/.github/workflows/docker-image.yml +++ b/.github/workflows/docker-image.yml @@ -14,8 +14,23 @@ jobs: runs-on: ubuntu-latest steps: - - uses: actions/checkout@v2 + - name: cleanup + run: + # Workaround to provide additional free space for testing. + # https://github.com/actions/virtual-environments/issues/2840 + rm -rf /usr/share/dotnet; + rm -rf /opt/ghc; + rm -rf /usr/local/lib/android + rm -rf "/usr/local/share/boost"; + rm -rf "$AGENT_TOOLSDIRECTORY"; + docker rmi $(docker image ls -aq) || true; + swapoff /swapfile || true; + rm -rf /swapfile; + apt-get autoremove -y >/dev/null 2>&1 || true; + apt-get autoclean -y >/dev/null 2>&1 || true; + - name: Build the Docker image + uses: actions/checkout@v2 run: docker build . --file Dockerfile --tag anniesoft/toolanalysis:latest - name: docker login uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 @@ -26,16 +41,6 @@ jobs: - name: push docker images run: docker push anniesoft/toolanalysis:latest - - name: cleanup + - name: cleanup2 run: - # Workaround to provide additional free space for testing. - # https://github.com/actions/virtual-environments/issues/2840 - sudo rm -rf /usr/share/dotnet; - sudo rm -rf /opt/ghc; - sudo rm -rf "/usr/local/share/boost"; - sudo rm -rf "$AGENT_TOOLSDIRECTORY"; docker rmi $(docker image ls -aq) || true; - swapoff /swapfile || true; - rm -rf /swapfile /usr/share/dotnet /usr/local/lib/android /opt/ghc || true; - apt-get autoremove -y >/dev/null 2>&1 || true; - apt-get autoclean -y >/dev/null 2>&1 || true; From c8c4c63d423d93674986062327cce65f3743cee3 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Wed, 7 Feb 2024 17:10:07 +0000 Subject: [PATCH 20/31] Update docker-image.yml --- .github/workflows/docker-image.yml | 90 ++++++++++++++++++++---------- 1 file changed, 62 insertions(+), 28 deletions(-) diff --git a/.github/workflows/docker-image.yml b/.github/workflows/docker-image.yml index 634c9c540..3edcafb19 100644 --- a/.github/workflows/docker-image.yml +++ b/.github/workflows/docker-image.yml @@ -14,33 +14,67 @@ jobs: runs-on: ubuntu-latest steps: - - name: cleanup - run: - # Workaround to provide additional free space for testing. - # https://github.com/actions/virtual-environments/issues/2840 - rm -rf /usr/share/dotnet; - rm -rf /opt/ghc; - rm -rf /usr/local/lib/android - rm -rf "/usr/local/share/boost"; - rm -rf "$AGENT_TOOLSDIRECTORY"; - docker rmi $(docker image ls -aq) || true; - swapoff /swapfile || true; - rm -rf /swapfile; - apt-get autoremove -y >/dev/null 2>&1 || true; - apt-get autoclean -y >/dev/null 2>&1 || true; - - - name: Build the Docker image - uses: actions/checkout@v2 - run: docker build . --file Dockerfile --tag anniesoft/toolanalysis:latest - - name: docker login - uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 - with: - username: ${{ secrets.DOCKER_USERNAME }} - password: ${{ secrets.DOCKER_PASSWORD }} + - uses: actions/checkout@v2 + + - name: Check disk space + run: | + sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -nr | head + df . -h + sudo du / -hx -d 4 --threshold=1G | sort -hr | head + - name: Free disk space + run: | + # https://github.com/actions/virtual-environments/issues/2840 + # https://stackoverflow.com/questions/75536771/github-runner-out-of-disk-space-after-building-docker-image + sudo docker rmi $(docker image ls -aq) >/dev/null 2>&1 || true + sudo rm -rf \ + /usr/share/dotnet /usr/local/lib/android /opt/ghc \ + /usr/local/share/powershell /usr/share/swift /usr/local/.ghcup \ + /usr/lib/jvm /usr/local/share/boost || true + sudo rm -rf "$AGENT_TOOLSDIRECTORY"; + echo "some directories deleted" + sudo apt install aptitude -y >/dev/null 2>&1 + sudo aptitude purge aria2 ansible azure-cli shellcheck rpm xorriso zsync \ + esl-erlang firefox gfortran-8 gfortran-9 google-chrome-stable \ + google-cloud-sdk imagemagick \ + libmagickcore-dev libmagickwand-dev libmagic-dev ant ant-optional kubectl \ + mercurial apt-transport-https mono-complete libmysqlclient \ + unixodbc-dev yarn chrpath libssl-dev libxft-dev \ + libfreetype6 libfreetype6-dev libfontconfig1 libfontconfig1-dev \ + snmp pollinate libpq-dev postgresql-client powershell ruby-full \ + sphinxsearch subversion mongodb-org azure-cli microsoft-edge-stable \ + -y -f >/dev/null 2>&1 + sudo aptitude purge google-cloud-sdk -f -y >/dev/null 2>&1 + sudo aptitude purge microsoft-edge-stable -f -y >/dev/null 2>&1 || true + sudo apt purge microsoft-edge-stable -f -y >/dev/null 2>&1 || true + sudo aptitude purge '~n ^mysql' -f -y >/dev/null 2>&1 + sudo aptitude purge '~n ^php' -f -y >/dev/null 2>&1 + sudo aptitude purge '~n ^dotnet' -f -y >/dev/null 2>&1 + sudo apt-get autoremove -y >/dev/null 2>&1 + sudo apt-get autoclean -y >/dev/null 2>&1 + echo "some packages purged" + docker rmi $(docker image ls -aq) || true + sudo swapoff /swapfile || true + sudo rm -rf /swapfile + sudo apt-get autoremove -y >/dev/null 2>&1 || true + sudo apt-get autoclean -y >/dev/null 2>&1 || true + - name: Check disk space + run: | + sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -nr | head + df . -h + sudo du / -hx -d 4 --threshold=1G | sort -hr | head + + - name: Build the Docker image + run: docker build . --file Dockerfile --tag anniesoft/toolanalysis:latest + + - name: docker login + uses: docker/login-action@f054a8b539a109f9f41c372932f1ae047eff08c9 + with: + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_PASSWORD }} - - name: push docker images - run: docker push anniesoft/toolanalysis:latest + - name: push docker images + run: docker push anniesoft/toolanalysis:latest - - name: cleanup2 - run: - docker rmi $(docker image ls -aq) || true; + - name: cleanup2 + run: + docker rmi $(docker image ls -aq) || true; From 79f6e861e340ddfb056a93fb4ad236bc5ad969c7 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Wed, 7 Feb 2024 18:15:43 +0000 Subject: [PATCH 21/31] Update docker-image.yml --- .github/workflows/docker-image.yml | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/.github/workflows/docker-image.yml b/.github/workflows/docker-image.yml index 3edcafb19..dd8b6cacc 100644 --- a/.github/workflows/docker-image.yml +++ b/.github/workflows/docker-image.yml @@ -25,7 +25,6 @@ jobs: run: | # https://github.com/actions/virtual-environments/issues/2840 # https://stackoverflow.com/questions/75536771/github-runner-out-of-disk-space-after-building-docker-image - sudo docker rmi $(docker image ls -aq) >/dev/null 2>&1 || true sudo rm -rf \ /usr/share/dotnet /usr/local/lib/android /opt/ghc \ /usr/local/share/powershell /usr/share/swift /usr/local/.ghcup \ @@ -35,7 +34,7 @@ jobs: sudo apt install aptitude -y >/dev/null 2>&1 sudo aptitude purge aria2 ansible azure-cli shellcheck rpm xorriso zsync \ esl-erlang firefox gfortran-8 gfortran-9 google-chrome-stable \ - google-cloud-sdk imagemagick \ + google-cloud-sdk google-cloud-cli imagemagick \ libmagickcore-dev libmagickwand-dev libmagic-dev ant ant-optional kubectl \ mercurial apt-transport-https mono-complete libmysqlclient \ unixodbc-dev yarn chrpath libssl-dev libxft-dev \ @@ -46,9 +45,11 @@ jobs: sudo aptitude purge google-cloud-sdk -f -y >/dev/null 2>&1 sudo aptitude purge microsoft-edge-stable -f -y >/dev/null 2>&1 || true sudo apt purge microsoft-edge-stable -f -y >/dev/null 2>&1 || true + sudo aptitude purge google-chrome-stable -f -y >/dev/null 2>&1 || true sudo aptitude purge '~n ^mysql' -f -y >/dev/null 2>&1 sudo aptitude purge '~n ^php' -f -y >/dev/null 2>&1 sudo aptitude purge '~n ^dotnet' -f -y >/dev/null 2>&1 + sudo aptitude purge '~n ^temurin' -f -y >/dev/null 2>&1 sudo apt-get autoremove -y >/dev/null 2>&1 sudo apt-get autoclean -y >/dev/null 2>&1 echo "some packages purged" From b0566c2061d0dd6746036cb64b322c68b8194a83 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Wed, 7 Feb 2024 23:13:28 +0000 Subject: [PATCH 22/31] Update tempbuild.yml test to cleanup host before running build in container --- .github/workflows/tempbuild.yml | 106 +++++++++++++++++++++++++++----- 1 file changed, 89 insertions(+), 17 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index d8b0889d6..3aacd69a5 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -13,21 +13,93 @@ jobs: build_1: runs-on: ubuntu-latest - container: 'anniesoft/toolanalysis:latest' + #container: 'anniesoft/toolanalysis:latest' steps: - - uses: actions/checkout@v2 - - name: prerequisits - run: yum install -y git make gcc-c++ which wget - - name: build - run: - # Workaround to provide additional free space for testing. - # https://github.com/actions/virtual-environments/issues/2840 - df -h; - rm -rf /usr/share/dotnet; - rm -rf /opt/ghc; - rm -rf "/usr/local/share/boost"; - rm -rf "$AGENT_TOOLSDIRECTORY"; - df -h; - echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make - - name: test - run : source ./Setup.sh && ./Analyse + - name: Check disk space + run: | + sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -nr | head + df . -h + sudo du / -hx -d 4 --threshold=1G | sort -hr | head + - name: Free disk space + run: | + # https://github.com/actions/virtual-environments/issues/2840 + # https://stackoverflow.com/questions/75536771/github-runner-out-of-disk-space-after-building-docker-image + sudo rm -rf \ + /usr/share/dotnet /usr/local/lib/android /opt/ghc \ + /usr/local/share/powershell /usr/share/swift /usr/local/.ghcup \ + /usr/lib/jvm /usr/local/share/boost || true + sudo rm -rf "$AGENT_TOOLSDIRECTORY"; + echo "some directories deleted" + sudo apt install aptitude -y >/dev/null 2>&1 + sudo aptitude purge aria2 ansible azure-cli shellcheck rpm xorriso zsync \ + esl-erlang firefox gfortran-8 gfortran-9 google-chrome-stable \ + google-cloud-sdk google-cloud-cli imagemagick \ + libmagickcore-dev libmagickwand-dev libmagic-dev ant ant-optional kubectl \ + mercurial apt-transport-https mono-complete libmysqlclient \ + unixodbc-dev yarn chrpath libssl-dev libxft-dev \ + libfreetype6 libfreetype6-dev libfontconfig1 libfontconfig1-dev \ + snmp pollinate libpq-dev postgresql-client powershell ruby-full \ + sphinxsearch subversion mongodb-org azure-cli microsoft-edge-stable \ + -y -f >/dev/null 2>&1 + sudo aptitude purge google-cloud-sdk -f -y >/dev/null 2>&1 + sudo aptitude purge microsoft-edge-stable -f -y >/dev/null 2>&1 || true + sudo apt purge microsoft-edge-stable -f -y >/dev/null 2>&1 || true + sudo aptitude purge google-chrome-stable -f -y >/dev/null 2>&1 || true + sudo aptitude purge '~n ^mysql' -f -y >/dev/null 2>&1 + sudo aptitude purge '~n ^php' -f -y >/dev/null 2>&1 + sudo aptitude purge '~n ^dotnet' -f -y >/dev/null 2>&1 + sudo aptitude purge '~n ^temurin' -f -y >/dev/null 2>&1 + sudo apt-get autoremove -y >/dev/null 2>&1 + sudo apt-get autoclean -y >/dev/null 2>&1 + echo "some packages purged" + docker rmi $(docker image ls -aq) || true + sudo swapoff /swapfile || true + sudo rm -rf /swapfile + sudo apt-get autoremove -y >/dev/null 2>&1 || true + sudo apt-get autoclean -y >/dev/null 2>&1 || true + - name: Check disk space + run: | + sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -nr | head + df . -h + sudo du / -hx -d 4 --threshold=1G | sort -hr | head + + - uses: actions/checkout@v2 + + ################## + + #- name: prerequisites + # run: yum install -y git make gcc-c++ which wget + + #- name: build + # run: + # echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make + + ################## + + #- name: test + # run : source ./Setup.sh && ./Analyse + + #- name: build and test + # uses: docker://anniesoft/toolanalysis:latest + # with: + # entrypoint: /bin/bash + # args: -c "echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make && ./Analyse" + + - name: build and test + - uses: addnab/docker-run-action@v3 + with: + image: anniesoft/toolanalysis:latest + options: -v ${{ github.workspace }}:/ToolAnalysis + run: | + echo "Running Script" + echo `pwd` + ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ + ls -l + ls -l ./ToolDAQ + source ./Setup.sh + make clean + make + ./Analyse + + + From b3b11ab330fe6b8405e7594f0dfeff85f3fcdc03 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Wed, 7 Feb 2024 23:15:52 +0000 Subject: [PATCH 23/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index 3aacd69a5..5a9c3010e 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -62,7 +62,8 @@ jobs: sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -nr | head df . -h sudo du / -hx -d 4 --threshold=1G | sort -hr | head - + + - name: checkout - uses: actions/checkout@v2 ################## @@ -85,8 +86,10 @@ jobs: # entrypoint: /bin/bash # args: -c "echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make && ./Analyse" + ################## + - name: build and test - - uses: addnab/docker-run-action@v3 + uses: addnab/docker-run-action@v3 with: image: anniesoft/toolanalysis:latest options: -v ${{ github.workspace }}:/ToolAnalysis From 8e1195eb1ac093f3d1cf7a4ecce651c8da24c804 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 00:41:45 +0000 Subject: [PATCH 24/31] Update Dockerfile add `git checkout -- .` to Dockerfile run command as `make update` does not do this for the main TA repository*, and if there are outstanding changes, the built code will not be the latest. Also swap chaining commands with `;` to using `&&` as all steps should be completed successfully. --- Dockerfile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Dockerfile b/Dockerfile index dac7ff16f..cbdd664f4 100644 --- a/Dockerfile +++ b/Dockerfile @@ -6,7 +6,7 @@ FROM anniesoft/toolanalysis:base ### Run the following commands as super user (root): USER root -Run cd ToolAnalysis; bash -c "source Setup.sh; make update; make;" +Run cd ToolAnalysis; bash -c "source Setup.sh && git checkout -- . && make update && make" ### Open terminal CMD ["/bin/bash"] From 1c863bf21cf4a8be1fc11538668865708bc2008a Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 00:43:57 +0000 Subject: [PATCH 25/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index 5a9c3010e..124255c21 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -62,32 +62,32 @@ jobs: sudo dpkg-query -Wf '${Installed-Size}\t${Package}\n' | sort -nr | head df . -h sudo du / -hx -d 4 --threshold=1G | sort -hr | head - + - name: checkout - - uses: actions/checkout@v2 - + uses: actions/checkout@v2 + ################## #- name: prerequisites # run: yum install -y git make gcc-c++ which wget - + #- name: build # run: # echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make - + ################## - + #- name: test # run : source ./Setup.sh && ./Analyse - + #- name: build and test # uses: docker://anniesoft/toolanalysis:latest # with: # entrypoint: /bin/bash # args: -c "echo `pwd` && ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ && ls -l && ls -l ./ToolDAQ && source ./Setup.sh && make clean && make && ./Analyse" - + ################## - + - name: build and test uses: addnab/docker-run-action@v3 with: From cecec26465799532700b5e09c8e2135fafc8746c Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 01:15:05 +0000 Subject: [PATCH 26/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index 124255c21..c68755d06 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -91,8 +91,8 @@ jobs: - name: build and test uses: addnab/docker-run-action@v3 with: - image: anniesoft/toolanalysis:latest - options: -v ${{ github.workspace }}:/ToolAnalysis + image: "docker://anniesoft/toolanalysis:latest" + options: "-v ${{ github.workspace }}:/ToolAnalysis" run: | echo "Running Script" echo `pwd` From e578e212dfb5f4c7df134e0632db52b465b3d060 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 01:15:35 +0000 Subject: [PATCH 27/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index c68755d06..95979b31e 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -92,7 +92,7 @@ jobs: uses: addnab/docker-run-action@v3 with: image: "docker://anniesoft/toolanalysis:latest" - options: "-v ${{ github.workspace }}:/ToolAnalysis" + options: -v ${{ github.workspace }}:/ToolAnalysis run: | echo "Running Script" echo `pwd` From 07e06e6ddc565c11b02734afd78412ae6f9f95ae Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 01:55:56 +0000 Subject: [PATCH 28/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index 95979b31e..bb09611e4 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -91,7 +91,8 @@ jobs: - name: build and test uses: addnab/docker-run-action@v3 with: - image: "docker://anniesoft/toolanalysis:latest" + image: anniesoft/toolanalysis:latest + registry: docker.io options: -v ${{ github.workspace }}:/ToolAnalysis run: | echo "Running Script" From 0fffaf642303e0bbc5b02686e645a8195a7e9f5d Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 02:11:20 +0000 Subject: [PATCH 29/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index bb09611e4..9d36d0e15 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -52,7 +52,7 @@ jobs: sudo apt-get autoremove -y >/dev/null 2>&1 sudo apt-get autoclean -y >/dev/null 2>&1 echo "some packages purged" - docker rmi $(docker image ls -aq) || true + #docker rmi $(docker image ls -aq) || true sudo swapoff /swapfile || true sudo rm -rf /swapfile sudo apt-get autoremove -y >/dev/null 2>&1 || true From 7796349b29d1f784151484e1aa859d7e26e74c44 Mon Sep 17 00:00:00 2001 From: marc1uk Date: Thu, 8 Feb 2024 02:24:40 +0000 Subject: [PATCH 30/31] Update tempbuild.yml --- .github/workflows/tempbuild.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/tempbuild.yml b/.github/workflows/tempbuild.yml index 9d36d0e15..8ba0c5bec 100644 --- a/.github/workflows/tempbuild.yml +++ b/.github/workflows/tempbuild.yml @@ -93,12 +93,14 @@ jobs: with: image: anniesoft/toolanalysis:latest registry: docker.io - options: -v ${{ github.workspace }}:/ToolAnalysis + options: -v ${{ github.workspace }}:/TA run: | echo "Running Script" echo `pwd` - ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ ls -l + cd /TA + ls -l + ln -s /ToolAnalysis/ToolDAQ $PWD/ToolDAQ ls -l ./ToolDAQ source ./Setup.sh make clean From 426b7cb01057cef1f216b1b63eb203b5df007f71 Mon Sep 17 00:00:00 2001 From: Karagiannis Chrysovalantis <102170668+ckaragian@users.noreply.github.com> Date: Fri, 16 Feb 2024 19:25:29 +0200 Subject: [PATCH 31/31] Update to Track Length in the water & Energy Reconstruction (#248) * Adding tools for the track length in the water tank and the muon energy reconstruction * Adding the config files for the EnergyReco toolchains * Correcting some mistakes in README.md files * Fixed units of MC track length in mrd in FindTrackLengthInWater tool and converted reconstructed track length in the water and energy in [m] and [GeV] before passing them to the ANNIEEvent store. * Update PlotsTrackLengthAndEnergy.cpp Fix memory leaks * Fixing minor bug in PlotsTrackLengthAndEnergy.cpp script --------- Co-authored-by: marc1uk --- .../BDTMuonEnergyPredict.py | 177 ++++++ UserTools/BDTMuonEnergyPredict/README.md | 40 ++ .../BDTMuonEnergyTrain_Test.py | 280 +++++++++ UserTools/BDTMuonEnergyTrain_Test/README.md | 44 ++ .../DNNTrackLengthPredict.py | 201 +++++++ UserTools/DNNTrackLengthPredict/README.md | 45 ++ .../DNNTrackLengthTrain_Test.py | 335 +++++++++++ UserTools/DNNTrackLengthTrain_Test/README.md | 49 ++ UserTools/Factory/Factory.cpp | 1 + .../FindTrackLengthInWater.cpp | 557 +++++++++++------- .../FindTrackLengthInWater.h | 32 +- UserTools/FindTrackLengthInWater/README.md | 71 ++- .../PlotsTrackLengthAndEnergy.cpp | 121 ++++ .../PlotsTrackLengthAndEnergy.h | 45 ++ UserTools/PlotsTrackLengthAndEnergy/README.md | 23 + UserTools/Unity.h | 1 + configfiles/EnergyReco/DummyToolConfig | 3 - configfiles/EnergyReco/Erecoconfig | 6 - .../Predict/BDTMuonEnergyPredictConfig | 9 + .../EnergyReco/Predict/ClusterFinderConfig | 12 + .../Predict/DNNTrackLengthPredictConfig | 13 + .../EnergyReco/Predict/DigitBuilderConfig | 11 + .../EnergyReco/Predict/EventSelectorConfig | 15 + .../EnergyReco/Predict/FindMrdTracksConfig | 12 + .../Predict/FindTrackLengthInWaterConfig | 5 + .../EnergyReco/Predict/HitCleanerConfig | 20 + configfiles/EnergyReco/Predict/LAPPDIDs.txt | 5 + .../EnergyReco/Predict/LoadWCSimConfig | 15 + .../EnergyReco/Predict/LoadWCSimLAPPDConfig | 10 + .../Predict/MCParticlePropertiesConfig | 1 + .../Predict/MCRecoEventLoaderConfig | 12 + .../Predict/PlotsTrackLengthAndEnergyConfig | 1 + .../EnergyReco/Predict/TimeClusteringConfig | 12 + .../EnergyReco/{ => Predict}/ToolChainConfig | 6 +- configfiles/EnergyReco/Predict/ToolsConfig | 19 + .../Predict/VtxExtendedVertexFinderConfig | 9 + .../EnergyReco/Predict/VtxSeedFineGridConfig | 7 + .../EnergyReco/Predict/VtxSeedGeneratorConfig | 7 + configfiles/EnergyReco/README.md | 57 +- configfiles/EnergyReco/ToolsConfig | 1 - .../Train_Test/BDTMuonEnergyTrainConfig | 15 + .../EnergyReco/Train_Test/ClusterFinderConfig | 12 + .../Train_Test/DNNTrackLengthTrainConfig | 18 + .../EnergyReco/Train_Test/DigitBuilderConfig | 11 + .../EnergyReco/Train_Test/EventSelectorConfig | 15 + .../EnergyReco/Train_Test/FindMrdTracksConfig | 12 + .../Train_Test/FindTrackLengthInWaterConfig | 6 + .../EnergyReco/Train_Test/HitCleanerConfig | 20 + .../EnergyReco/Train_Test/LAPPDIDs.txt | 5 + .../EnergyReco/Train_Test/LoadWCSimConfig | 15 + .../Train_Test/LoadWCSimLAPPDConfig | 10 + .../Train_Test/MCParticlePropertiesConfig | 1 + .../Train_Test/MCRecoEventLoaderConfig | 12 + .../Train_Test/TimeClusteringConfig | 12 + .../EnergyReco/Train_Test/ToolChainConfig | 23 + configfiles/EnergyReco/Train_Test/ToolsConfig | 18 + .../Train_Test/VtxExtendedVertexFinderConfig | 9 + .../Train_Test/VtxSeedFineGridConfig | 7 + .../Train_Test/VtxSeedGeneratorConfig | 6 + 59 files changed, 2264 insertions(+), 253 deletions(-) create mode 100644 UserTools/BDTMuonEnergyPredict/BDTMuonEnergyPredict.py create mode 100644 UserTools/BDTMuonEnergyPredict/README.md create mode 100644 UserTools/BDTMuonEnergyTrain_Test/BDTMuonEnergyTrain_Test.py create mode 100644 UserTools/BDTMuonEnergyTrain_Test/README.md create mode 100644 UserTools/DNNTrackLengthPredict/DNNTrackLengthPredict.py create mode 100644 UserTools/DNNTrackLengthPredict/README.md create mode 100644 UserTools/DNNTrackLengthTrain_Test/DNNTrackLengthTrain_Test.py create mode 100644 UserTools/DNNTrackLengthTrain_Test/README.md create mode 100644 UserTools/PlotsTrackLengthAndEnergy/PlotsTrackLengthAndEnergy.cpp create mode 100644 UserTools/PlotsTrackLengthAndEnergy/PlotsTrackLengthAndEnergy.h create mode 100644 UserTools/PlotsTrackLengthAndEnergy/README.md delete mode 100644 configfiles/EnergyReco/DummyToolConfig delete mode 100644 configfiles/EnergyReco/Erecoconfig create mode 100644 configfiles/EnergyReco/Predict/BDTMuonEnergyPredictConfig create mode 100644 configfiles/EnergyReco/Predict/ClusterFinderConfig create mode 100644 configfiles/EnergyReco/Predict/DNNTrackLengthPredictConfig create mode 100644 configfiles/EnergyReco/Predict/DigitBuilderConfig create mode 100644 configfiles/EnergyReco/Predict/EventSelectorConfig create mode 100644 configfiles/EnergyReco/Predict/FindMrdTracksConfig create mode 100644 configfiles/EnergyReco/Predict/FindTrackLengthInWaterConfig create mode 100644 configfiles/EnergyReco/Predict/HitCleanerConfig create mode 100644 configfiles/EnergyReco/Predict/LAPPDIDs.txt create mode 100644 configfiles/EnergyReco/Predict/LoadWCSimConfig create mode 100644 configfiles/EnergyReco/Predict/LoadWCSimLAPPDConfig create mode 100644 configfiles/EnergyReco/Predict/MCParticlePropertiesConfig create mode 100644 configfiles/EnergyReco/Predict/MCRecoEventLoaderConfig create mode 100644 configfiles/EnergyReco/Predict/PlotsTrackLengthAndEnergyConfig create mode 100644 configfiles/EnergyReco/Predict/TimeClusteringConfig rename configfiles/EnergyReco/{ => Predict}/ToolChainConfig (71%) create mode 100644 configfiles/EnergyReco/Predict/ToolsConfig create mode 100644 configfiles/EnergyReco/Predict/VtxExtendedVertexFinderConfig create mode 100644 configfiles/EnergyReco/Predict/VtxSeedFineGridConfig create mode 100644 configfiles/EnergyReco/Predict/VtxSeedGeneratorConfig delete mode 100644 configfiles/EnergyReco/ToolsConfig create mode 100644 configfiles/EnergyReco/Train_Test/BDTMuonEnergyTrainConfig create mode 100644 configfiles/EnergyReco/Train_Test/ClusterFinderConfig create mode 100644 configfiles/EnergyReco/Train_Test/DNNTrackLengthTrainConfig create mode 100644 configfiles/EnergyReco/Train_Test/DigitBuilderConfig create mode 100644 configfiles/EnergyReco/Train_Test/EventSelectorConfig create mode 100644 configfiles/EnergyReco/Train_Test/FindMrdTracksConfig create mode 100644 configfiles/EnergyReco/Train_Test/FindTrackLengthInWaterConfig create mode 100644 configfiles/EnergyReco/Train_Test/HitCleanerConfig create mode 100644 configfiles/EnergyReco/Train_Test/LAPPDIDs.txt create mode 100644 configfiles/EnergyReco/Train_Test/LoadWCSimConfig create mode 100644 configfiles/EnergyReco/Train_Test/LoadWCSimLAPPDConfig create mode 100644 configfiles/EnergyReco/Train_Test/MCParticlePropertiesConfig create mode 100644 configfiles/EnergyReco/Train_Test/MCRecoEventLoaderConfig create mode 100644 configfiles/EnergyReco/Train_Test/TimeClusteringConfig create mode 100644 configfiles/EnergyReco/Train_Test/ToolChainConfig create mode 100644 configfiles/EnergyReco/Train_Test/ToolsConfig create mode 100644 configfiles/EnergyReco/Train_Test/VtxExtendedVertexFinderConfig create mode 100644 configfiles/EnergyReco/Train_Test/VtxSeedFineGridConfig create mode 100644 configfiles/EnergyReco/Train_Test/VtxSeedGeneratorConfig diff --git a/UserTools/BDTMuonEnergyPredict/BDTMuonEnergyPredict.py b/UserTools/BDTMuonEnergyPredict/BDTMuonEnergyPredict.py new file mode 100644 index 000000000..74f81a19f --- /dev/null +++ b/UserTools/BDTMuonEnergyPredict/BDTMuonEnergyPredict.py @@ -0,0 +1,177 @@ +# BDTMuonEnergy Tool script +# ------------------ +from Tool import * +import sys +import numpy as np +import pandas as pd +import tensorflow as tf +import tempfile +import random +import csv +import matplotlib +matplotlib.use('Agg') +import matplotlib.pyplot as plt +from array import array +from sklearn import datasets +from sklearn import metrics +from sklearn import model_selection +from sklearn import preprocessing +import sklearn +from sklearn.utils import shuffle +from sklearn import linear_model, ensemble +from sklearn.metrics import mean_squared_error +import pickle +import ROOT + +class BDTMuonEnergyPredict(Tool): + + # declare member variables here + weightsfilename = std.string("") + + def Initialise(self): + self.m_log.Log(__file__+" Initialising", self.v_debug, self.m_verbosity) + self.m_variables.Print() + self.m_variables.Get("BDTMuonModelFile", self.weightsfilename) + return 1 + + def Execute(self): + self.m_log.Log(__file__+" Executing", self.v_debug, self.m_verbosity) + #Load Data + EnergyRecoBoostStore=cppyy.gbl.BoostStore(True, 2)#define the energy boost store class object to load the variables for the BDT training + EnergyRecoBoostStore = self.m_data.Stores.at("EnergyReco") + #Retrieve the required variables from the Store + EnergyRecoBoostStore.Print(False) + get_ok = EnergyRecoBoostStore.Has("num_pmt_hits") + num_pmt_hits=ctypes.c_int(0) + if not get_ok: + print("BDTMuonEnergyPredict Tool: There is no entry in Energy Reco boost store.") + return 1 + if get_ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry num_pmt_hits: ", get_ok) + print("BDTMuonEnergyPredict Tool: type of num_pmt_hits entry is :",EnergyRecoBoostStore.Type("num_pmt_hits")) + print("BDTMuonEnergyPredict Tool: Getting num_pmt_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_pmt_hits",num_pmt_hits) + print("BDTMuonEnergyPredict Tool: Number of pmt hits is: ", num_pmt_hits.value) + ok = EnergyRecoBoostStore.Has("num_lappd_hits") + num_lappd_hits=ctypes.c_int(0) + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry num_lappd_hits: ",ok) + print("BDTMuonEnergyPredict Tool: type of num_lappd_hits entry is :",EnergyRecoBoostStore.Type("num_lappd_hits")) + print("BDTMuonEnergyPredict Tool: Getting num_lappd_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_lappd_hits",num_lappd_hits) + print("BDTMuonEnergyPredict Tool: Number of lappd hits is: ", num_lappd_hits.value) + ok = EnergyRecoBoostStore.Has("DNNRecoLength") + DNNRecoLength=ctypes.c_double(0) + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry DNNRecoLength: ",ok) + print("BDTMuonEnergyPredict Tool: type of DNNRecoLength entry is :",EnergyRecoBoostStore.Type("DNNRecoLength")) + print("BDTMuonEnergyPredict Tool: Getting DNNRecoLength from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("DNNRecoLength",DNNRecoLength) + print("BDTMuonEnergyPredict Tool: The reconstructed track length in the water by the DNN is: ", DNNRecoLength.value) + ok = EnergyRecoBoostStore.Has("recoTrackLengthInMrd") + recoTrackLengthInMrd=ctypes.c_double(0) + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry recoTrackLengthInMrd: ",ok) + print("BDTMuonEnergyPredict Tool: type of recoTrackLengthInMrd entry is :",EnergyRecoBoostStore.Type("recoTrackLengthInMrd")) + print("BDTMuonEnergyPredict Tool: Getting recoTrackLengthInMrd from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("recoTrackLengthInMrd",recoTrackLengthInMrd) + print("BDTMuonEnergyPredict Tool: The reconstructed track length in the MRD is: ", recoTrackLengthInMrd.value) + ok = EnergyRecoBoostStore.Has("diffDirAbs") + diffDirAbs=ctypes.c_float(0) + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry diffDirAbs: ",ok) + print("BDTMuonEnergyPredict Tool: type of diffDirAbs entry is :",EnergyRecoBoostStore.Type("diffDirAbs")) + print("BDTMuonEnergyPredict Tool: Getting diffDirAbs from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("diffDirAbs",diffDirAbs) + print("BDTMuonEnergyPredict Tool: DiffDirAbs is: ", diffDirAbs.value) + ok = EnergyRecoBoostStore.Has("recoDWallR") + recoDWallR=ctypes.c_float(0) + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry recoDWallR: ",ok) + print("BDTMuonEnergyPredict Tool: type of recoDWallR entry is :",EnergyRecoBoostStore.Type("recoDWallR")) + print("BDTMuonEnergyPredict Tool: Getting recoDWallR from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("recoDWallR",recoDWallR) + print("BDTMuonEnergyPredict Tool: RecoDWallR is: ", recoDWallR.value) + ok = EnergyRecoBoostStore.Has("recoDWallZ") + recoDWallZ=ctypes.c_float(0) + if(ok): + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry recoDWallZ: ",ok) + print("BDTMuonEnergyPredict Tool: type of recoDWallZ entry is :",EnergyRecoBoostStore.Type("recoDWallZ")) + print("BDTMuonEnergyPredict Tool: Getting recoDWallZ from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("recoDWallZ",recoDWallZ) + print("BDTMuonEnergyPredict Tool: RecoDWallZ is: ", recoDWallZ.value) + ok = EnergyRecoBoostStore.Has("vtxVec") + vtx_position=cppyy.gbl.Position() + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry vtxVec: ",ok) + print("BDTMuonEnergyPredict Tool: type of vtxVec entry is :", EnergyRecoBoostStore.Type("vtxVec")) + print("BDTMuonEnergyPredict Tool: Getting vtxVec from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("vtxVec", vtx_position) + vtxX=vtx_position.X() + print("BDTMuonEnergyPredict Tool: VtxX is: ", vtxX) + vtxY=vtx_position.Y() + print("BDTMuonEnergyPredict Tool: VtxY is: ", vtxY) + vtxZ=vtx_position.Z() + print("BDTMuonEnergyPredict Tool: VtxZ is: ", vtxZ) + ok = EnergyRecoBoostStore.Has("trueMuonEnergy") + trueMuonEnergy=ctypes.c_double(0) + if ok: + print("BDTMuonEnergyPredict Tool: EnergyRecoBoostStore has entry trueMuonEnergy: ",ok) + print("BDTMuonEnergyPredict Tool: type of trueMuonEnergy entry is :",EnergyRecoBoostStore.Type("trueMuonEnergy")) + print("BDTMuonEnergyPredict Tool: Getting trueMuonEnergy from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("trueMuonEnergy",trueMuonEnergy) + print("BDTMuonEnergyPredict Tool: The MC muon energy is: ", trueMuonEnergy.value) + + #Create features and labels and preprocess data for the model + features_list=[] + features_list.append(DNNRecoLength.value/600.) + features_list.append(recoTrackLengthInMrd.value/200.) + features_list.append(diffDirAbs.value) + features_list.append(recoDWallR.value) + features_list.append(recoDWallZ.value) + features_list.append(num_lappd_hits.value/200.) + features_list.append(num_pmt_hits.value/200.) + features_list.append(vtxX/150.) + features_list.append(vtxY/200.) + features_list.append(vtxZ/150.) + features=np.array(features_list).reshape(1,10) + labels=np.array([trueMuonEnergy.value]) + + # load the model from disk + print("BDTMuonEnergyPredict Tool: Loading model") + loaded_model = pickle.load(open(str(self.weightsfilename), 'rb')) + + #predicting... + print("BDTMuonEnergyPredict Tool: Predicting") + recoEnergy = loaded_model.predict(features) + + #Set the BDTMuonEnergy in the EnergyReco boost store to be loaded by other tools + BDTMuonEnergy=float(recoEnergy[0]) + EnergyRecoBoostStore.Set("BDTMuonEnergy", BDTMuonEnergy) + self.m_data.Stores.at("ANNIEEvent").Set("RecoMuonEnergy", BDTMuonEnergy/1000.)#Set the BDTMuonEnergy in the ANNIEEvent store in [GeV] + + EnergyRecoBoostStore.Save("EnergyRecoStore.bs")#Append each entry to file in case we want to make plots + + return 1 + + def Finalise(self): + self.m_log.Log(__file__+" Finalising", self.v_debug, self.m_verbosity) + return 1 + +################### +# ↓ Boilerplate ↓ # +################### + +thistool = BDTMuonEnergyPredict() + +def SetToolChainVars(m_data_in, m_variables_in, m_log_in): + return thistool.SetToolChainVars(m_data_in, m_variables_in, m_log_in) + +def Initialise(): + return thistool.Initialise() + +def Execute(): + return thistool.Execute() + +def Finalise(): + return thistool.Finalise() diff --git a/UserTools/BDTMuonEnergyPredict/README.md b/UserTools/BDTMuonEnergyPredict/README.md new file mode 100644 index 000000000..390cbdba7 --- /dev/null +++ b/UserTools/BDTMuonEnergyPredict/README.md @@ -0,0 +1,40 @@ +# BDTMuonEnergyPredict + +The `BDTMuonEnergyPredict` tool is used to reconstruct the energy of the muon using a Boosted Decision Tree(BDT) with Gradient Boost. The tool loads the necessary information from the `EnergyReco` store. The `FindTrackLengthInWater` and `DNNTrackLengthPredict` tools should always be placed before the `BDTMuonEnergyPredict` tool in a toolchain. This tool loads the weights file of the model which has already been trained. The value of the reconstructed muon energy is passed to the next tools through the `EnergyReco` store. Also, this value is set into the `ANNIEEvent` store with the key `RecoMuonEnergy`. + +## Data + +### Input + +The following variables are obtained from the `EnergyReco` store: + +**DNNRecoLength** `double` The reconstructed track length in water for a single event + +**num_pmt_hits** `int` Total number of pmt digits + +**num_lappd_hits** `int` Total number of lappd digits + +**recoTrackLengthInMrd** Track length of a reconstructed track in the MRD found by the `FindMrdTracks` tool + +**diffDirAbs** `double` Angle difference between the reconstructed z direction and the beam direction at (0,0,1) + +**recoDWallR** `double` Radial distance of the reconstructed vertex from the walls of the tank + +**recoDWallZ** `double` Axial distance of the reconstructed vertex from the walls of the tank + +**vtxVec** `Position` Position of the reconstructed vertex + +**trueMuonEnergy** `double` MC muon energy + +### Output + +The following variables are passed on to the next tool via the `EnergyReco` store: + +**BDTMuonEnergy** `double` The reconstructed energy of the muon for a single event + +## Configuration + +``` +BDTMuonModelFile finalized_BDTmodel_forMuonEnergy.sav +The path of the weights file as it has been set when training the model +``` diff --git a/UserTools/BDTMuonEnergyTrain_Test/BDTMuonEnergyTrain_Test.py b/UserTools/BDTMuonEnergyTrain_Test/BDTMuonEnergyTrain_Test.py new file mode 100644 index 000000000..ad26fe60f --- /dev/null +++ b/UserTools/BDTMuonEnergyTrain_Test/BDTMuonEnergyTrain_Test.py @@ -0,0 +1,280 @@ +# BDTMuonEnergyTrain_Test Tool script# ------------------ +import sys +import numpy as np +import pandas as pd +import tempfile +import random +import csv +import matplotlib +matplotlib.use('Agg') +import matplotlib.pyplot as plt +from array import array +from sklearn import datasets +from sklearn import metrics +from sklearn import model_selection +from sklearn import preprocessing +import sklearn +from sklearn.utils import shuffle +from sklearn import linear_model, ensemble +from sklearn.metrics import mean_squared_error +import pickle +from Tool import * + +class BDTMuonEnergyTrain_Test(Tool): + + # declare member variables here + weightsfilename=std.string("") + inputBoostStorepathname = std.string("") + + def Initialise(self): + self.m_log.Log(__file__+" Initialising", self.v_debug, self.m_verbosity) + self.m_variables.Print() + self.m_variables.Get("BDTMuonEnergyWeightsFile", self.weightsfilename) + self.m_variables.Get("BDTMuonEnergyTrainingInputBoostStoreFile", self.inputBoostStorepathname) + return 1 + + def Execute(self): + self.m_log.Log(__file__+" Executing", self.v_debug, self.m_verbosity) + + #Set seed for reproducibility + seed=150 + + EnergyRecoBoostStore=cppyy.gbl.BoostStore(True, 2)#define the energy boost store class object to load the variables for the BDT training + ok=EnergyRecoBoostStore.Initialise(self.inputBoostStorepathname)#read from disk + print("BDTMuonEnergyTrain_Test Tool: Initiliased boost store successfully",ok) + total_entries = ctypes.c_ulong(0) + get_ok = EnergyRecoBoostStore.Header.Get("TotalEntries",total_entries) + print("BDTMuonEnergyTrain_Test Tool: Get num of entries of Energy Reco Store: ",get_ok,", entries: ",total_entries.value) + ievt=ctypes.c_ulong(0) + while True: + get_ok=EnergyRecoBoostStore.GetEntry(ievt.value) + print("BDTMuonEnergyTrain_Test Tool: There is an entry in the BoostStore",get_ok) + if not get_ok: + break; + #When there is no other entry GetEntry() returns false so the while loop stops + #Retrieve the required variables from this entry + EnergyRecoBoostStore.Print(False) + ok = EnergyRecoBoostStore.Has("num_pmt_hits") + num_pmt_hits=ctypes.c_int(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry num_pmt_hits: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of num_pmt_hits entry is :",EnergyRecoBoostStore.Type("num_pmt_hits")) + print("BDTMuonEnergyTrain_Test Tool: Getting num_pmt_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_pmt_hits",num_pmt_hits) + print("BDTMuonEnergyTrain_Test Tool: Number of pmt hits is: ", num_pmt_hits.value) + ok = EnergyRecoBoostStore.Has("num_lappd_hits") + num_lappd_hits=ctypes.c_int(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry num_lappd_hits: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of num_lappd_hits entry is :",EnergyRecoBoostStore.Type("num_lappd_hits")) + print("BDTMuonEnergyTrain_Test Tool: Getting num_lappd_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_lappd_hits",num_lappd_hits) + print("BDTMuonEnergyTrain_Test Tool: Number of lappd hits is: ", num_lappd_hits.value) + ok = EnergyRecoBoostStore.Has("recoTrackLengthInMrd") + recoTrackLengthInMrd=ctypes.c_double(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry recoTrackLengthInMrd: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of recoTrackLengthInMrd entry is :",EnergyRecoBoostStore.Type("recoTrackLengthInMrd")) + print("BDTMuonEnergyTrain_Test Tool: Getting recoTrackLengthInMrd from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("recoTrackLengthInMrd",recoTrackLengthInMrd) + print("BDTMuonEnergyTrain_Test Tool: The reconstructed track length in the MRD is: ", recoTrackLengthInMrd.value) + ok = EnergyRecoBoostStore.Has("diffDirAbs") + diffDirAbs=ctypes.c_float(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry diffDirAbs: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of diffDirAbs entry is :",EnergyRecoBoostStore.Type("diffDirAbs")) + print("BDTMuonEnergyTrain_Test Tool: Getting diffDirAbs from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("diffDirAbs",diffDirAbs) + print("BDTMuonEnergyTrain_Test Tool: DiffDirAbs is: ", diffDirAbs.value) + ok = EnergyRecoBoostStore.Has("recoDWallR") + recoDWallR=ctypes.c_float(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry recoDWallR: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of recoDWallR entry is :",EnergyRecoBoostStore.Type("recoDWallR")) + print("BDTMuonEnergyTrain_Test Tool: Getting recoDWallR from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("recoDWallR",recoDWallR) + print("BDTMuonEnergyTrain_Test Tool: RecoDWallR is: ", recoDWallR.value) + ok = EnergyRecoBoostStore.Has("recoDWallZ") + recoDWallZ=ctypes.c_float(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry recoDWallZ: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of recoDWallZ entry is :",EnergyRecoBoostStore.Type("recoDWallZ")) + print("BDTMuonEnergyTrain_Test Tool: Getting recoDWallZ from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("recoDWallZ",recoDWallZ) + print("BDTMuonEnergyTrain_Test Tool: RecoDWallZ is: ", recoDWallZ.value) + ok = EnergyRecoBoostStore.Has("vtxVec") + vtx_position=cppyy.gbl.Position() + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry vtxVec: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of vtxVec entry is :", EnergyRecoBoostStore.Type("vtxVec")) + print("BDTMuonEnergyTrain_Test Tool: Getting vtxVec from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("vtxVec", vtx_position) + vtxX=vtx_position.X() + print("BDTMuonEnergyTrain_Test Tool: VtxX is: ", vtxX) + vtxY=vtx_position.Y() + print("BDTMuonEnergyTrain_Test Tool: VtxY is: ", vtxY) + vtxZ=vtx_position.Z() + print("BDTMuonEnergyTrain_Test Tool: VtxZ is: ", vtxZ) + ok = EnergyRecoBoostStore.Has("trueMuonEnergy") + trueMuonEnergy=ctypes.c_double(0) + if ok: + print("BDTMuonEnergyTrain_Test Tool: EnergyRecoBoostStore has entry trueMuonEnergy: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of trueMuonEnergy entry is :",EnergyRecoBoostStore.Type("trueMuonEnergy")) + print("BDTMuonEnergyTrain_Test Tool: Getting trueMuonEnergy from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("trueMuonEnergy",trueMuonEnergy) + print("BDTMuonEnergyTrain_Test Tool: The MC muon energy is: ", trueMuonEnergy.value) + #Create features and labels and preprocess data for the model + features_list=[] + features_list.append(recoTrackLengthInMrd.value/200.) + features_list.append(diffDirAbs.value) + features_list.append(recoDWallR.value) + features_list.append(recoDWallZ.value) + features_list.append(num_lappd_hits.value/200.) + features_list.append(num_pmt_hits.value/200.) + features_list.append(vtxX/150.) + features_list.append(vtxY/200.) + features_list.append(vtxZ/150.) + #make the features and labels numpy array for this entry + featuresforthisentry=np.array(features_list) + labelsforthisentry=np.array([trueMuonEnergy.value]) + #vstack each entry + if ievt.value==0: + features=featuresforthisentry + labels=labelsforthisentry + else: + features=np.vstack([features,featuresforthisentry]) + labels=np.vstack([labels,labelsforthisentry]) + ievt.value+=1 + + print(features) + print(features.shape) + print(labels) + print(labels.shape) + + Dataset=np.concatenate((features,labels),axis=1) + + print(Dataset) + + np.random.seed(seed) + np.random.shuffle(Dataset) + + print(Dataset) + + features, labels = np.split(Dataset,[9],axis=1) + + num_events, num_pixels = features.shape + + print(num_events, num_pixels) + np.random.seed(0) + #select the events for which we have the reconstructed track length from the DNN + if len(labels) % 2==0: + a=int(len(labels)/2) + else: + a=int((len(labels)+1)/2) + features= features[a:] + labels = labels[a:] + + num_events, num_pixels = features.shape + print("BDTMuonEnergyTrain_Test Tool: Events with DNNRecoLength: ", num_events, num_pixels) + + #Get the DNN reconstructed track length in the water tank from RecoLength boost store + #Get the RecoLength Boost Store from DataModel + DNNRecoLengthBoostStore = self.m_data.Stores.at("RecoLength") + ok = DNNRecoLengthBoostStore.Has("DNNRecoLength") + DNNRecoLength_vector=std.vector[float](range(num_events)) + if ok: + print("BDTMuonEnergyTrain_Test Tool: DNNRecoLengthBoostStore has entry DNNRecoLength: ",ok) + print("BDTMuonEnergyTrain_Test Tool: type of DNNRecoLength entry is :", DNNRecoLengthBoostStore.Type("DNNRecoLength")) + print("BDTMuonEnergyTrain_Test Tool: Getting DNNRecoLength from DNNRecoLengthBoostStore") + DNNRecoLengthBoostStore.Get("DNNRecoLength", DNNRecoLength_vector) + print("BDTMuonEnergyTrain_Test Tool: The DNNRecoLength for the first event: ", DNNRecoLength_vector.at(0)) + DNNRecoLength_list=[] + for i in range(DNNRecoLength_vector.size()): + DNNRecoLength_list.append(DNNRecoLength_vector.at(i)/600.) + DNNRecoLength=np.array(DNNRecoLength_list).reshape(len(DNNRecoLength_list),1) + #Place the DNNRecoLength in the dataset + features=np.concatenate((DNNRecoLength, features), axis=1) + print(features) + print("BDTMuonEnergyTrain_Test Tool: Features shape after adding DNNRecoLength",features.shape) + + DNNRecoLength_new=features[:,0] + #This loop excludes any events with reconstructed length >1000 as not well reconstructed + j=0 + b=[] + for k in DNNRecoLength_new: + if k>1000: + print("RecoLength:",k,"Event:",j) + b.append(j) + j+=1 + features=np.delete(features,b,axis=0) + labels=np.delete(labels,b,axis=0) + + ########### BDTG ############ + n_estimators=500 + params = {'n_estimators':n_estimators, 'max_depth': 50, + 'learning_rate': 0.025, 'loss': 'absolute_error'} + + #--- select 70% of sample for training and 30% for testing: + offset = int(features.shape[0] * 0.7) + train_X = features[:offset] # train sample + train_Y = labels[:offset].reshape(-1)#reshape for model + test_X = features[offset:] # test sample + test_Y = labels[offset:].reshape(-1)#reshape for model + + print("BDTMuonEnergyTrain_Test Tool: train shape: ", train_X.shape," label: ", train_Y.shape) + print("BDTMuonEnergyTrain_Test Tool: test shape: ", test_X.shape," label: ", test_Y.shape) + + print("BDTMuonEnergyTrain_Test Tool: Training BDTG...") + net_hi_E = ensemble.GradientBoostingRegressor(**params) + model = net_hi_E.fit(train_X, train_Y) + net_hi_E + + # save the model to disk + filename = str(self.weightsfilename) + pickle.dump(model, open(filename, 'wb')) + + mse = mean_squared_error(test_Y, net_hi_E.predict(test_X)) + print("BDTMuonEnergyTrain_Test Tool: MSE: %.4f" % mse) + print("BDTMuonEnergyTrain_Test Tool: events at training & test samples: ", len(labels)) + print("BDTMuonEnergyTrain_Test Tool: events at train sample: ", len(train_Y)) + print("BDTMuonEnergyTrain_Test Tool: events at test sample: ", len(test_Y)) + + test_score = np.zeros((params['n_estimators'],), dtype=np.float64) + + for i, y_pred in enumerate(net_hi_E.staged_predict(test_X)): + test_score[i] = net_hi_E.loss_(test_Y, y_pred) + + fig,ax=plt.subplots(ncols=1, sharey=True) + ax.plot(np.arange(params['n_estimators']) + 1, net_hi_E.train_score_, 'b-', label='Training Set Error') + ax.plot(np.arange(params['n_estimators']) + 1, test_score, 'r-', label='Test Set Error') + ax.set_ylim(0.,500.) + ax.set_xlim(0.,n_estimators) + ax.legend(loc='upper right') + ax.set_ylabel('Absolute Errors [MeV]') + ax.set_xlabel('Number of Estimators') + ax.yaxis.set_label_coords(-0.1, 0.6) + ax.xaxis.set_label_coords(0.85, -0.08) + plt.savefig("error_train_test.png") + return 1 + + def Finalise(self): + self.m_log.Log(__file__+" Finalising", self.v_debug, self.m_verbosity) + return 1 + +################### +# ↓ Boilerplate ↓ # +################### + +thistool = BDTMuonEnergyTrain_Test() + +def SetToolChainVars(m_data_in, m_variables_in, m_log_in): + return thistool.SetToolChainVars(m_data_in, m_variables_in, m_log_in) + +def Initialise(): + return thistool.Initialise() + +def Execute(): + return thistool.Execute() + +def Finalise(): + return thistool.Finalise() diff --git a/UserTools/BDTMuonEnergyTrain_Test/README.md b/UserTools/BDTMuonEnergyTrain_Test/README.md new file mode 100644 index 000000000..c36050f66 --- /dev/null +++ b/UserTools/BDTMuonEnergyTrain_Test/README.md @@ -0,0 +1,44 @@ +# BDTMuonEnergyTrain_Test + +The `BDTMuonEnergyTrain_Test` tool is used to train a Boosted Decision Tree(BDT) with Gradient Boost which will then be able to reconstruct the energy of the muon. The tool loads the necessary information from the `EnergyReco` store which have been saved to disk by the `FindTrackLengthInWater` tool. The `FindTrackLengthInWater` tool should hence always be placed before the `BDTMuonEnergyTrain_Test` tool in a toolchain. The tool also loads the values for the reconstructed track length in the water for the each of the events which are calculated by the `DNNTrackLengthTrain_Test` tool and are passed to the `BDTMuonEnergyTrain_Test` tool through the `DNNRecoLength` store. The `DNNTrackLengthTrain_Test` tool should also always be placed before the `BDTMuonEnergyTrain_Test` tool in a toolchain. After training and testing the weights are saved locally. A few plots are also drawn for visualization purposes. + +## Data + +### Input + +The following variables are obtained from the `EnergyReco` store: + +**num_pmt_hits** `int` Total number of pmt digits + +**num_lappd_hits** `int` Total number of lappd digits + +**recoTrackLengthInMrd** Track length of a reconstructed track in the MRD found by the `FindMrdTracks` tool + +**diffDirAbs** `double` Angle difference between the reconstructed z direction and the beam direction at (0,0,1) + +**recoDWallR** `double` Radial distance of the reconstructed vertex from the walls of the tank + +**recoDWallZ** `double` Axial distance of the reconstructed vertex from the walls of the tank + +**vtxVec** `Position` Position of the reconstructed vertex + +**trueMuonEnergy** `double` MC muon energy + +The following variables are obtained from the `DNNRecoLength` store: + +**DNNRecoLength** `std::vector` Vector with the reconstructed track length in water for each event of the event sample + +## Configuration + +``` +InitialiseFunction Initialise +ExecuteFunction Finalise +FinaliseFunction Execute +Everything is done in the Execute method of the tool. We need to run the Execute method in the Finalise step of the toolchain so that the FindTrackLengthInWater tool has already saved a multiple event sample for the training. + +BDTMuonEnergyWeightsFile finalized_BDTmodel_forMuonEnergy.sav +The path where you want to save the weights file + +BDTMuonEnergyTrainingInputBoostStoreFile EnergyReco.bs +The path of the EnergyReco boost store +``` diff --git a/UserTools/DNNTrackLengthPredict/DNNTrackLengthPredict.py b/UserTools/DNNTrackLengthPredict/DNNTrackLengthPredict.py new file mode 100644 index 000000000..aef8b11ef --- /dev/null +++ b/UserTools/DNNTrackLengthPredict/DNNTrackLengthPredict.py @@ -0,0 +1,201 @@ +##### DNNTrackLengthPredict Tool Script +import numpy +import tensorflow +import random +import sys +import glob +import numpy as np +import pandas #as pd +import tempfile +import csv +import matplotlib +matplotlib.use('Agg') +import matplotlib.pyplot #as plt +from array import array +from sklearn import datasets +from sklearn import metrics +from sklearn import model_selection +from sklearn import preprocessing +from tensorflow import keras +from tensorflow.keras.models import Sequential +from tensorflow.keras.layers import Dense +from tensorflow.keras.callbacks import ModelCheckpoint +from tensorflow.keras.wrappers.scikit_learn import KerasRegressor +from tensorflow.keras import backend as K +import pprint +#import Store and other modules +from Tool import * + +class DNNTrackLengthPredict(Tool): + + # declare member variables here + weightsfilename = std.string("") + ScalingVarsBoostStorepathname = std.string("") + + def Initialise(self): + self.m_log.Log(__file__+" Initialising", self.v_debug, self.m_verbosity) + self.m_variables.Print() + self.m_variables.Get("TrackLengthWeightsFile", self.weightsfilename) + self.m_variables.Get("ScalingVarsBoostStoreFile", self.ScalingVarsBoostStorepathname) + return 1 + + def Execute(self): + self.m_log.Log(__file__+" Executing", self.v_debug, self.m_verbosity) + # Load Data from EnergyReco Boost Store + #----------------------------- + EnergyRecoBoostStore=cppyy.gbl.BoostStore(True, 2)#define the energy boost store class object to load the variables for the DNN training + EnergyRecoBoostStore = self.m_data.Stores.at("EnergyReco") + #Retrieve the required variables from the Store + EnergyRecoBoostStore.Print(False) + get_ok = EnergyRecoBoostStore.Has("MaxTotalHitsToDNN") + MaxTotalHitsToDNN=ctypes.c_int(0) + if not get_ok: + print("DNNTrackLengthPredict Tool: There is no entry in Energy Reco boost store.") + return 1 + if get_ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry MaxTotalHitsToDNN: ",get_ok) + print("DNNTrackLengthPredict Tool: type of MaxTotalHitsToDNN entry is :",EnergyRecoBoostStore.Type("MaxTotalHitsToDNN")) + print("DNNTrackLengthPredict Tool: Getting MaxTotalHitsToDNN from EnergyRecoBoostStore")#we are going to use it to instantiate the lambda and digit times vectors + EnergyRecoBoostStore.Get("MaxTotalHitsToDNN",MaxTotalHitsToDNN) + print("DNNTrackLengthPredict Tool: MaxTotalHitsToDNN is: ", MaxTotalHitsToDNN.value) + ok = EnergyRecoBoostStore.Has("lambda_vec") + lambda_vector=std.vector['double'](range(MaxTotalHitsToDNN.value)) + if ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry lambda_vec: ",ok) + print("DNNTrackLengthPredict Tool: type of lambda_vec entry is :", EnergyRecoBoostStore.Type("lambda_vec")) + print("DNNTrackLengthPredict Tool: Getting lambda_vec from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("lambda_vec", lambda_vector) + print("DNNTrackLengthPredict Tool: The lambda for the first digit is: ", lambda_vector.at(0)) + ok = EnergyRecoBoostStore.Has("digit_ts_vec") + digit_ts_vector=std.vector['double'](range(MaxTotalHitsToDNN.value)) + if ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry digit_ts_vec: ",ok) + print("DNNTrackLengthPredict Tool: type of digit_ts_vec entry is :",EnergyRecoBoostStore.Type("digit_ts_vec")) + print("DNNTrackLengthPredict Tool: Getting digit_ts_vec from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("digit_ts_vec", digit_ts_vector) + print("DNNTrackLengthPredict Tool: The digit time for the first digit is: ", digit_ts_vector.at(0)) + ok = EnergyRecoBoostStore.Has("lambda_max") + lambda_max=ctypes.c_double(0) + if ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry lambda_max: ",ok) + print("DNNTrackLengthPredict Tool: type of lambda_max entry is :",EnergyRecoBoostStore.Type("lambda_max")) + print("DNNTrackLengthPredict Tool: Getting lambda_max from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("lambda_max",lambda_max) + print("DNNTrackLengthPredict Tool: Lambda_max is: ", lambda_max.value) + ok = EnergyRecoBoostStore.Has("num_pmt_hits") + num_pmt_hits=ctypes.c_int(0) + if ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry num_pmt_hits: ",ok) + print("DNNTrackLengthPredict Tool: type of num_pmt_hits entry is :",EnergyRecoBoostStore.Type("num_pmt_hits")) + print("DNNTrackLengthPredict Tool: Getting num_pmt_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_pmt_hits",num_pmt_hits) + print("DNNTrackLengthPredict Tool: Number of pmt hits is: ", num_pmt_hits.value) + ok = EnergyRecoBoostStore.Has("num_lappd_hits") + num_lappd_hits=ctypes.c_int(0) + if ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry num_lappd_hits: ",ok) + print("DNNTrackLengthPredict Tool: type of num_lappd_hits entry is :",EnergyRecoBoostStore.Type("num_lappd_hits")) + print("DNNTrackLengthPredict Tool: Getting num_lappd_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_lappd_hits",num_lappd_hits) + print("DNNTrackLengthPredict Tool: Number of lappd hits is: ", num_lappd_hits.value) + ok = EnergyRecoBoostStore.Has("TrueTrackLengthInWater") + TrueTrackLengthInWater=ctypes.c_float(0) + if ok: + print("DNNTrackLengthPredict Tool: EnergyRecoBoostStore has entry TrueTrackLengthInWater: ",ok) + print("DNNTrackLengthPredict Tool: type of TrueTrackLengthInWater entry is :",EnergyRecoBoostStore.Type("TrueTrackLengthInWater")) + print("DNNTrackLengthPredict Tool: Getting TrueTrackLengthInWater from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("TrueTrackLengthInWater",TrueTrackLengthInWater) + print("DNNTrackLengthPredict Tool: TrueTrackLengthInWater is: ", TrueTrackLengthInWater.value) + + #Create features and labels and preprocess data for the model + features_list=[] + for i in range(lambda_vector.size()): + features_list.append(lambda_vector.at(i)) + for j in range(digit_ts_vector.size()): + features_list.append(digit_ts_vector.at(j)) + features_list.append(lambda_max.value) + features_list.append(num_pmt_hits.value) + features_list.append(num_lappd_hits.value) + #make the features and labels numpy array + features=np.array(features_list) + labels=np.array([TrueTrackLengthInWater.value]) + + print(features) + print(features.shape) + print(labels) + print(labels.shape) + + #Load scaling parameters + ScalingVarsStore=cppyy.gbl.BoostStore(True, 0) + ok=ScalingVarsStore.Initialise(self.ScalingVarsBoostStorepathname) + features_mean_values_vec=std.vector['double'](range(len(features))) + features_std_values_vec=std.vector['double'](range(len(features))) + ScalingVarsStore.Get("features_mean_values",features_mean_values_vec) + ScalingVarsStore.Get("features_std_values",features_std_values_vec) + + #Transform data + test_x=[] + + for i in range(len(features)): + test_x.append((features[i]-features_mean_values_vec.at(i))/features_std_values_vec.at(i)) + test_X=np.array(test_x).reshape(1,2203) + + print("DNNTrackLengthPredict Tool: Defining the model") + model = Sequential() + print("DNNTrackLengthPredict Tool: Adding layers") + model.add(Dense(25, input_dim=2203, kernel_initializer='normal', activation='relu')) + model.add(Dense(25, kernel_initializer='normal', activation='relu')) + model.add(Dense(1, kernel_initializer='normal', activation='relu')) + + # load weights + print("DNNTrackLengthPredict Tool: Loading weights from file ", self.weightsfilename) + model.load_weights(str(self.weightsfilename)) + + # Compile model + print("DNNTrackLengthPredict Tool: Compiling model") + model.compile(loss='mean_squared_error', optimizer='Adamax', metrics=['accuracy']) + print("DNNTrackLengthPredict Tool: Created model and loaded weights from file", self.weightsfilename) + + # Score accuracy / Make predictions + #---------------------------------- + print('DNNTrackLengthPredict Tool: Predicting...') + y_predicted = model.predict(test_X) + print(y_predicted.shape) + + # estimate accuracy on dataset using loaded weights + print("DNNTrackLengthPredict Tool: Evalulating model on test") + scores = model.evaluate(test_X, labels, verbose=0) + print("%s: %.2f%%" % (model.metrics_names[1], scores[1]*100)) + + # Score with sklearn. + print("scoring sk mse") + score_sklearn = metrics.mean_squared_error(y_predicted, labels) + print('MSE (sklearn): {0:f}'.format(score_sklearn)) + + #Set the DNNRecoLength in the EnergyReco boost store for next tools + DNNRecoLength=float(y_predicted[0]) + EnergyRecoBoostStore.Set("DNNRecoLength", DNNRecoLength) + self.m_data.Stores.at("ANNIEEvent").Set("RecoTrackLengthInTank", DNNRecoLength/100.)#Set the DNNRecoLength in the ANNIEEvent store in [m] + return 1 + + def Finalise(self): + self.m_log.Log(__file__+" Finalising", self.v_debug, self.m_verbosity) + return 1 + +################### +# ↓ Boilerplate ↓ # +################### + +thistool = DNNTrackLengthPredict() + +def SetToolChainVars(m_data_in, m_variables_in, m_log_in): + return thistool.SetToolChainVars(m_data_in, m_variables_in, m_log_in) + +def Initialise(): + return thistool.Initialise() + +def Execute(): + return thistool.Execute() + +def Finalise(): + return thistool.Finalise() diff --git a/UserTools/DNNTrackLengthPredict/README.md b/UserTools/DNNTrackLengthPredict/README.md new file mode 100644 index 000000000..f77bddcff --- /dev/null +++ b/UserTools/DNNTrackLengthPredict/README.md @@ -0,0 +1,45 @@ +# DNNTrackLengthPredict + +The `DNNTrackLengthPredict` tool is used to reconstruct the track length of the muon in the water tank using a Deep Learning Neural Network(DNN) from the Keras library on top of Tensorflow. The tool loads the necessary information from the `EnergyReco` store. The `FindTrackLengthInWater` tool should always be placed before the `DNNTrackLengthPredict` tool in a toolchain. The scaling parameters are loaded from the `ScalingVarsStore` in order to preprocess our data for the model. This tool also loads the weights file of the model which has already been trained. The value of the reconstructed track length in the water tank is passed to the next tools through the `EnergyReco` store. Also, this value is set into the `ANNIEEvent` store with the key `RecoTrackLengthInTank`. + +## Data + +### Input + +The following variables are obtained from the `EnergyReco` store: + +**MaxTotalHitsToDNN** `int` + +**lambda_vec** `std::vector` Vector with all the lambda values for each event + +**digit_ts_vec** `std::vector` Vector with the time of all the digits of each event + +**lambda_max** `double` The distance between the reconstructed vertex and last Cherenkov photon emission point along the track + +**num_pmt_hits** `int` Total number of pmt digits + +**num_lappd_hits** `int` Total number of lappd digits + +**TrueTrackLengthInWater** `float` MC track length in the water + +The following variables are obtained from the `ScalingVarsStore` store: + +**features_mean_values** `std::vector` Vector with the means of each feature of the training dataset + +**features_std_values** `std::vector` Vector with the standard deviations of each feature of the training dataset + +### Output + +The following variables are passed on to the next tool via the `EnergyReco` store: + +**DNNRecoLength** `double` The reconstructed track length in water for a single event + +## Configuration + +``` +TrackLengthWeightsFile UserTools/DNNTrackLength/stand_alone/weights/weights_bets.hdf5 +The path of the weights file as it has been set when training the model + +ScalingVarsBoostStoreFile Data_Energy_Reco/ScalingVarsStore.bs +The path of the scaling parameters file as it has been set when training the model +``` diff --git a/UserTools/DNNTrackLengthTrain_Test/DNNTrackLengthTrain_Test.py b/UserTools/DNNTrackLengthTrain_Test/DNNTrackLengthTrain_Test.py new file mode 100644 index 000000000..65a678344 --- /dev/null +++ b/UserTools/DNNTrackLengthTrain_Test/DNNTrackLengthTrain_Test.py @@ -0,0 +1,335 @@ +# DNNTrackLengthTrain_Test Tool script +# ------------------ +import sys +import glob +import numpy as np +import pandas as pd +import tensorflow as tf +import tempfile +import random +import csv +import matplotlib +matplotlib.use('Agg') +import matplotlib.pyplot as plt +from array import array +from sklearn import datasets +from sklearn import metrics +from sklearn import model_selection +from sklearn import preprocessing +from sklearn.utils import shuffle +from tensorflow import keras +from tensorflow.keras.models import Sequential +from tensorflow.keras.layers import Dense +from tensorflow.keras.callbacks import ModelCheckpoint +from tensorflow.keras.wrappers.scikit_learn import KerasRegressor +import ROOT +import matplotlib.pylab as pylab +params = {'legend.fontsize': 'x-large', + 'figure.figsize': (9, 7), + 'axes.labelsize': 'x-large', + 'axes.titlesize':'x-large', + 'xtick.labelsize':'x-large', + 'ytick.labelsize':'x-large'} +pylab.rcParams.update(params) +from Tool import * + +class DNNTrackLengthTrain_Test(Tool): + + # declare member variables here + weightsfilename = std.string("") + inputBoostStorepathname = std.string("") + ScalingVarsBoostStorepathname = std.string("") + + def Initialise(self): + self.m_log.Log(__file__+" Initialising", self.v_debug, self.m_verbosity) + self.m_variables.Print() + self.m_variables.Get("TrackLengthOutputWeightsFile", self.weightsfilename) + self.m_variables.Get("TrackLengthTrainingInputBoostStoreFile", self.inputBoostStorepathname) + self.m_variables.Get("ScalingVarsBoostStoreFile", self.ScalingVarsBoostStorepathname) + return 1 + + def Execute(self): + self.m_log.Log(__file__+" Executing", self.v_debug, self.m_verbosity) + #Set seed for reproducibility + + seed=150 + + EnergyRecoBoostStore=cppyy.gbl.BoostStore(True, 2)#define the energy boost store class object to load the variables for the DNN training + ok=EnergyRecoBoostStore.Initialise(self.inputBoostStorepathname)#read from disk + print("DNNTrackLengthTrain_Test Tool: Initiliased boost store successfully") + total_entries = ctypes.c_ulong(0) + get_ok = EnergyRecoBoostStore.Header.Get("TotalEntries",total_entries) + print("DNNTrackLengthTrain_Test Tool: Get num of entries of Energy Reco Store: ",get_ok,", entries: ",total_entries.value) + ievt=ctypes.c_ulong(0) + while True: + get_ok=EnergyRecoBoostStore.GetEntry(ievt.value) + print("DNNTrackLengthTrain_Test Tool: There is an entry in the BoostStore",get_ok) + if not get_ok: + break; + #When there is no other entry GetEntry() returns false so the while loop stops + #Retrieve the required variables from this entry + EnergyRecoBoostStore.Print(False) + ok = EnergyRecoBoostStore.Has("MaxTotalHitsToDNN") + MaxTotalHitsToDNN=ctypes.c_int(0) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry MaxTotalHitsToDNN: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of MaxTotalHitsToDNN entry is :",EnergyRecoBoostStore.Type("MaxTotalHitsToDNN")) + print("DNNTrackLengthTrain_Test Tool: Getting MaxTotalHitsToDNN from EnergyRecoBoostStore")#we are going to use it to instantiate the lambda and digit times vectors + EnergyRecoBoostStore.Get("MaxTotalHitsToDNN",MaxTotalHitsToDNN) + print("DNNTrackLengthTrain_Test Tool: MaxTotalHitsToDNN is: ", MaxTotalHitsToDNN.value) + ok = EnergyRecoBoostStore.Has("lambda_vec") + lambda_vector=std.vector['double'](range(MaxTotalHitsToDNN.value)) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry lambda_vec: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of lambda_vec entry is :", EnergyRecoBoostStore.Type("lambda_vec")) + print("DNNTrackLengthTrain_Test Tool: Getting lambda_vec from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("lambda_vec", lambda_vector) + print("DNNTrackLengthTrain_Test Tool: The lambda for the first digit is: ", lambda_vector.at(0)) + ok = EnergyRecoBoostStore.Has("digit_ts_vec") + digit_ts_vector=std.vector['double'](range(MaxTotalHitsToDNN.value)) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry digit_ts_vec: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of digit_ts_vec entry is :",EnergyRecoBoostStore.Type("digit_ts_vec")) + print("DNNTrackLengthTrain_Test Tool: Getting digit_ts_vec from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("digit_ts_vec", digit_ts_vector) + print("DNNTrackLengthTrain_Test Tool: The digit time for the first digit is: ", digit_ts_vector.at(0)) + ok = EnergyRecoBoostStore.Has("lambda_max") + lambda_max=ctypes.c_double(0) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry lambda_max: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of lambda_max entry is :",EnergyRecoBoostStore.Type("lambda_max")) + print("DNNTrackLengthTrain_Test Tool: Getting lambda_max from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("lambda_max",lambda_max) + print("DNNTrackLengthTrain_Test Tool: Lambda_max is: ", lambda_max.value) + ok = EnergyRecoBoostStore.Has("num_pmt_hits") + num_pmt_hits=ctypes.c_int(0) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry num_pmt_hits: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of num_pmt_hits entry is :",EnergyRecoBoostStore.Type("num_pmt_hits")) + print("Getting num_pmt_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_pmt_hits",num_pmt_hits) + print("DNNTrackLengthTrain_Test Tool: Number of pmt hits is: ", num_pmt_hits.value) + ok = EnergyRecoBoostStore.Has("num_lappd_hits") + num_lappd_hits=ctypes.c_int(0) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry num_lappd_hits: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of num_lappd_hits entry is :",EnergyRecoBoostStore.Type("num_lappd_hits")) + print("DNNTrackLengthTrain_Test Tool: Getting num_lappd_hits from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("num_lappd_hits",num_lappd_hits) + print("DNNTrackLengthTrain_Test Tool: Number of lappd hits is: ", num_lappd_hits.value) + ok = EnergyRecoBoostStore.Has("TrueTrackLengthInWater") + TrueTrackLengthInWater=ctypes.c_float(0) + if ok: + print("DNNTrackLengthTrain_Test Tool: EnergyRecoBoostStore has entry TrueTrackLengthInWater: ",ok) + print("DNNTrackLengthTrain_Test Tool: type of TrueTrackLengthInWater entry is :",EnergyRecoBoostStore.Type("TrueTrackLengthInWater")) + print("DNNTrackLengthTrain_Test Tool: Getting TrueTrackLengthInWater from EnergyRecoBoostStore") + EnergyRecoBoostStore.Get("TrueTrackLengthInWater",TrueTrackLengthInWater) + print("DNNTrackLengthTrain_Test Tool: TrueTrackLengthInWater is: ", TrueTrackLengthInWater.value) + + #Create features and labels and preprocess data for the model + features_list=[] + for i in range(lambda_vector.size()): + features_list.append(lambda_vector.at(i)) + for j in range(digit_ts_vector.size()): + features_list.append(digit_ts_vector.at(j)) + features_list.append(lambda_max.value) + features_list.append(num_pmt_hits.value) + features_list.append(num_lappd_hits.value) + #make the features and labels numpy array for this entry + featuresforthisentry=np.array(features_list) + labelsforthisentry=np.array([TrueTrackLengthInWater.value]) + #vstack each entry + if ievt.value==0: + features=featuresforthisentry + labels=labelsforthisentry + else: + features=np.vstack([features,featuresforthisentry]) + labels=np.vstack([labels,labelsforthisentry]) + ievt.value+=1 + + print(features) + print(features.shape) + print(labels) + print(labels.shape) + + Dataset=np.concatenate((features,labels),axis=1) + + print(Dataset) + + #shuffle the data in order to avoid any bias in training + np.random.seed(seed) + np.random.shuffle(Dataset) + + print(Dataset) + + features, labels = np.split(Dataset,[2203],axis=1) + + #split events in train/test samples: + + num_events, num_pixels = features.shape + print(num_events, num_pixels) + np.random.seed(0) + #split in half if the number of events is even or take one more event for training when odd + if len(labels) % 2==0: + a=int(len(labels)/2) + else: + a=int((len(labels)+1)/2) + train_x = features[:a] + train_y = labels[:a] + test_x = features[a:] + test_y = labels[a:] + + print("DNNTrackLengthTrain_Test Tool: train sample features shape: ", train_x.shape," DNNTrackLengthTrain_Test Tool: train sample label shape: ", train_y.shape) + print("DNNTrackLengthTrain_Test Tool: test sample features shape: ", test_x.shape," DNNTrackLengthTrain_Test Tool: test sample label shape: ", test_y.shape) + + # Scale data (training set) to 0 mean and unit standard deviation. + scaler = preprocessing.StandardScaler() + train_x = scaler.fit_transform(train_x) + + #Save the scaling parameters from fit_transform for later use in the predict toolchain + features_mean_values=scaler.mean_ + features_std_values=scaler.scale_ + + #Turn into std.vectors() to store in the ScalingVars BoostStore + features_mean_values_vec=std.vector['double'](range(len(features_mean_values))) + for i in range(features_mean_values_vec.size()): + features_mean_values_vec[i]=features_mean_values[i] + features_std_values_vec=std.vector['double'](range(len(features_std_values))) + for j in range(features_std_values_vec.size()): + features_std_values_vec[j]=features_std_values[j] + #Create a boost store to store these values + ScalingVarsStore=cppyy.gbl.BoostStore(True, 0) + print("DNNTrackLengthTrain_Test Tool: Constructed: ",type(ScalingVarsStore)) + ScalingVarsStore.Set("features_mean_values",features_mean_values_vec) + ScalingVarsStore.Set("features_std_values",features_std_values_vec) + #Save BoostStore locally for later use in EnergyRecoPredict toolchain + print("DNNTrackLengthTrain_Test Tool: Saving boost store with scaling parameters locally for later use") + ScalingVarsStore.Save(self.ScalingVarsBoostStorepathname) + def create_model(): + # create model + model = Sequential() + model.add(Dense(25, input_dim=2203, kernel_initializer='normal', activation='relu')) + model.add(Dense(25, kernel_initializer='normal', activation='relu')) + model.add(Dense(1, kernel_initializer='normal', activation='relu')) + # Compile model + model.compile(loss='mean_squared_error', optimizer='Adamax', metrics=['accuracy']) + return model + + estimator = KerasRegressor(build_fn=create_model, epochs=10, batch_size=2, verbose=0) + + # checkpoint + filepath=str(self.weightsfilename) + checkpoint = ModelCheckpoint(filepath, monitor='val_loss', verbose=1, save_best_only=True, save_weights_only=True, mode='auto') + callbacks_list = [checkpoint] + # Fit the model + + history = estimator.fit(train_x, train_y, validation_split=0.33, epochs=12, batch_size=1, callbacks=callbacks_list, verbose=0) + #----------------------------- + # summarize history for loss + fig, ax = plt.subplots(1,1) + ax.plot(history.history['loss']) + ax.plot(history.history['val_loss']) + ax.set_title('Model Loss') + ax.set_ylabel('Performance') + ax.set_xlabel('Epochs') + ax.set_xlim(0.,12.) + ax.legend(['training loss', 'validation loss'], loc='upper left') + plt.savefig("keras_train_test.pdf") + plt.close(fig) + + # create model to test the weights + model = Sequential() + model.add(Dense(25, input_dim=2203, kernel_initializer='normal', activation='relu')) + model.add(Dense(25, kernel_initializer='normal', activation='relu')) + model.add(Dense(1, kernel_initializer='normal', activation='relu')) + + # load weights + model.load_weights(filepath) + + # Compile model + model.compile(loss='mean_squared_error', optimizer='Adamax', metrics=['accuracy']) + print("DNNTrackLengthTrain_Test Tool: Created model and loaded weights from"+filepath+"for testing") + + ## Predict. + print('DNNTrackLengthTrain_Test Tool: Predicting...') + x_transformed = scaler.transform(test_x) + y_predicted = model.predict(x_transformed) + + scores = model.evaluate(x_transformed, test_y, verbose=0) + print("%s: %.2f%%" % (model.metrics_names[1], scores[1]*100)) + + # Score with sklearn. + score_sklearn = metrics.mean_squared_error(y_predicted, test_y) + print('MSE (sklearn): {0:f}'.format(score_sklearn)) + + #----------------------------- + print("shapes: ", test_y.shape, ", ", y_predicted.shape) + #Creating a BoostStore to store the DNN reconstructed track length in the water in the DataModel to be loaded for the BDT trainining + RecoLengthStore = cppyy.gbl.BoostStore(True,0) + DNNRecoLength=std.vector[float](range(len(y_predicted))) + for k in range(len(y_predicted)): + DNNRecoLength[k]=float(y_predicted[k]) + print(DNNRecoLength.at(0),y_predicted[0]) + RecoLengthStore.Set("DNNRecoLength", DNNRecoLength) + self.m_data.Stores["RecoLength"] = RecoLengthStore + + #Make some plots for visualization purposes + fig0, ax0 = plt.subplots() + ax0.scatter(test_y,y_predicted) + ax0.plot([test_y.min(),test_y.max()],[test_y.min(),test_y.max()],'k--',lw=3) + ax0.set_xlabel('MC Tracklength in water(cm)') + ax0.set_ylabel('Predicted Reconstucted Length from DNN(cm)') + fig0.savefig('recolength.png') + plt.close(fig0) + + data = abs(y_predicted-test_y) + lambda_max=test_x[:,[2200]].tolist() + dataprev = abs(lambda_max-test_y) + nbins=np.arange(0.,400.,5) + fig1,ax1=plt.subplots(ncols=1, sharey=False) + f0=ax1.hist(data, nbins, histtype='step', fill=False, color='blue',alpha=0.75) + f1=ax1.hist(dataprev, nbins, histtype='step', fill=False, color='red',alpha=0.75) + ax1.set_xlabel('$\Delta R = |L_{Reco}-L_{MC}|$ [cm]') + ax1.legend(('NEW','Previous')) + ax1.xaxis.set_ticks(np.arange(0., 425., 25)) + ax1.tick_params(axis='x', which='minor', bottom=False) + xmin, xmax = plt.xlim() + title = "mean = %.2f, std = %.2f, Prev: mean = %.2f, std = %.2f " % (data.mean(), data.std(),dataprev.mean(), dataprev.std()) + plt.title(title) + fig1.savefig('resol_distr2l_WCSim.png') + plt.close(fig1) + + canvas = ROOT.TCanvas() + canvas.cd(1) + th2f = ROOT.TH2F("True_RecoLength", "; MC Track Length [cm]; Reconstructed Track Length [cm]", 50, 0, 400., 50, 0., 400.) + for i in range(len(test_y)): + th2f.Fill(test_y[i], y_predicted[i]) + line = ROOT.TLine(0.,0.,400.,400.) + th2f.SetStats(0) + th2f.Draw("ColZ") + line.SetLineColor(2) + line.Draw("same") + canvas.SaveAs("MClength_newrecolength.png") + return 1 + + def Finalise(self): + self.m_log.Log(__file__+" Finalising", self.v_debug, self.m_verbosity) + return 1 + +################### +# ↓ Boilerplate ↓ # +################### + +thistool = DNNTrackLengthTrain_Test() + +def SetToolChainVars(m_data_in, m_variables_in, m_log_in): + return thistool.SetToolChainVars(m_data_in, m_variables_in, m_log_in) + +def Initialise(): + return thistool.Initialise() + +def Execute(): + return thistool.Execute() + +def Finalise(): + return thistool.Finalise() diff --git a/UserTools/DNNTrackLengthTrain_Test/README.md b/UserTools/DNNTrackLengthTrain_Test/README.md new file mode 100644 index 000000000..906f07cb5 --- /dev/null +++ b/UserTools/DNNTrackLengthTrain_Test/README.md @@ -0,0 +1,49 @@ +# DNNTrackLengthTrain_Test + +The `DNNTrackLengthTrain_Test` tool is used to train a Deep Learning Neural Network(DNN) using the Keras library on top of Tensorflow to reconstruct the track length of the muon in the water. The tool loads the necessary information from the `EnergyReco` store which have saved to disk by the `FindTrackLengthInWater` tool. The `FindTrackLengthInWater` tool should hence always be placed before the `DNNTrackLengthTrain_Test` tool in a toolchain. The input dataset is split into half in order to use one half for training and testing the model and the second half for reconstructing the track length in the water and use these events to train the BDT for the muon energy in the next tool. After training and testing the weights are saved locally. The values of the reconstructed track length in the water for the second half of the dataset are saved in the `DNNRecoLength` store to be loaded by the next tool. Also, some parameters concerning the training dataset that will need to be used in the prediction toolchain to scale our data are saved locally in the `ScalingVarsStore`. A few plots are also drawn for visualization purposes. + +## Data + +### Input + +The following variables are obtained from the `EnergyReco` store: + +**MaxTotalHitsToDNN** `int` + +**lambda_vec** `std::vector` Vector with all the lambda values for each event + +**digit_ts_vec** `std::vector` Vector with the time of all the digits of each event + +**lambda_max** `double` The distance between the reconstructed vertex and last Cherenkov photon emission point along the track + +**num_pmt_hits** `int` Total number of pmt digits + +**num_lappd_hits** `int` Total number of lappd digits + +**TrueTrackLengthInWater** `float` MC track length in the water + +### Output + +**features_mean_values** `std::vector` Vector with the means of each feature of the training dataset + +**features_std_values** `std::vector` Vector with the standard deviations of each feature of the training dataset + +**DNNRecoLength** `std::vector` Vector with the reconstructed track length in water for each event of the second half of the event sample + +## Configuration + +``` +InitialiseFunction Initialise +ExecuteFunction Finalise +FinaliseFunction Execute +Everything is done in the Execute method of the tool. We need to run the Execute method in the Finalise step of the toolchain so that the FindTrackLengthInWater tool has already saved a multiple event sample for the training. + +TrackLengthOutputWeightsFile UserTools/DNNTrackLength/stand_alone/weights/weights_bets.hdf5 +The path where you want to save the weights file + +TrackLengthTrainingInputBoostStoreFile EnergyReco.bs +The path of the EnergyReco boost store + +ScalingVarsBoostStoreFile Data_Energy_Reco/ScalingVarsStore.bs +The path where you want to save the scaling parameters file +``` diff --git a/UserTools/Factory/Factory.cpp b/UserTools/Factory/Factory.cpp index 2215596e1..cd6659bd5 100644 --- a/UserTools/Factory/Factory.cpp +++ b/UserTools/Factory/Factory.cpp @@ -159,6 +159,7 @@ if (tool=="FilterLAPPDEvents") ret=new FilterLAPPDEvents; if (tool=="FilterEvents") ret=new FilterEvents; if (tool=="Stage1DataBuilder") ret=new Stage1DataBuilder; if (tool=="BeamFetcherV2") ret=new BeamFetcherV2; +if (tool=="PlotsTrackLengthAndEnergy") ret=new PlotsTrackLengthAndEnergy; if (tool=="SaveConfigInfo") ret=new SaveConfigInfo; if (tool=="ReadConfigInfo") ret=new ReadConfigInfo; return ret; diff --git a/UserTools/FindTrackLengthInWater/FindTrackLengthInWater.cpp b/UserTools/FindTrackLengthInWater/FindTrackLengthInWater.cpp index 260fde121..205724970 100644 --- a/UserTools/FindTrackLengthInWater/FindTrackLengthInWater.cpp +++ b/UserTools/FindTrackLengthInWater/FindTrackLengthInWater.cpp @@ -1,4 +1,6 @@ #include "FindTrackLengthInWater.h" +#include +#include "TMath.h" FindTrackLengthInWater::FindTrackLengthInWater():Tool(){} @@ -11,226 +13,357 @@ bool FindTrackLengthInWater::Initialise(std::string configfile, DataModel &data) m_data= &data; //assigning transient data pointer ///////////////////////////////////////////////////////////////// - // get configuration variables for this tool - m_variables.Get("InputFile",infile); - - file= new TFile(infile.c_str(),"READ"); - regTree= (TTree*) file->Get("vertextree"); - std::cout<<"Number of entries in tree: "<GetEntries()<1100){ - std::cerr<<" Please change the dim of double lambda_vec[1100]={0.}; double digitt[1100]={0.}; from 1100 to max number of hits"<Stores.emplace("EnergyReco",energystore);// place boost store in the DataModel + + // Get values from Config file + // =========================== + get_ok = m_variables.Get("MaxTotalHitsToDNN",maxhits0); + if(not get_ok){ + Log("FindTrackLengthInWater Tool: No MaxTotalHitsToDNN specified: assuming 1100, but this MUST match the value used for DNN training!",v_warning,verbosity); + maxhits0=1100; + } + Log("FindTrackLengthInWater Tool: max number of hits per event: "+to_string(maxhits0),v_debug,verbosity); + + // Get geometry variables from ANNIEEvent + // ============================= + get_ok = m_data->Stores.at("ANNIEEvent")->Header->Get("AnnieGeometry",anniegeom); + if(not get_ok){ + Log("FindTrackLengthInWater Tool: No Geometry in ANNIEEvent!",v_error,verbosity); + return false; + } + tank_radius = anniegeom->GetTankRadius()*100.; + std::cout<<"Tank radius is "<GetTankHalfheight()*100.; + std::cout<<"Tank halfheight is "<Branch("ievt", &ievt, "ievt/I"); - nu_eneNEW->Branch("neutrinoE", &trueNeuE, "neutrinoE/F"); - nu_eneNEW->Branch("trueKE", &trueE, "trueKE/F"); - nu_eneNEW->Branch("diffDirAbs2", &diffDirAbs2, "diffDirAbs2/F"); - nu_eneNEW->Branch("TrueTrackLengthInWater", &TrueTrackLengthInWater2, "TrueTrackLengthInWater/F"); - nu_eneNEW->Branch("TrueTrackLengthInMrd", &TrueTrackLengthInMrd2, "TrueTrackLengthInMrd/F"); - nu_eneNEW->Branch("recoDWallR2", &recoDWallR2, "recoDWallR2/F"); - nu_eneNEW->Branch("recoDWallZ2", &recoDWallZ2, "recoDWallZ2/F"); - nu_eneNEW->Branch("totalPMTs", &totalPMTs2, "totalPMTs/F"); - nu_eneNEW->Branch("totalLAPPDs", &totalLAPPDs2, "totalLAPPDs/F"); - nu_eneNEW->Branch("lambda_max_2", &lambda_max_2, "lambda_max_2/F"); - nu_eneNEW->Branch("dirX",&dirX2, "dirX/F"); - nu_eneNEW->Branch("dirY",&dirY2, "dirY/F"); - nu_eneNEW->Branch("dirZ",&dirZ2, "dirZ/F"); - nu_eneNEW->Branch("vtxX",&vtxX2, "vtxX/F"); - nu_eneNEW->Branch("vtxY",&vtxY2, "vtxY/F"); - nu_eneNEW->Branch("vtxZ",&vtxZ2, "vtxZ/F"); - - //----------- read the tree from file: - //deny_access=1; - Int_t run, event, nhits, trigger,recoStatus; - double vtxX,vtxY,vtxZ,dirX,dirY,dirZ,TrueTrackLengthInMrd,TrueTrackLengthInWater,TrueNeutrinoEnergy,trueEnergy,TrueMomentumTransfer,TrueMuonAngle; - std::string *TrueInteractionType = 0; - std::vector *digitX=0; std::vector *digitY=0; std::vector *digitZ=0; - std::vector *digitT=0; std::vector *digitType=0; - - regTree->GetEntry(currententry); - - regTree->SetBranchAddress("run", &run); - regTree->SetBranchAddress("event", &event); - regTree->SetBranchAddress("trueEnergy", &trueEnergy); - regTree->SetBranchAddress("TrueNeutrinoEnergy", &TrueNeutrinoEnergy); - regTree->SetBranchAddress("trigger", &trigger); - regTree->SetBranchAddress("nhits", &nhits); - regTree->SetBranchAddress("vtxX", &vtxX); - regTree->SetBranchAddress("vtxY", &vtxY); - regTree->SetBranchAddress("vtxZ", &vtxZ); - regTree->SetBranchAddress("dirX", &dirX); - regTree->SetBranchAddress("dirY", &dirY); - regTree->SetBranchAddress("dirZ", &dirZ); - regTree->SetBranchAddress("digitT", &digitT); - regTree->SetBranchAddress("digitX", &digitX); - regTree->SetBranchAddress("digitY", &digitY); - regTree->SetBranchAddress("digitZ", &digitZ); - regTree->SetBranchAddress("digitType", &digitType); - regTree->SetBranchAddress("recoStatus", &recoStatus); - regTree->SetBranchAddress("TrueInteractionType", &TrueInteractionType); - regTree->SetBranchAddress("TrueTrackLengthInMrd", &TrueTrackLengthInMrd); - regTree->SetBranchAddress("TrueTrackLengthInWater", &TrueTrackLengthInWater); - regTree->SetBranchAddress("TrueMomentumTransfer", &TrueMomentumTransfer); - regTree->SetBranchAddress("TrueMuonAngle", &TrueMuonAngle); - - double lambda_min = 10000000; double lambda_max = -99999999.9; double lambda = 0; - int totalPMTs=0; int totalLAPPDs=0; recoDWallR2=0; recoDWallZ2=0; diffDirAbs2=0; - double lambda_vec[1100]={0.}; double digitt[1100]={0.}; - - std::cout<<"currententry: "<0.){ - //std::cout<<"current entry: "<Stores.at("EnergyReco")->Delete();//clear the last entry from RAM + + // See if this event passes selection: we have several potential cuts. + // First check the EventCutstatus: event was in fiducial volume, had a stopping muon etc. + bool EventCutstatus; + get_ok = m_data->Stores.at("RecoEvent")->Get("EventCutStatus",EventCutstatus); + if(not get_ok){ + Log("FindTrackLengthInWater Tool: No EventCutStatus in the ANNIEEvent!",v_error,verbosity); + return false; + } + if(not EventCutstatus){ + Log("FindTrackLengthInWater Tool: Event did not pass the reconstruction selection cuts, skipping",v_message, verbosity); + return true; + } + count2++; + + // Check for the reconstructed tank vertex + RecoVertex* theExtendedVertex=nullptr; + get_ok = m_data->Stores.at("RecoEvent")->Get("ExtendedVertex", theExtendedVertex); + if((get_ok==0)||(theExtendedVertex==nullptr)){ + Log("FindTrackLengthInWater Tool: Failed to retrieve the ExtendedVertex from RecoEvent Store!",v_error,verbosity); + return false; + } + Int_t recoStatus = theExtendedVertex->GetStatus(); + double recoVtxFOM = theExtendedVertex->GetFOM(); + Log("FindTrackLengthInWater Tool: recoVtxFOM="+to_string(recoVtxFOM),v_debug,verbosity); + if(recoVtxFOM<=0.){ + Log("FindTrackLengthInWater Tool: Vertex reconstruction failed, skipping",v_message,verbosity); + return true; + } + Log("FindTrackLengthInWater Tool: Vertex reconstruction cuts passed",v_debug,verbosity); + count3++; + + //Get the reconstructed MRDTrackLength from CStore + std::vector> MrdTimeClusters; + std::vector* theMrdTracks; + int numtracksinev; + double MRDTrackLength=-9999; + Position StartVertex; + Position StopVertex; + //Load the mrd time clusters from CStore + bool get_clusters = m_data->CStore.Get("MrdTimeClusters",MrdTimeClusters); + if(!get_clusters){ + std::cout << "FindTrackLengthInWater tool: No MRD time clusters found. Will be no tracks." << std::endl; + return false; + } + + //loop through the time clusters and get the mrd tracks + for(int i=0; i < (int) MrdTimeClusters.size(); i++){ + m_data->Stores["MRDTracks"]->Get("MRDTracks",theMrdTracks); + m_data->Stores["MRDTracks"]->Get("NumMrdTracks",numtracksinev); + //loop through the mrd tracks and get the necessary info to calculate MRDTrackLength for each track + for(int tracki=0; trackiat(tracki)); + int TrackEventID = -1; + //get track properties that are needed for the through-going muon selection + thisTrackAsBoostStore->Get("MrdSubEventID",TrackEventID); + if(TrackEventID!= i) continue; + thisTrackAsBoostStore->Get("StartVertex",StartVertex); + thisTrackAsBoostStore->Get("StopVertex",StopVertex); + MRDTrackLength = sqrt(pow((StopVertex.X()-StartVertex.X()),2)+pow(StopVertex.Y()-StartVertex.Y(),2)+pow(StopVertex.Z()-StartVertex.Z(),2)) * 100.0; + } + } + //Don't use events without reconstructed track length in the MRD + if(MRDTrackLength<=0.){ + Log("FindTrackLengthInWater Tool: MRD reconstruction failed, skipping",v_message,verbosity); + return true; + } + count1++; + + // That's all the cuts! + // ==================== + //get info for mc vertex + RecoVertex *trueVtx = 0; + auto get_truevtx = m_data->Stores.at("RecoEvent")->Get("TrueVertex", trueVtx); + + //Get mc track length in the mrd stored in the RecoEvent store from previous tools + double TrueTrackLengthInMrd; + auto get_MRDTrackLength = m_data->Stores.at("RecoEvent")->Get("TrueTrackLengthInMRD", TrueTrackLengthInMrd); + Log("FindTrackLengthInWater Tool: TrueTrackLengthInMrd="+to_string(TrueTrackLengthInMrd),v_debug,verbosity); + + // proceed with getting event info we need to calculate the lambda values for the track length in water reconstruction + double vtxX,vtxY,vtxZ,dirX,dirY,dirZ,TrueNeutrinoEnergy,trueEnergy; + std::vector digitX; std::vector digitY; std::vector digitZ; + std::vector digitT; + + // get reconstructed vertex and direction info + Log("FindTrackLengthInWater Tool: Getting reco vertex and direction components",v_debug,verbosity); + vtxX = theExtendedVertex->GetPosition().X(); + vtxY = theExtendedVertex->GetPosition().Y(); + vtxZ = theExtendedVertex->GetPosition().Z(); + dirX = theExtendedVertex->GetDirection().X(); + dirY = theExtendedVertex->GetDirection().Y(); + dirZ = theExtendedVertex->GetDirection().Z(); + + // get additional primary muon info from RecoEvent store + Log("FindTrackLengthInWater Tool: Getting primary muon info",v_debug,verbosity); + double TrueTrackLengthInWater; + auto get_tankTrackLength = m_data->Stores.at("RecoEvent")->Get("TrueTrackLengthInWater", TrueTrackLengthInWater); + if(not get_tankTrackLength){ + Log("FindTrackLengthInWater Tool: Failed to retrieve the TrueTrackLengthInWater from RecoEvent Store!",v_error,verbosity); + return false; + } + auto get_muonMCEnergy = m_data->Stores.at("RecoEvent")->Get("TrueMuonEnergy", trueEnergy); + if(not get_muonMCEnergy){ + Log("FindTrackLengthInWater Tool: Failed to retrieve the TrueMuonEnergy from RecoEvent Store!",v_error,verbosity); + return false; + } + + /*// Get neutrino info needed for neutrino energy BDT training + get_ok = m_data->Stores.at("GenieEvent")->Get("TrueNeutrinoEnergy", TrueNeutrinoEnergy); + if(not get_ok){ + Log("FindTrackLengthInWater Tool: Failed to retrieve TrueNeutrinoEnergy!",v_error,verbosity); + return false; + } + */ + + // get digits from RecoDigit store + std::vector* digitList; + auto get_digits=m_data->Stores.at("RecoEvent")->Get("RecoDigit", digitList); + if(not get_digits){ + Log("FindTrackLengthInWater Tool: Failed to retrieve the RecoDigit from RecoEvent Store!",v_error,verbosity); + return false; + } + // Extract the PMT & LAPPD digit information + // =============================== + int totalPMTs =0; // number of digits from PMT hits in the event + int totalLAPPDs = 0; // number of digits from LAPPD hits in the event + //loop through all digits + for(RecoDigit &adigit : *digitList){ + digitX.push_back(adigit.GetPosition().X()); + digitY.push_back(adigit.GetPosition().Y()); + digitZ.push_back(adigit.GetPosition().Z()); + digitT.push_back(adigit.GetCalTime()); + if(adigit.GetDigitType()==0){totalPMTs+=1;} //when the digit type is zero we have a PMT digit + else{totalLAPPDs+=1;}// when it is 1 we have LAPPD + } + Log("FindTrackLengthInWater Tool: Got "+to_string(totalPMTs)+" PMT digits; "+to_string(digitT.size()) + +" total digits so far",v_debug,verbosity); + Log("FindTrackLengthInWater Tool: Got "+to_string(totalLAPPDs)+" LAPPD digits; "+to_string(digitT.size()) + +" total digits",v_debug,verbosity); + + // Estimate the track length in the tank + // ===================================== + //calculate diff dir with (0,0,1) double diffDirAbs0 = TMath::ACos(dirZ)*TMath::RadToDeg(); - //cout<<"diffDirAbs0: "<at(k)<<" | "<at(k)<at(k); - if( (digitType->at(k)) == "PMT8inch"){ totalPMTs++; } - if( (digitType->at(k)) == "lappd_v0"){ totalLAPPDs++; } - - //------ Find rack Length as the distance between the reconstructed vertex last photon emission point ----/ - lambda = find_lambda(vtxX,vtxY,vtxZ,dirX,dirY,dirZ,digitX->at(k),digitY->at(k),digitZ->at(k),42.); + float diffDirAbs2=diffDirAbs0/90.; + double recoVtxR2 = vtxX*vtxX + vtxZ*vtxZ; + double recoDWallR = tank_radius-TMath::Sqrt(recoVtxR2); + double recoDWallZ = tank_halfheight/2.-TMath::Abs(vtxY); + //Get true vtx and dir (optional) + double truevtxX=trueVtx->GetPosition().X(); + double truevtxY=trueVtx->GetPosition().Y(); + double truevtxZ=trueVtx->GetPosition().Z(); + double truedirX=trueVtx->GetDirection().X(); + double truedirY=trueVtx->GetDirection().Y(); + double truedirZ=trueVtx->GetDirection().Z(); + // Estimate the track length + // ========================= + Log("FindTrackLengthInWater Tool: Estimating track length in tank",v_debug,verbosity); + double lambda_min = 10000000; double lambda_max = -99999999.9; double lambda = 0; + std::vector lambda_vector; + for(int k=0; k= lambda_max ){ lambda_max = lambda; } - lambda_vec[k]=lambda; - //m_data->Stores["ANNIEEvent"]->Set("WaterRecoTrackLength",lambda_max); + lambda_vector.push_back(lambda); } - //std::cout<<"the track length in the water tank (1st approx) is: "<Fill(); - } - } - currententry++; - - if(currententry==regTree->GetEntries()) m_data->vars.Set("StopLoop",1); - //if(currententry==5) m_data->vars.Set("StopLoop",1); + + // Post-processing of variables to store + // ===================================== + float recoDWallR2 = recoDWallR/tank_radius; + float recoDWallZ2 = recoDWallZ/tank_halfheight*2.; + float TrueTrackLengthInWater2 = TrueTrackLengthInWater*100.; // convert to [cm] + float TrueTrackLengthInMrd2 = TrueTrackLengthInMrd; // it is already in [cm] + // we need to normalise the digit time and lambda vectors to fixed dimensions to match the MaxTotalHitsToDNN + + lambda_vector.resize(maxhits0); + + digitT.resize(maxhits0); + + //put MaxTotalHitsToDNN in store for use in the next tools + m_data->Stores.at("EnergyReco")->Set("MaxTotalHitsToDNN",maxhits0); + + // put the last successfully processed event number in the EnergyReco store as well. + // write the current event to file + uint32_t EventNumber; + get_ok = m_data->Stores.at("ANNIEEvent")->Get("EventNumber", EventNumber); + + + // Put these variables in the EnergyReco BoostStore + // ================================================ + Log("FindTrackLengthInWater Tool: putting event "+to_string(EventNumber)+" into the EnergyReco store",v_debug,verbosity); + m_data->Stores.at("EnergyReco")->Set("ThisEvtNum",EventNumber); + //std::cout<<"This is the Eventnumber you are looking for"<Stores.at("EnergyReco")->Set("lambda_vec",lambda_vector); + m_data->Stores.at("EnergyReco")->Set("digit_ts_vec",digitT); + m_data->Stores.at("EnergyReco")->Set("lambda_max",lambda_max); + m_data->Stores.at("EnergyReco")->Set("num_pmt_hits",totalPMTs); + m_data->Stores.at("EnergyReco")->Set("num_lappd_hits",totalLAPPDs); + m_data->Stores.at("EnergyReco")->Set("TrueTrackLengthInWater",TrueTrackLengthInWater2); + //m_data->Stores.at("EnergyReco")->Set("trueNeuE",TrueNeutrinoEnergy); + m_data->Stores.at("EnergyReco")->Set("trueMuonEnergy",trueEnergy); + m_data->Stores.at("EnergyReco")->Set("diffDirAbs",diffDirAbs2); + //m_data->Stores.at("EnergyReco")->Set("TrueTrackLengthInMrd",TrueTrackLengthInMrd2); + m_data->Stores.at("EnergyReco")->Set("recoDWallR",recoDWallR2); + m_data->Stores.at("EnergyReco")->Set("recoDWallZ",recoDWallZ2); + m_data->Stores.at("EnergyReco")->Set("dirVec",theExtendedVertex->GetDirection()); + m_data->Stores.at("EnergyReco")->Set("vtxVec",theExtendedVertex->GetPosition()); + m_data->Stores.at("EnergyReco")->Set("recoTrackLengthInMrd",MRDTrackLength); + + if(not fDoTraining){ + Log("FindTrackLengthInWater Tool: Not doing training, so BoostStore will not be saved locally",v_error,verbosity); + } +// only save all data to disk when training +if(fDoTraining){ + m_data->Stores.at("EnergyReco")->Save("EnergyReco.bs"); // write this Energy Reco entry to disk. If the file exists, it appends as a new entry. + } +//---------------------------------------------------------------------------------------------------------------------------------------------------------// + if(lambda_vector.size()!=maxhits0){ + Log("FindTrackLengthInWater Tool: Error! lambdavector size is not maxhits0! Check dimensions!",v_error,verbosity); + return false; + } + if(digitT.size()!=maxhits0){ + Log("FindTrackLengthInWater Tool: Error! digitT size is not maxhits0! Check dimensions!",v_error,verbosity); + return false; + } + + // Write to .csv file + // ================== + if(not csvfile.is_open()){ + Log("FindTrackLengthInWater Tool: output file is closed, skipping write",v_debug,verbosity); + return true; + } + + for(int i=0; iWrite(); + m_data->Stores.at("EnergyReco")->Close(); + if(csvfile.is_open()) csvfile.close(); + Log("FindTrackLengthInWater Tool: processed "+to_string(count1)+" events",v_message,verbosity); + std::cout<<"processed a total of "< #include -#include #include "ANNIEalgorithms.h" #include "Tool.h" @@ -25,25 +24,24 @@ class FindTrackLengthInWater: public Tool { private: - std::string infile; - TFile* file; - TTree* regTree; - TTree * nu_eneNEW; - ExampleRoot* Data; - int maxhits0=1100; - long currententry; - long NumEvents; bool first=1; bool deny_access=0; - double diffDirAbs2=0; double diffDirAbs=0; - double recoDWallR2=0; double recoDWallZ2=0; - int count1=0; - + // counters to keep track of cut efficiencies + int count1=0, count2=0, count3=0, count4=0; std::ofstream csvfile; - std::string myfile; - std::string outputdir=""; - bool writefile=false; - TFile* outputFile; + Geometry* anniegeom=nullptr; + double tank_radius; + double tank_halfheight; + int fDoTraining=0; + + // verbosity levels: if 'verbosity' < this level, the message type will be logged. + int verbosity=1; + int v_error=0; + int v_warning=1; + int v_message=2; + int v_debug=3; + std::string logmessage; + int get_ok; }; diff --git a/UserTools/FindTrackLengthInWater/README.md b/UserTools/FindTrackLengthInWater/README.md index 915425343..4fdd4ff5e 100644 --- a/UserTools/FindTrackLengthInWater/README.md +++ b/UserTools/FindTrackLengthInWater/README.md @@ -1,7 +1,72 @@ # FindTrackLengthInWater -FindTrackLengthInWater +The `FindTrackLengthInWater` tool uses the `find_lambda()` function to calculate the length between the reconstructed Vertex and the photon production Point(lambda) for each digit. These lengths are going to be used to reconstruct the track in the water in the next tool. In order to do that the tool requires information about the `ExtendedVertex` and the `RecoDigit` which are stored in the `RecoEvent` store from previous tools. Then the required information for the track length and energy reconstruction are passed to the next tools through the `EnergyReco` boost store. Also cuts are applied to exclude events with bad vertex reconstruction(recovtxFOM<=0) and with no reconstructed tracks in the MRD. -* Takes the .root file from reconstruction (e.g. reco26_5LAPPDs+128PMTs_extv3_9.root), calculates the track length as the distance between the first and last Cherenkov photon emission point along the track and stores variables for track length reconstruction using DNN in a .csv file. -* Set input/output file names at: configfiles/FindTrackLengthInWater/LoadRecoInputFile +## Data +### Input + +The following variables are obtained from the `ANNIEEvent` store: + +**EventNumber** `uint32_t` + +**AnnieGeometry**(Header) `Geometry` Retrieve the tank radius and the tank halfheight from the geometry object of the `ANNIEEvent` store + +The following variables are obtained from the `RecoEvent` store: + +**ExtendedVertex** `RecoVertex` Contains the reconstructed Vertex information + +**MrdTimeClusters** `vector>` One vector for each subevent containing the digit IDs for clustered hits in each subevent + +**TrueTrackLengthInWater** `double` MC track length in the water is retrieved from the `RecoEvent` store + +**TrueMuonEnergy** `double` MC muon energy is retrieved from the `RecoEvent` store + +**RecoDigit** `std::vector` One vector for each event containing the RecoDigit objects for each event + +### Output + +The following variables are passed on to the next tool via the `EnergyReco` store: + +**MaxTotalHitsToDNN** `int` + +**ThisEvtNum** `uint32_t` + +**lambda_vec** `std::vector` Vector with all the lambda values for each event + +**digit_ts_vec** `std::vector` Vector with the time of all the digits of each event + +**lambda_max** `double` The distance between the reconstructed vertex and last Cherenkov photon emission point along the track + +**num_pmt_hits** `int` Total number of pmt digits + +**num_lappd_hits** `int` Total number of lappd digits + +**TrueTrackLengthInWater** `float` MC track length in the water + +**trueMuonEnergy** `double` MC muon energy + +**diffDirAbs** `double` Angle difference between the reconstructed z direction and the beam direction at (0,0,1) + +**recoDWallR** `double` Radial distance of the reconstructed vertex from the walls of the tank + +**recoDWallZ** `double` Axial distance of the reconstructed vertex from the walls of the tank + +**dirVec** `Direction` Direction of the reconstructed vertex + +**vtxVec** `Position` Position of the reconstructed vertex + +**recoTrackLengthInMrd** Track length of a reconstructed track in the MRD found by the `FindMrdTracks` tool + +## Configuration + +``` +MaxTotalHitsToDNN 1100 +This is set to 1100 as a reasonable upper limit to the total number of hits that might happen in a single event in order to have a fixed number of features for the DNN + +OutputDataFile data_for_trackLength_training.csv +There exists the capabillity to create an output .csv file with the necessary information for the DNN for any inpdependent analysis or testing + +DoTraining bool +It is by default set to 0. Only when you want to run the training toolchain you need to set it to 1 +``` diff --git a/UserTools/PlotsTrackLengthAndEnergy/PlotsTrackLengthAndEnergy.cpp b/UserTools/PlotsTrackLengthAndEnergy/PlotsTrackLengthAndEnergy.cpp new file mode 100644 index 000000000..a8b33ab95 --- /dev/null +++ b/UserTools/PlotsTrackLengthAndEnergy/PlotsTrackLengthAndEnergy.cpp @@ -0,0 +1,121 @@ +#include "PlotsTrackLengthAndEnergy.h" +#include "TCanvas.h" +#include "TMath.h" +#include "TH2F.h" +#include "TLegend.h" +#include "TAxis.h" +#include "TLine.h" + +PlotsTrackLengthAndEnergy::PlotsTrackLengthAndEnergy():Tool(){} + + +bool PlotsTrackLengthAndEnergy::Initialise(std::string configfile, DataModel &data){ + + /////////////////// Useful header /////////////////////// + if(configfile!="") m_variables.Initialise(configfile); // loading config file + //m_variables.Print(); + + m_data= &data; //assigning transient data pointer + ///////////////////////////////////////////////////////////////// + + return true; +} + + +bool PlotsTrackLengthAndEnergy::Execute(){ + + BoostStore EnergyReco(true,2); + + EnergyReco.Initialise("EnergyRecoStore.bs"); + + unsigned long n_entries; + bool get_ok = EnergyReco.Header->Get("TotalEntries", n_entries); + if(not get_ok) { + Log("PlotsTrackLengthAndEnergy Tool: EnergyRecoStore file does not exist, run the EnergyRecoPredict toolchain first!",v_error,verbosity); + return false; + } + std::cout<<"got total entries; "< +#include + +#include "Tool.h" + + +/** + * \class PlotsTrackLengthAndEnergy + * + * This is a blank template for a Tool used by the script to generate a new custom tool. Please fill out the description and author information. +* +* $Author: B.Richards $ +* $Date: 2019/05/28 10:44:00 $ +* Contact: b.richards@qmul.ac.uk +*/ +class PlotsTrackLengthAndEnergy: public Tool { + + + public: + + PlotsTrackLengthAndEnergy(); ///< Simple constructor + bool Initialise(std::string configfile,DataModel &data); ///< Initialise Function for setting up Tool resources. @param configfile The path and name of the dynamic configuration file to read in. @param data A reference to the transient data class used to pass information between Tools. + bool Execute(); ///< Execute function used to perform Tool purpose. + bool Finalise(); ///< Finalise function used to clean up resources. + + + private: + +// verbosity levels: if 'verbosity' < this level, the message type will be logged. + int verbosity=1; + int v_error=0; + int v_warning=1; + int v_message=2; + int v_debug=3; + std::string logmessage; + + + +}; + + +#endif diff --git a/UserTools/PlotsTrackLengthAndEnergy/README.md b/UserTools/PlotsTrackLengthAndEnergy/README.md new file mode 100644 index 000000000..c3f1db6f5 --- /dev/null +++ b/UserTools/PlotsTrackLengthAndEnergy/README.md @@ -0,0 +1,23 @@ +# PlotsTrackLengthAndEnergy + +The `PlotsTrackLengthAndEnergy` tool is used to plot the reconstructed track length and energy from the DNN and the BDT. Therefore this tool should be run only after running the `EnergyRecoPredict` toolchain. This tool loads the `EnergyReco` boost store that is being saved locally by the `BDTMuonEnergyPredict` tool in order to make the plots we want. + +## Data + +### Input + +The following variables are obtained from the `EnergyRecoStore`: + +**lambda_max** `double` The distance between the reconstructed vertex and last Cherenkov photon emission point along the track + +**TrueTrackLengthInWater** `float` MC track length in the water + +**DNNRecoLength** `double` The reconstructed track length in water for a single event + +**trueMuonEnergy** `double` MC muon energy + +**BDTMuonEnergy** `double` The reconstructed energy of the muon for a single event + +## Configuration + +There aren't any configuration variables for PlotsTrackLengthAndEnergy. diff --git a/UserTools/Unity.h b/UserTools/Unity.h index db441a61d..dc6e501b7 100644 --- a/UserTools/Unity.h +++ b/UserTools/Unity.h @@ -167,5 +167,6 @@ #include "FilterEvents.h" #include "Stage1DataBuilder.h" #include "BeamFetcherV2.h" +#include "PlotsTrackLengthAndEnergy.h" #include "SaveConfigInfo.h" #include "ReadConfigInfo.h" diff --git a/configfiles/EnergyReco/DummyToolConfig b/configfiles/EnergyReco/DummyToolConfig deleted file mode 100644 index 95cad88d2..000000000 --- a/configfiles/EnergyReco/DummyToolConfig +++ /dev/null @@ -1,3 +0,0 @@ -# Dummy config file - -verbose 2 \ No newline at end of file diff --git a/configfiles/EnergyReco/Erecoconfig b/configfiles/EnergyReco/Erecoconfig deleted file mode 100644 index ae289ebdf..000000000 --- a/configfiles/EnergyReco/Erecoconfig +++ /dev/null @@ -1,6 +0,0 @@ -#PythonScript BDT_MuonEnergyReco -PythonScript BDT_NeutrinoEnergyReco - -InitialiseFunction Initialise -ExecuteFunction Execute -FinaliseFunction Finalise diff --git a/configfiles/EnergyReco/Predict/BDTMuonEnergyPredictConfig b/configfiles/EnergyReco/Predict/BDTMuonEnergyPredictConfig new file mode 100644 index 000000000..6eb0a32e5 --- /dev/null +++ b/configfiles/EnergyReco/Predict/BDTMuonEnergyPredictConfig @@ -0,0 +1,9 @@ +# This config file stores variables that may be retrieved by the python script +# Access them by retrieving the corresponding variable from the 'Config' store + +PythonScript BDTMuonEnergyPredict + +verbose 1 + +# BDT model file to load +BDTMuonModelFile finalized_BDTmodel_forMuonEnergy.sav diff --git a/configfiles/EnergyReco/Predict/ClusterFinderConfig b/configfiles/EnergyReco/Predict/ClusterFinderConfig new file mode 100644 index 000000000..05600b7fb --- /dev/null +++ b/configfiles/EnergyReco/Predict/ClusterFinderConfig @@ -0,0 +1,12 @@ +# ClusterFinder Config File + +HitStore MCHits #Either MCHits or Hits (accessed in ANNIEEvent store) +OutputFile Run1415S0_AllPMTs_ClusterFinder #Output root prefix name for the current run +ClusterFindingWindow 50 # in ns, size of the window used to "clusterize" +AcqTimeWindow 4000 # in ns, size of the acquisition window +ClusterIntegrationWindow 50 # in ns, all hits with +/- 1/2 of this window are considered in the cluster +MinHitsPerCluster 10 # group of hits are considered clusters above this amount of hits + +verbosity 0 #verbosity of the application +end_of_window_time_cut 0.95 # from 0 to 1, length of the window you want to loop over with respect to acq. window (1 for full window, 0.95 for 95% from the start) +Plots2D 0 #2D charge-vs-time plot to be drawn? diff --git a/configfiles/EnergyReco/Predict/DNNTrackLengthPredictConfig b/configfiles/EnergyReco/Predict/DNNTrackLengthPredictConfig new file mode 100644 index 000000000..7dd7ac486 --- /dev/null +++ b/configfiles/EnergyReco/Predict/DNNTrackLengthPredictConfig @@ -0,0 +1,13 @@ +# This config file stores variables that may be retrieved by the python script +# Also this is a caller config file + +PythonScript DNNTrackLengthPredict + +verbose 1 + +# DNN model, weights etc +TrackLengthWeightsFile UserTools/DNNTrackLength/stand_alone/weights/weights_bets.hdf5 + +# Scaling Parameters + +ScalingVarsBoostStoreFile Data_Energy_Reco/ScalingVarsStore.bs diff --git a/configfiles/EnergyReco/Predict/DigitBuilderConfig b/configfiles/EnergyReco/Predict/DigitBuilderConfig new file mode 100644 index 000000000..8eed149e9 --- /dev/null +++ b/configfiles/EnergyReco/Predict/DigitBuilderConfig @@ -0,0 +1,11 @@ +# DigitBuilder config file + +verbosity 0 +ParametricModel 1 +#Reading in MC files +IsMC 1 +DigitChargeThr 20 +# There are three configurations: "PMT_only", "LAPPD_only", "All" +PhotoDetectorConfiguration All +#File must be in /pnfs/ space when loading on Fermilab cluster +LAPPDIDFile configfiles/EnergyReco/Predict/LAPPDIDs.txt diff --git a/configfiles/EnergyReco/Predict/EventSelectorConfig b/configfiles/EnergyReco/Predict/EventSelectorConfig new file mode 100644 index 000000000..ca6032811 --- /dev/null +++ b/configfiles/EnergyReco/Predict/EventSelectorConfig @@ -0,0 +1,15 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 1 +MCMRDCut 1 +MCPiKCut 0 +MCIsMuonCut 1 +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 1 +PromptTrigOnly 1 +SaveStatusToStore 1 +Triggerword -1 diff --git a/configfiles/EnergyReco/Predict/FindMrdTracksConfig b/configfiles/EnergyReco/Predict/FindMrdTracksConfig new file mode 100644 index 000000000..7a9d11f7d --- /dev/null +++ b/configfiles/EnergyReco/Predict/FindMrdTracksConfig @@ -0,0 +1,12 @@ +# FindMrdTracks Config File +# all variables retrieved with m_variables.Get() must be defined here! + +verbosity 0 +IsData 0 +OutputDirectory . +OutputFile STEC_MRDTracks_cluster40ns +DrawTruthTracks 0 # whether to add MC Truth track info for drawing in MrdPaddlePlot Tool + ## note you need to run that tool to actually view the tracks! +WriteTracksToFile 0 # should the track information be written to a ROOT-file? +SelectTriggerType 0 #should the loaded data be filtered by trigger type? +TriggerType Beam #options: Cosmic, Beam, No Loopback diff --git a/configfiles/EnergyReco/Predict/FindTrackLengthInWaterConfig b/configfiles/EnergyReco/Predict/FindTrackLengthInWaterConfig new file mode 100644 index 000000000..2322e20c5 --- /dev/null +++ b/configfiles/EnergyReco/Predict/FindTrackLengthInWaterConfig @@ -0,0 +1,5 @@ +#FindTrackLengthInWater Config File +# all variables retrieved with m_variables.Get() must be defined here! +verbosity 1 +MaxTotalHitsToDNN 1100 +OutputDataFile beamlikeEvts.csv diff --git a/configfiles/EnergyReco/Predict/HitCleanerConfig b/configfiles/EnergyReco/Predict/HitCleanerConfig new file mode 100644 index 000000000..36d7f0137 --- /dev/null +++ b/configfiles/EnergyReco/Predict/HitCleanerConfig @@ -0,0 +1,20 @@ +# HitCleaner config file + +verbosity 5 +Config 2 #config type: 1 = pulse height cut, 2 = +neighbour cut, 3 = +cluster cut +PmtMinPulseHeight 20 #minimum pulse height +PmtNeighbourRadius 60 #digit neighbouring distance [cm] +PmtMinNeighbourDigits 2 #minimum neighbour digits +PmtClusterRadius 60 #digit clustering distance [cm] +PmtTimeWindowN 10 #neighbouring time window [ns] +PmtTimeWindowC 10 #clustering time window [ns] +PmtMinHitsPerCluster 4 #number of hits per cluster +LappdMinPulseHeight 0 #minimum pulse height +LappdNeighbourRadius 25 #digit neighbouring distance [cm] +LappdMinNeighbourDigits 20 #minimum neighbour digits +LappdClusterRadius 25 #digit clustering distance [cm] +LappdTimeWindowN 1 #neighbouring time window [ns] +LappdTimeWindowC 1 #clustering time window [ns] +LappdMinHitsPerCluster 20 #number of digits per cluster +#MinClusterDigits 50 #minimum clustered digits (LAPPD+PMT) +MinClusterDigits 10 #minimum clustered digits (PMT-only) diff --git a/configfiles/EnergyReco/Predict/LAPPDIDs.txt b/configfiles/EnergyReco/Predict/LAPPDIDs.txt new file mode 100644 index 000000000..776b28912 --- /dev/null +++ b/configfiles/EnergyReco/Predict/LAPPDIDs.txt @@ -0,0 +1,5 @@ +11 +13 +14 +15 +17 diff --git a/configfiles/EnergyReco/Predict/LoadWCSimConfig b/configfiles/EnergyReco/Predict/LoadWCSimConfig new file mode 100644 index 000000000..001d2e929 --- /dev/null +++ b/configfiles/EnergyReco/Predict/LoadWCSimConfig @@ -0,0 +1,15 @@ +#LoadWCSim Config File +# all variables retrieved with m_variables.Get() must be defined here! +verbose 0 + +InputFile /pnfs/annie/persistent/simulations/wcsim/G1810a0211a/standard/tank/pmt/wcsim_0* #James's files + +TriggerType Beam +SplitSubTriggers 1 + +WCSimVersion 10 ## should reflect the WCSim version of the files being loaded +HistoricTriggeroffset 0 ## time offset of digits relative to the trigger +#UseDigitSmearedTime 1 ## whether to use smeared digit time (T), or true time of first photon (F) +LappdNumStrips 60 ## num channels to construct from each LAPPD +LappdStripLength 100 ## relative x position of each LAPPD strip, for dual-sided readout [mm] +LappdStripSeparation 10 ## stripline separation, for calculating relative y position of each LAPPD strip [mm] diff --git a/configfiles/EnergyReco/Predict/LoadWCSimLAPPDConfig b/configfiles/EnergyReco/Predict/LoadWCSimLAPPDConfig new file mode 100644 index 000000000..2b82ff922 --- /dev/null +++ b/configfiles/EnergyReco/Predict/LoadWCSimLAPPDConfig @@ -0,0 +1,10 @@ +#LoadWCSimLAPPD Config File +# all variables retrieved with m_variables.Get() must be defined here! +verbose 0 + +InputFile /pnfs/annie/persistent/simulations/wcsim/G1810a0211a/standard/tank/lappd/wcsim_lappd_0* #James's files + +WCSimVersion 10 ## should reflect the WCSim version of the files being loaded +InnerStructureRadius 1.3545 ## octagonal inner structure radius in m (from drawings 106.64") +HistoricTriggeroffset 0 +DrawDebugGraphs 0 ## whether to draw TPolyMarker3D's of hits diff --git a/configfiles/EnergyReco/Predict/MCParticlePropertiesConfig b/configfiles/EnergyReco/Predict/MCParticlePropertiesConfig new file mode 100644 index 000000000..752200268 --- /dev/null +++ b/configfiles/EnergyReco/Predict/MCParticlePropertiesConfig @@ -0,0 +1 @@ +verbosity 0 diff --git a/configfiles/EnergyReco/Predict/MCRecoEventLoaderConfig b/configfiles/EnergyReco/Predict/MCRecoEventLoaderConfig new file mode 100644 index 000000000..193bfd196 --- /dev/null +++ b/configfiles/EnergyReco/Predict/MCRecoEventLoaderConfig @@ -0,0 +1,12 @@ +# MCRecoEventLoader config file + +verbosity 0 +#Get Pion/Kaon counts from MC Truth +GetPionKaonInfo 1 +#Particle ID you want to load from parent particles; 13 for muon +ParticleID 13 +#coordinate shifts needed to put particles in tank origin coordinates +xshift 0.0 +yshift 14.46469 +zshift -168.1 + diff --git a/configfiles/EnergyReco/Predict/PlotsTrackLengthAndEnergyConfig b/configfiles/EnergyReco/Predict/PlotsTrackLengthAndEnergyConfig new file mode 100644 index 000000000..ef7a3d415 --- /dev/null +++ b/configfiles/EnergyReco/Predict/PlotsTrackLengthAndEnergyConfig @@ -0,0 +1 @@ +#PlotsTrackLengthAndEnergy config file diff --git a/configfiles/EnergyReco/Predict/TimeClusteringConfig b/configfiles/EnergyReco/Predict/TimeClusteringConfig new file mode 100644 index 000000000..03419833f --- /dev/null +++ b/configfiles/EnergyReco/Predict/TimeClusteringConfig @@ -0,0 +1,12 @@ +#TimeClustering config file + +verbosity 1 +MinDigitsForTrack 4 +MaxMrdSubEventDuration 40 +MinSubeventTimeSep 40 +MakeMrdDigitTimePlot 0 +LaunchTApplication 0 +IsData 0 +#OutputROOTFile TimeClustering_MRDTest28_cluster40ns +OutputROOTFile STEC_TimeClusteringOut +MapChankey_WCSimID ./configfiles/SimpleTankEnergyCalibrator/MRD_Chankey_WCSimID.dat diff --git a/configfiles/EnergyReco/ToolChainConfig b/configfiles/EnergyReco/Predict/ToolChainConfig similarity index 71% rename from configfiles/EnergyReco/ToolChainConfig rename to configfiles/EnergyReco/Predict/ToolChainConfig index db437bc5c..ad7c94761 100644 --- a/configfiles/EnergyReco/ToolChainConfig +++ b/configfiles/EnergyReco/Predict/ToolChainConfig @@ -15,9 +15,9 @@ service_publish_sec -1 service_kick_sec -1 ##### Tools To Add ##### -Tools_File configfiles/EnergyReco/ToolsConfig ## list of tools to run and their config files +Tools_File configfiles/EnergyReco/Predict/ToolsConfig ## list of tools to run and their config files ##### Run Type ##### -Inline 1 #-1 ## number of Execute steps in program, -1 infinite loop that is ended by user -Interactive 1 #0 ## set to 1 if you want to run the code interactively +Inline -1 ## number of Execute steps in program, -1 infinite loop that is ended by user +Interactive 0 ## set to 1 if you want to run the code interactively diff --git a/configfiles/EnergyReco/Predict/ToolsConfig b/configfiles/EnergyReco/Predict/ToolsConfig new file mode 100644 index 000000000..5926759d1 --- /dev/null +++ b/configfiles/EnergyReco/Predict/ToolsConfig @@ -0,0 +1,19 @@ +# predict machine learning algorithm +myLoadWCSim LoadWCSim configfiles/EnergyReco/Predict/LoadWCSimConfig +myLoadWCSimLAPPD LoadWCSimLAPPD configfiles/EnergyReco/Predict/LoadWCSimLAPPDConfig +myMCParticleProperties MCParticleProperties configfiles/EnergyReco/Predict/MCParticlePropertiesConfig +MCRecoEventLoader MCRecoEventLoader configfiles/EnergyReco/Predict/MCRecoEventLoaderConfig +DigitBuilder DigitBuilder configfiles/EnergyReco/Predict/DigitBuilderConfig +HitCleaner HitCleaner configfiles/EnergyReco/Predict/HitCleanerConfig +ClusterFinder ClusterFinder configfiles/EnergyReco/Predict/ClusterFinderConfig +TimeClustering TimeClustering configfiles/EnergyReco/Predict/TimeClusteringConfig +EventSelector EventSelector configfiles/EnergyReco/Predict/EventSelectorConfig +FindMrdTracks FindMrdTracks configfiles/EnergyReco/Predict/FindMrdTracksConfig +VtxSeedGenerator VtxSeedGenerator configfiles/EnergyReco/Predict/VtxSeedGeneratorConfig +VtxSeedFineGrid VtxSeedFineGrid configfiles/EnergyReco/Predict/VtxSeedFineGridConfig +VtxExtendedVertexFinder VtxExtendedVertexFinder configfiles/EnergyReco/Predict/VtxExtendedVertexFinderConfig + +FindTrackLengthInWater FindTrackLengthInWater configfiles/EnergyReco/Predict/FindTrackLengthInWaterConfig +DNNTrackLengthPredict PythonScript configfiles/EnergyReco/Predict/DNNTrackLengthPredictConfig +BDTMuonEnergyPredict PythonScript configfiles/EnergyReco/Predict/BDTMuonEnergyPredictConfig +#PlotsTrackLengthAndEnergy PlotsTrackLengthAndEnergy configfiles/EnergyReco/Predict/PlotsTrackLengthAndEnergyConfig diff --git a/configfiles/EnergyReco/Predict/VtxExtendedVertexFinderConfig b/configfiles/EnergyReco/Predict/VtxExtendedVertexFinderConfig new file mode 100644 index 000000000..59f74e5eb --- /dev/null +++ b/configfiles/EnergyReco/Predict/VtxExtendedVertexFinderConfig @@ -0,0 +1,9 @@ +# VtxPointPositionFinder config file + +verbosity 5 + +# Only one of the options below should be set to 1. All the others should be set to 0 +UseTrueVertexAsSeed 0 +UsePointVertexAsSeed 0 +FitAllOnSeedGrid 1 +UseMeanTimeAsSeed 0 diff --git a/configfiles/EnergyReco/Predict/VtxSeedFineGridConfig b/configfiles/EnergyReco/Predict/VtxSeedFineGridConfig new file mode 100644 index 000000000..674e643a0 --- /dev/null +++ b/configfiles/EnergyReco/Predict/VtxSeedFineGridConfig @@ -0,0 +1,7 @@ +verbosity 5 +useDirectionGrid 0 +useSimpleDirection 1 +useTrueDir 0 +useMRDTrack 0 +usePastResolution 0 +multiGrid 1 diff --git a/configfiles/EnergyReco/Predict/VtxSeedGeneratorConfig b/configfiles/EnergyReco/Predict/VtxSeedGeneratorConfig new file mode 100644 index 000000000..fe2688cc3 --- /dev/null +++ b/configfiles/EnergyReco/Predict/VtxSeedGeneratorConfig @@ -0,0 +1,7 @@ +# VtxSeedGenerator config file + +verbosity 3 +NumberOfSeeds 300 +UseSeedGrid 1 +SeedType 2 +UseFineGrid 0 diff --git a/configfiles/EnergyReco/README.md b/configfiles/EnergyReco/README.md index 5afa52c11..c7082bf29 100644 --- a/configfiles/EnergyReco/README.md +++ b/configfiles/EnergyReco/README.md @@ -1,25 +1,60 @@ # Configure files *********************** -#Description +# Description ********************** -Configure files are simple text files for passing variables to the Tools. - -Text files are read by the Store class (src/Store) and automatically asigned to an internal map for the relavent Tool to use. +The `EnergyReco` toolchains are used to reconstruct the track length in the water tank and the tank energy of a muon by using a Deep Learning Neural Network(DNN) and a Boosted Decision Tree(BDT) with Gradient Boost. The `Train_Test` toolchain is used to train and test the models that we want to use later for the reconstruction. The `Predict` toolchain is used after we've trained the models in order to reconstruct the track length in the water tank and the tank energy of a muon for different events. +Both of these toolchains require information from the digit, the MRD and the vertex reconstruction so the appropriate tools need to be used. ************************ -#Useage +# Tools ************************ -Any line starting with a "#" will be ignored by the Store, as will blank lines. - -Variables should be stored one per line as follows: - +************************ +# Train_Test +************************ -Name Value #Comments +The tools in the `Train_Test` toolchain are the following: + +* LoadWCSim +* LoadWCSimLAPPD +* MCParticleProperties +* MCRecoEventLoader +* DigitBuilder +* HitCleaner +* ClusterFinder +* TimeClustering +* EventSelector +* FindMrdTracks +* VtxSeedGenerator +* VtxSeedFineGrid +* VtxExtendedVertexFinder +* FindTrackLengthInWater +* DNNTrackLengthTrain_Test +* BDTMuonEnergyTrain_Test +************************ +# Predict +************************ -Note: Only one value is permitted per name and they are stored in a string stream and templated cast back to the type given. +The tools in the `Predict` toolchain are the following: + +* LoadWCSim +* LoadWCSimLAPPD +* MCParticleProperties +* MCRecoEventLoader +* DigitBuilder +* HitCleaner +* ClusterFinder +* TimeClustering +* EventSelector +* FindMrdTracks +* VtxSeedGenerator +* VtxSeedFineGrid +* VtxExtendedVertexFinder +* FindTrackLengthInWater +* DNNTrackLengthPredict +* BDTMuonEnergyPredict diff --git a/configfiles/EnergyReco/ToolsConfig b/configfiles/EnergyReco/ToolsConfig deleted file mode 100644 index 5bf9f59c1..000000000 --- a/configfiles/EnergyReco/ToolsConfig +++ /dev/null @@ -1 +0,0 @@ -EnergyReco PythonScript configfiles/EnergyReco/Erecoconfig diff --git a/configfiles/EnergyReco/Train_Test/BDTMuonEnergyTrainConfig b/configfiles/EnergyReco/Train_Test/BDTMuonEnergyTrainConfig new file mode 100644 index 000000000..d5fdbff87 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/BDTMuonEnergyTrainConfig @@ -0,0 +1,15 @@ +# This config file stores variables that may be retrieved by the python script +# Access them by retrieving the corresponding variable from the 'Config' store + +PythonScript BDTMuonEnergyTrain_Test + +verbosity 1 + +InitialiseFunction Initialise +ExecuteFunction Finalise +FinaliseFunction Execute + +# BDT model file to write +BDTMuonEnergyWeightsFile finalized_BDTmodel_forMuonEnergy.sav + +BDTMuonEnergyTrainingInputBoostStoreFile EnergyReco.bs diff --git a/configfiles/EnergyReco/Train_Test/ClusterFinderConfig b/configfiles/EnergyReco/Train_Test/ClusterFinderConfig new file mode 100644 index 000000000..05600b7fb --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/ClusterFinderConfig @@ -0,0 +1,12 @@ +# ClusterFinder Config File + +HitStore MCHits #Either MCHits or Hits (accessed in ANNIEEvent store) +OutputFile Run1415S0_AllPMTs_ClusterFinder #Output root prefix name for the current run +ClusterFindingWindow 50 # in ns, size of the window used to "clusterize" +AcqTimeWindow 4000 # in ns, size of the acquisition window +ClusterIntegrationWindow 50 # in ns, all hits with +/- 1/2 of this window are considered in the cluster +MinHitsPerCluster 10 # group of hits are considered clusters above this amount of hits + +verbosity 0 #verbosity of the application +end_of_window_time_cut 0.95 # from 0 to 1, length of the window you want to loop over with respect to acq. window (1 for full window, 0.95 for 95% from the start) +Plots2D 0 #2D charge-vs-time plot to be drawn? diff --git a/configfiles/EnergyReco/Train_Test/DNNTrackLengthTrainConfig b/configfiles/EnergyReco/Train_Test/DNNTrackLengthTrainConfig new file mode 100644 index 000000000..185227cd2 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/DNNTrackLengthTrainConfig @@ -0,0 +1,18 @@ +# This config file stores variables that may be retrieved by the python script +# Access them by retrieving the corresponding variable from the 'Config' store + +PythonScript DNNTrackLengthTrain_Test + +verbosity 1 + +InitialiseFunction Initialise +ExecuteFunction Finalise +FinaliseFunction Execute + +# DNN model, weights etc +TrackLengthOutputWeightsFile UserTools/DNNTrackLength/stand_alone/weights/weights_bets.hdf5 + +# Training data +TrackLengthTrainingInputBoostStoreFile EnergyReco.bs + +ScalingVarsBoostStoreFile Data_Energy_Reco/ScalingVarsStore.bs diff --git a/configfiles/EnergyReco/Train_Test/DigitBuilderConfig b/configfiles/EnergyReco/Train_Test/DigitBuilderConfig new file mode 100644 index 000000000..1dcc890b6 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/DigitBuilderConfig @@ -0,0 +1,11 @@ +# DigitBuilder config file + +verbosity 0 +ParametricModel 1 +#Reading in MC files +IsMC 1 +DigitChargeThr 20 +# There are three configurations: "PMT_only", "LAPPD_only", "All" +PhotoDetectorConfiguration All +#File must be in /pnfs/ space when loading on Fermilab cluster +LAPPDIDFile configfiles/EnergyReco/Train_Test/LAPPDIDs.txt diff --git a/configfiles/EnergyReco/Train_Test/EventSelectorConfig b/configfiles/EnergyReco/Train_Test/EventSelectorConfig new file mode 100644 index 000000000..ca6032811 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/EventSelectorConfig @@ -0,0 +1,15 @@ +# EventSelector config file + +verbosity 0 +MCPMTVolCut 0 +MCFVCut 1 +MCMRDCut 1 +MCPiKCut 0 +MCIsMuonCut 1 +MRDRecoCut 0 +RecoPMTVolCut 0 +RecoFVCut 0 +NHitCut 1 +PromptTrigOnly 1 +SaveStatusToStore 1 +Triggerword -1 diff --git a/configfiles/EnergyReco/Train_Test/FindMrdTracksConfig b/configfiles/EnergyReco/Train_Test/FindMrdTracksConfig new file mode 100644 index 000000000..7a9d11f7d --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/FindMrdTracksConfig @@ -0,0 +1,12 @@ +# FindMrdTracks Config File +# all variables retrieved with m_variables.Get() must be defined here! + +verbosity 0 +IsData 0 +OutputDirectory . +OutputFile STEC_MRDTracks_cluster40ns +DrawTruthTracks 0 # whether to add MC Truth track info for drawing in MrdPaddlePlot Tool + ## note you need to run that tool to actually view the tracks! +WriteTracksToFile 0 # should the track information be written to a ROOT-file? +SelectTriggerType 0 #should the loaded data be filtered by trigger type? +TriggerType Beam #options: Cosmic, Beam, No Loopback diff --git a/configfiles/EnergyReco/Train_Test/FindTrackLengthInWaterConfig b/configfiles/EnergyReco/Train_Test/FindTrackLengthInWaterConfig new file mode 100644 index 000000000..7744dae8c --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/FindTrackLengthInWaterConfig @@ -0,0 +1,6 @@ +#FindTrackLengthInWater Config File +# all variables retrieved with m_variables.Get() must be defined here! +verbosity 1 +MaxTotalHitsToDNN 1100 +OutputDataFile data_for_trackLength_training.csv +DoTraining 1 diff --git a/configfiles/EnergyReco/Train_Test/HitCleanerConfig b/configfiles/EnergyReco/Train_Test/HitCleanerConfig new file mode 100644 index 000000000..36d7f0137 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/HitCleanerConfig @@ -0,0 +1,20 @@ +# HitCleaner config file + +verbosity 5 +Config 2 #config type: 1 = pulse height cut, 2 = +neighbour cut, 3 = +cluster cut +PmtMinPulseHeight 20 #minimum pulse height +PmtNeighbourRadius 60 #digit neighbouring distance [cm] +PmtMinNeighbourDigits 2 #minimum neighbour digits +PmtClusterRadius 60 #digit clustering distance [cm] +PmtTimeWindowN 10 #neighbouring time window [ns] +PmtTimeWindowC 10 #clustering time window [ns] +PmtMinHitsPerCluster 4 #number of hits per cluster +LappdMinPulseHeight 0 #minimum pulse height +LappdNeighbourRadius 25 #digit neighbouring distance [cm] +LappdMinNeighbourDigits 20 #minimum neighbour digits +LappdClusterRadius 25 #digit clustering distance [cm] +LappdTimeWindowN 1 #neighbouring time window [ns] +LappdTimeWindowC 1 #clustering time window [ns] +LappdMinHitsPerCluster 20 #number of digits per cluster +#MinClusterDigits 50 #minimum clustered digits (LAPPD+PMT) +MinClusterDigits 10 #minimum clustered digits (PMT-only) diff --git a/configfiles/EnergyReco/Train_Test/LAPPDIDs.txt b/configfiles/EnergyReco/Train_Test/LAPPDIDs.txt new file mode 100644 index 000000000..776b28912 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/LAPPDIDs.txt @@ -0,0 +1,5 @@ +11 +13 +14 +15 +17 diff --git a/configfiles/EnergyReco/Train_Test/LoadWCSimConfig b/configfiles/EnergyReco/Train_Test/LoadWCSimConfig new file mode 100644 index 000000000..001d2e929 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/LoadWCSimConfig @@ -0,0 +1,15 @@ +#LoadWCSim Config File +# all variables retrieved with m_variables.Get() must be defined here! +verbose 0 + +InputFile /pnfs/annie/persistent/simulations/wcsim/G1810a0211a/standard/tank/pmt/wcsim_0* #James's files + +TriggerType Beam +SplitSubTriggers 1 + +WCSimVersion 10 ## should reflect the WCSim version of the files being loaded +HistoricTriggeroffset 0 ## time offset of digits relative to the trigger +#UseDigitSmearedTime 1 ## whether to use smeared digit time (T), or true time of first photon (F) +LappdNumStrips 60 ## num channels to construct from each LAPPD +LappdStripLength 100 ## relative x position of each LAPPD strip, for dual-sided readout [mm] +LappdStripSeparation 10 ## stripline separation, for calculating relative y position of each LAPPD strip [mm] diff --git a/configfiles/EnergyReco/Train_Test/LoadWCSimLAPPDConfig b/configfiles/EnergyReco/Train_Test/LoadWCSimLAPPDConfig new file mode 100644 index 000000000..2b82ff922 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/LoadWCSimLAPPDConfig @@ -0,0 +1,10 @@ +#LoadWCSimLAPPD Config File +# all variables retrieved with m_variables.Get() must be defined here! +verbose 0 + +InputFile /pnfs/annie/persistent/simulations/wcsim/G1810a0211a/standard/tank/lappd/wcsim_lappd_0* #James's files + +WCSimVersion 10 ## should reflect the WCSim version of the files being loaded +InnerStructureRadius 1.3545 ## octagonal inner structure radius in m (from drawings 106.64") +HistoricTriggeroffset 0 +DrawDebugGraphs 0 ## whether to draw TPolyMarker3D's of hits diff --git a/configfiles/EnergyReco/Train_Test/MCParticlePropertiesConfig b/configfiles/EnergyReco/Train_Test/MCParticlePropertiesConfig new file mode 100644 index 000000000..752200268 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/MCParticlePropertiesConfig @@ -0,0 +1 @@ +verbosity 0 diff --git a/configfiles/EnergyReco/Train_Test/MCRecoEventLoaderConfig b/configfiles/EnergyReco/Train_Test/MCRecoEventLoaderConfig new file mode 100644 index 000000000..193bfd196 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/MCRecoEventLoaderConfig @@ -0,0 +1,12 @@ +# MCRecoEventLoader config file + +verbosity 0 +#Get Pion/Kaon counts from MC Truth +GetPionKaonInfo 1 +#Particle ID you want to load from parent particles; 13 for muon +ParticleID 13 +#coordinate shifts needed to put particles in tank origin coordinates +xshift 0.0 +yshift 14.46469 +zshift -168.1 + diff --git a/configfiles/EnergyReco/Train_Test/TimeClusteringConfig b/configfiles/EnergyReco/Train_Test/TimeClusteringConfig new file mode 100644 index 000000000..e3061f75f --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/TimeClusteringConfig @@ -0,0 +1,12 @@ +#TimeClustering config file + +verbosity 7 +MinDigitsForTrack 4 +MaxMrdSubEventDuration 40 +MinSubeventTimeSep 40 +MakeMrdDigitTimePlot 0 +LaunchTApplication 0 +IsData 0 +#OutputROOTFile TimeClustering_MRDTest28_cluster40ns +OutputROOTFile STEC_TimeClusteringOut +MapChankey_WCSimID ./configfiles/SimpleTankEnergyCalibrator/MRD_Chankey_WCSimID.dat diff --git a/configfiles/EnergyReco/Train_Test/ToolChainConfig b/configfiles/EnergyReco/Train_Test/ToolChainConfig new file mode 100644 index 000000000..59c288a77 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/ToolChainConfig @@ -0,0 +1,23 @@ +#ToolChain dynamic setup file + +##### Runtime Paramiters ##### +verbose 1 ## Verbosity level of ToolChain +error_level 0 # 0= do not exit, 1= exit on unhandeled errors only, 2= exit on unhandeled errors and handeled errors +attempt_recover 1 ## 1= will attempt to finalise if an execute fails + +###### Logging ##### +log_mode Interactive # Interactive=cout , Remote= remote logging system "serservice_name Remote_Logging" , Local = local file log; +log_local_path ./log +log_service LogStore + +###### Service discovery ##### Ignore these settings for local analysis +service_publish_sec -1 +service_kick_sec -1 + +##### Tools To Add ##### +Tools_File configfiles/EnergyReco/Train_Test/ToolsConfig ## list of tools to run and their config files + +##### Run Type ##### +Inline -1 ## number of Execute steps in program, -1 infinite loop that is ended by user +Interactive 0 ## set to 1 if you want to run the code interactively + diff --git a/configfiles/EnergyReco/Train_Test/ToolsConfig b/configfiles/EnergyReco/Train_Test/ToolsConfig new file mode 100644 index 000000000..8c68239ac --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/ToolsConfig @@ -0,0 +1,18 @@ +# train machine learning algorithm +myLoadWCSim LoadWCSim configfiles/EnergyReco/Train_Test/LoadWCSimConfig +myLoadWCSimLAPPD LoadWCSimLAPPD configfiles/EnergyReco/Train_Test/LoadWCSimLAPPDConfig +myMCParticleProperties MCParticleProperties configfiles/EnergyReco/Train_Test/MCParticlePropertiesConfig +MCRecoEventLoader MCRecoEventLoader configfiles/EnergyReco/Train_Test/MCRecoEventLoaderConfig +DigitBuilder DigitBuilder configfiles/EnergyReco/Train_Test/DigitBuilderConfig +HitCleaner HitCleaner configfiles/EnergyReco/Train_Test/HitCleanerConfig +ClusterFinder ClusterFinder configfiles/EnergyReco/Train_Test/ClusterFinderConfig +TimeClustering TimeClustering configfiles/EnergyReco/Train_Test/TimeClusteringConfig +EventSelector EventSelector configfiles/EnergyReco/Train_Test/EventSelectorConfig +FindMrdTracks FindMrdTracks configfiles/EnergyReco/Train_Test/FindMrdTracksConfig +VtxSeedGenerator VtxSeedGenerator configfiles/EnergyReco/Train_Test/VtxSeedGeneratorConfig +VtxSeedFineGrid VtxSeedFineGrid configfiles/EnergyReco/Train_Test/VtxSeedFineGridConfig +VtxExtendedVertexFinder VtxExtendedVertexFinder configfiles/EnergyReco/Train_Test/VtxExtendedVertexFinderConfig + +FindTrackLengthInWater FindTrackLengthInWater configfiles/EnergyReco/Train_Test/FindTrackLengthInWaterConfig +DNNTrackLengthTrainer PythonScript configfiles/EnergyReco/Train_Test/DNNTrackLengthTrainConfig +BDTMuonEnergyTrainer PythonScript configfiles/EnergyReco/Train_Test/BDTMuonEnergyTrainConfig diff --git a/configfiles/EnergyReco/Train_Test/VtxExtendedVertexFinderConfig b/configfiles/EnergyReco/Train_Test/VtxExtendedVertexFinderConfig new file mode 100644 index 000000000..59f74e5eb --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/VtxExtendedVertexFinderConfig @@ -0,0 +1,9 @@ +# VtxPointPositionFinder config file + +verbosity 5 + +# Only one of the options below should be set to 1. All the others should be set to 0 +UseTrueVertexAsSeed 0 +UsePointVertexAsSeed 0 +FitAllOnSeedGrid 1 +UseMeanTimeAsSeed 0 diff --git a/configfiles/EnergyReco/Train_Test/VtxSeedFineGridConfig b/configfiles/EnergyReco/Train_Test/VtxSeedFineGridConfig new file mode 100644 index 000000000..674e643a0 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/VtxSeedFineGridConfig @@ -0,0 +1,7 @@ +verbosity 5 +useDirectionGrid 0 +useSimpleDirection 1 +useTrueDir 0 +useMRDTrack 0 +usePastResolution 0 +multiGrid 1 diff --git a/configfiles/EnergyReco/Train_Test/VtxSeedGeneratorConfig b/configfiles/EnergyReco/Train_Test/VtxSeedGeneratorConfig new file mode 100644 index 000000000..014f6e4e7 --- /dev/null +++ b/configfiles/EnergyReco/Train_Test/VtxSeedGeneratorConfig @@ -0,0 +1,6 @@ +# VtxSeedGenerator config file + +verbosity 3 +NumberOfSeeds 300 +UseSeedGrid 1 +SeedType 2