-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathtestLHA_01.cpp
90 lines (71 loc) · 2.6 KB
/
testLHA_01.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
/*
c++ -o testLHA_01 `lhapdf-config --cppflags --ldflags` testLHA_01.cpp
*/
// Simple test program to test functionality of
// the LHAPDF C++ wrapper.
// Use this as a template for your program.
//
// Original author: Stefan Gieseke 2005
// Adapted for LHAPDF v5+ by Mike Whalley.
// Further updates for >= v5.4 by Andy Buckley.
#include "LHAPDF/LHAPDF.h"
#include <iterator>
#include <iostream>
#include <cstdlib>
using namespace std;
// NB. You might want to also have
using namespace LHAPDF;
// for convenience.
int main() {
const int SUBSET = 0;
const string NAME = "cteq6ll";
LHAPDF::initPDFSet(NAME, LHAPDF::LHPDF, SUBSET);
// LHAPDF::initPDFSet(NAME, LHAPDF::LHGRID, SUBSET);
const double Q = 10.0, mz = 91.2;
cout << "alphas(mz) = " << LHAPDF::alphasPDF(mz) << endl;
cout << "qcdlam4 = " << LHAPDF::getLam4(SUBSET) << endl;
cout << "qcdlam5 = " << LHAPDF::getLam5(SUBSET) << endl;
cout << "orderPDF = " << LHAPDF::getOrderPDF() << endl;
cout << "xmin = " << LHAPDF::getXmin(SUBSET) << endl;
cout << "xmax = " << LHAPDF::getXmax(SUBSET) << endl;
cout << "q2min = " << LHAPDF::getQ2min(SUBSET) << endl;
cout << "q2max = " << LHAPDF::getQ2max(SUBSET) << endl;
cout << "orderalfas = " << LHAPDF::getOrderAlphaS() << endl;
cout << "num flav = " << LHAPDF::getNf() << endl;
cout << "name = " << NAME << endl;
cout << "number = " << LHAPDF::numberPDF() << endl;
cout << endl;
// LHAPDF::extrapolate();
const int NUMBER = LHAPDF::numberPDF();
for (int n = 0; n < NUMBER + 1; ++n) {
cout << "Set number: " << n << endl;
LHAPDF::initPDF(n);
for (int ix = 1; ix < 11; ++ix) {
const double x = (ix - 0.5) / 10.0;
cout << "x=" << x << ", Q=" << Q << ", f=0: " << LHAPDF::xfx(x, Q, 0) << endl;
}
cout << endl;
}
for (int n = 0; n < NUMBER + 1; ++n) {
cout << "Set number: " << n << endl;
LHAPDF::initPDF(n);
for (int ix = 1; ix < 11; ++ix) {
const double x = (ix - 0.5) / 10.0;
cout << "x=" << x << ", Q=" << Q << ": ";
vector<double> result = LHAPDF::xfx(x, Q);
std::copy(result.begin(), result.end(), ostream_iterator<double>(cout,"\t"));
cout << endl;
}
cout << endl;
}
cout << string().insert(0, 40, '-') << endl << endl;
cout << "Checking LHAPDF with package " << endl;
cout << NAME << " set number " << SUBSET << "/" << LHAPDF::numberPDF() << endl << endl;
cout << "LHAPDF::getDescription() gives:" << endl;
LHAPDF::getDescription();
return EXIT_SUCCESS;
}
#include "FortranWrappers.h"
#ifdef FC_DUMMY_MAIN
int FC_DUMMY_MAIN() { return 1; }
#endif