Page MenuHomeHEPForge

No OneTemporary

diff --git a/FixedOrderGen/include/ProgressBar.hh b/FixedOrderGen/include/ProgressBar.hh
new file mode 100644
index 0000000..5904bf3
--- /dev/null
+++ b/FixedOrderGen/include/ProgressBar.hh
@@ -0,0 +1,64 @@
+#pragma once
+
+#include <ostream>
+#include <cassert>
+#include <stdexcept>
+
+namespace HEJFOG {
+
+ template<typename T>
+ class ProgressBar {
+ public:
+ ProgressBar(std::ostream & out, T max) :
+ out_{out}, max_{max}
+ {
+ if(max <= 0) {
+ throw std::invalid_argument{
+ "Maximum in progress bar has to be positive"
+ };
+ }
+ print_bar();
+ }
+
+ ProgressBar & increment(T count) {
+ counter_ += count;
+ update_progress();
+ return *this;
+ }
+
+ ProgressBar & operator++() {
+ ++counter_;
+ update_progress();
+ return *this;
+ }
+
+ private:
+ void update_progress() {
+ counter_ = std::min(counter_, max_);
+ const int ndots = (100*counter_)/max_;
+ const int new_dots = ndots - ndots_;
+ if(new_dots > 0) {
+ for(int dot = 0; dot < new_dots; ++dot) out_ << '.';
+ out_.flush();
+ ndots_ = ndots;
+ }
+ }
+
+ void print_bar() const {
+ out_ << "0% ";
+ for(int i = 10; i <= 100; i+= 10){
+ out_ << " " + std::to_string(i) + "%";
+ }
+ out_ << "\n|";
+ for(int i = 10; i <= 100; i+= 10){
+ out_ << "---------|";
+ }
+ out_ << '\n';
+ }
+
+ std::ostream & out_;
+ T counter_ = 0;
+ T ndots_ = 0;
+ T max_;
+ };
+}
diff --git a/FixedOrderGen/src/main.cc b/FixedOrderGen/src/main.cc
index f0c5563..d2598c2 100644
--- a/FixedOrderGen/src/main.cc
+++ b/FixedOrderGen/src/main.cc
@@ -1,238 +1,214 @@
/**
* Name: main.cc
* Authors: Jeppe R. Andersen
*/
#include <fstream>
#include <algorithm>
#include <memory>
#include <chrono>
#include <iostream>
#include <map>
#include "yaml-cpp/yaml.h"
#include "config.hh"
#include "LHEF/LHEF.h"
#include "RHEJ/CombinedEventWriter.hh"
#include "RHEJ/get_analysis.hh"
#include "RHEJ/utility.hh"
//#include "RHEJ/EventReweighter.hh"
#include "RHEJ/stream.hh"
#include "RHEJ/LesHouchesWriter.hh"
#include "EventGenerator.hh"
#include "PhaseSpacePoint.hh"
#include "Ranlux64Engine.hh"
+#include "ProgressBar.hh"
namespace{
constexpr auto banner =
" __ ___ __ ______ __ __ \n"
" / / / (_)___ _/ /_ / ____/___ ___ _________ ___ __ / /__ / /______ \n"
" / /_/ / / __ `/ __ \\ / __/ / __ \\/ _ \\/ ___/ __ `/ / / / __ / / _ \\/ __/ ___/ \n"
" / __ / / /_/ / / / / / /___/ / / / __/ / / /_/ / /_/ / / /_/ / __/ /_(__ ) \n"
" /_/ /_/_/\\__, /_/ /_/ /_____/_/ /_/\\___/_/ \\__, /\\__, / \\____/\\___/\\__/____/ \n"
" ____///__/ __ ____ ///__//____/ ______ __ \n"
" / ____(_) _____ ____/ / / __ \\_________/ /__ _____ / ____/__ ____ ___ _________ _/ /_____ _____\n"
" / /_ / / |/_/ _ \\/ __ / / / / / ___/ __ / _ \\/ ___/ / / __/ _ \\/ __ \\/ _ \\/ ___/ __ `/ __/ __ \\/ ___/\n"
" / __/ / /> </ __/ /_/ / / /_/ / / / /_/ / __/ / / /_/ / __/ / / / __/ / / /_/ / /_/ /_/ / / \n"
" /_/ /_/_/|_|\\___/\\__,_/ \\____/_/ \\__,_/\\___/_/ \\____/\\___/_/ /_/\\___/_/ \\__,_/\\__/\\____/_/ \n"
;
constexpr double invGeV2_to_pb = 389379292.;
}
HEJFOG::Config load_config(char const * filename){
try{
return HEJFOG::load_config(filename);
}
catch(std::exception const & exc){
std::cerr << "Error: " << exc.what() << '\n';
std::exit(EXIT_FAILURE);
}
}
std::unique_ptr<RHEJ::Analysis> get_analysis(
YAML::Node const & parameters
){
try{
return RHEJ::get_analysis(parameters);
}
catch(std::exception const & exc){
std::cerr << "Failed to load analysis: " << exc.what() << '\n';
std::exit(EXIT_FAILURE);
}
}
-std::string progress_bar(){
- std::string result = "0% ";
- for(int i = 10; i <= 100; i+= 10){
- result += " " + std::to_string(i) + "%";
- }
- result += "\n|";
- for(int i = 10; i <= 100; i+= 10){
- result += "---------|";
- }
- return result + '\n';
-}
-
int main(int argn, char** argv) {
if (argn < 2) {
std::cerr << "\n# Usage:\n.FOgen config_file\n";
return EXIT_FAILURE;
}
std::cout << banner;
fastjet::ClusterSequence::print_banner();
using clock = std::chrono::system_clock;
const auto start_time = clock::now();
// read configuration
auto config = load_config(argv[1]);
std::unique_ptr<RHEJ::Analysis> analysis = get_analysis(
config.analysis_parameters
);
assert(analysis != nullptr);
auto ran = HEJFOG::make_Ranlux64Engine();
if(config.RanLux_init) ran.restoreStatus(config.RanLux_init->c_str());
HEJFOG::EventGenerator generator{
config.process,
config.beam,
config.scale_gen,
config.jets,
config.pdf_id,
config.unordered_fraction,
config.Higgs_properties,
config.Higgs_coupling,
ran
};
//TODO: fix Les Houches init block (HEPRUP)
LHEF::HEPRUP lhefheprup;
lhefheprup.IDBMUP=std::pair<long,long>(config.beam.particles[0], config.beam.particles[1]);
lhefheprup.EBMUP=std::make_pair(config.beam.energy, config.beam.energy);
lhefheprup.PDFGUP=std::make_pair(0,0);
lhefheprup.PDFSUP=std::make_pair(config.pdf_id,config.pdf_id);
lhefheprup.NPRUP=1;
lhefheprup.XSECUP=std::vector<double>(1.);
lhefheprup.XERRUP=std::vector<double>(1.);
lhefheprup.LPRUP=std::vector<int>{1};
RHEJ::CombinedEventWriter writer{config.output, lhefheprup};
std::map<HEJFOG::Status, int> status_counter;
- int iprint = 0;
- int trial = 0;
const int test_trials = config.trials;
double FKL_xs = 0., FKL_xs_err = 0.;
double uno_xs = 0., uno_xs_err = 0.;
std::vector<RHEJ::Event> events;
// warm-up phase: check how efficient we are
std::cout << "Warm-up ...\n";
- std::cout << '\n' << progress_bar();
+ HEJFOG::ProgressBar<int> warmup_progress{std::cout, test_trials};
const auto warmup_start = clock::now();
- for(; trial < test_trials; ++trial){
- if (trial==iprint) {
- std::cout << ".";
- std::cout.flush();
- iprint += test_trials/100;
- }
+ for(int trial = 0; trial < test_trials; ++trial){
+ ++warmup_progress;
auto ev = generator.gen_event();
++status_counter[generator.status()];
if(generator.status() == HEJFOG::good && analysis->pass_cuts(ev, ev)) {
events.emplace_back(std::move(ev));
}
}
std::cout << std::endl;
const double efficiency = static_cast<double>(events.size())/test_trials;
+ assert(0. <= efficiency && efficiency <= 1.);
std::cout << "Efficiency: " << efficiency << '\n';
const int total_trials = test_trials/efficiency;
for(auto & ev: events) {
ev.central().weight *= invGeV2_to_pb/total_trials;
for(auto & var: ev.variations()){
var.weight *= invGeV2_to_pb/total_trials;
}
analysis->fill(ev, ev);
writer.write(ev);
if(ev.type() == RHEJ::event_type::FKL){
FKL_xs += ev.central().weight;
FKL_xs_err += ev.central().weight*ev.central().weight;
}
else {
uno_xs += ev.central().weight;
uno_xs_err += ev.central().weight*ev.central().weight;
}
}
const auto warmup_end = clock::now();
const std::chrono::duration<double> warmup_time = warmup_end - warmup_start;
std::cout
- << "Generating " << (total_trials - trial) << " additional configurations\n"
- "Expected remaining time: "
- << warmup_time.count()/efficiency << " seconds.\n";
- std::cout << '\n' << progress_bar();
- for(int dot = 0; dot < (100.*trial)/total_trials - 1; ++dot) {
- std::cout << ".";
- std::cout.flush();
- }
- iprint = trial;
- for(; trial < total_trials; ++trial){
- if (trial==iprint) {
- iprint += total_trials/100;
- std::cout << ".";
- std::cout.flush();
- }
+ << "Generating " << (total_trials - test_trials) << " additional configurations\n"
+ "Estimated remaining time: "
+ << warmup_time.count()/efficiency << " seconds.\n\n";
+ HEJFOG::ProgressBar<int> progress{std::cout, total_trials};
+ progress.increment(test_trials);
+ for(int trial = test_trials - 1; trial < total_trials; ++trial){
+ ++progress;
auto ev = generator.gen_event();
++status_counter[generator.status()];
if(generator.status() == HEJFOG::good && analysis->pass_cuts(ev, ev)) {
ev.central().weight *= invGeV2_to_pb/total_trials;
for(auto & var: ev.variations()){
var.weight *= invGeV2_to_pb/total_trials;
}
analysis->fill(ev, ev);
writer.write(ev);
if(ev.type() == RHEJ::event_type::FKL){
FKL_xs += ev.central().weight;
FKL_xs_err += ev.central().weight*ev.central().weight;
}
else {
uno_xs += ev.central().weight;
uno_xs_err += ev.central().weight*ev.central().weight;
}
}
}
std::cout << std::endl;
const std::chrono::duration<double> run_time = (clock::now() - start_time);
std::cout << "\nTask Runtime: " << run_time.count() << " seconds.\n";
std::cout.precision(10);
std::cout.width(12);
std::cout.setf(std::ios::fixed);
std::cout
<< "\nCross section: " << (FKL_xs + uno_xs)
<< " +- " << std::sqrt(FKL_xs_err + uno_xs_err) << " (pb)"
"\n FKL: " << FKL_xs << " +- " << std::sqrt(FKL_xs_err) << " (pb)"
"\n unordered: " << uno_xs << " +- " << std::sqrt(uno_xs_err) << " (pb)"
"\n";
std::cout << '\n';
for(auto && entry: status_counter){
const double fraction = static_cast<double>(entry.second)/total_trials;
const int percent = std::round(100*fraction);
std::cout << "status "
<< std::left << std::setw(16) << (to_string(entry.first) + ":")
<< " [";
for(int i = 0; i < percent/2; ++i) std::cout << '#';
for(int i = percent/2; i < 50; ++i) std::cout << ' ';
std::cout << "] " << percent << "%\n";
}
}

File Metadata

Mime Type
text/x-diff
Expires
Mon, Jan 20, 9:10 PM (1 d, 1 h)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
4218594
Default Alt Text
(10 KB)

Event Timeline