6 #ifndef HEPMC3_ATTRIBUTE_H 7 #define HEPMC3_ATTRIBUTE_H 29 #include "HepMC3/GenParticle_fwd.h" 30 #include "HepMC3/GenVertex_fwd.h" 96 virtual bool to_string(
string &att)
const = 0;
120 return std::const_pointer_cast<GenParticle>(
m_particle);
130 return std::const_pointer_cast<GenVertex>(
m_vertex);
169 m_val = atoi( att.c_str() );
175 att = std::to_string(
m_val);
210 m_val = atol( att.c_str() );
216 att = std::to_string(
m_val);
253 m_val = atof( att.c_str() );
259 std::ostringstream oss;
260 oss << std::setprecision(std::numeric_limits<double>::digits10)
298 m_val = float(atof( att.c_str() ));
304 std::ostringstream oss;
305 oss << std::setprecision(std::numeric_limits<float>::digits10)
401 att = std::to_string(
m_val);
436 m_val = atoll( att.c_str() );
442 att = std::to_string(
m_val);
479 m_val = strtold( att.c_str(),NULL);
485 std::ostringstream oss;
486 oss << std::setprecision(std::numeric_limits<long double>::digits10)
526 m_val = strtoul(att.c_str(), NULL, 0);
532 att = std::to_string(
m_val);
569 m_val = strtoul(att.c_str(), NULL, 0);
575 att = std::to_string(
m_val);
611 m_val = strtoull(att.c_str(), NULL, 0);
617 att = std::to_string(
m_val);
651 if (att.size()!=1)
return false;
652 if(att==std::string(
"1")) {
m_val =
true;
return true;}
653 if(att==std::string(
"0")) {
m_val =
false;
return true;}
659 att = std::to_string(
m_val);
696 std::stringstream datastream(att);
697 while (datastream >> datafoo)
m_val.push_back(datafoo);
704 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
741 std::stringstream datastream(att);
742 while (datastream >> datafoo)
m_val.push_back(datafoo);
749 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
787 std::stringstream datastream(att);
788 while (datastream >> datafoo)
m_val.push_back(datafoo);
795 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
800 std::vector<long double>
value()
const {
834 std::stringstream datastream(att);
835 while (datastream >> datafoo)
m_val.push_back(datafoo);
842 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
847 std::vector<long long>
value()
const {
877 unsigned int datafoo;
879 std::stringstream datastream(att);
880 while (datastream >> datafoo)
m_val.push_back(datafoo);
887 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
892 std::vector<unsigned int>
value()
const {
922 unsigned long datafoo;
924 std::stringstream datastream(att);
925 while (datastream >> datafoo)
m_val.push_back(datafoo);
932 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
937 std::vector<unsigned long>
value()
const {
968 unsigned long long datafoo;
970 std::stringstream datastream(att);
971 while (datastream >> datafoo)
m_val.push_back(datafoo);
978 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
983 std::vector<unsigned long long>
value()
const {
988 void set_value(
const std::vector<unsigned long long>& i) {
993 std::vector<unsigned long long>
m_val;
1015 std::stringstream datastream(att);
1016 while (datastream >> datafoo)
m_val.push_back(datafoo);
1023 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
1060 std::stringstream datastream(att);
1061 while (datastream >> datafoo)
m_val.push_back(datafoo);
1068 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
1105 std::stringstream datastream(att);
1106 while (datastream >> datafoo)
m_val.push_back(datafoo);
1113 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=std::to_string(a);}
1149 std::string datafoo;
1151 size_t posb=att.find_first_not_of(
' ');
1153 while (posb!=std::string::npos) { pose=att.find_first_not_of(
' ',posb+1);
m_val.push_back(att.substr(posb,pose)); posb=att.find_first_not_of(
' ',pose+1);}
1160 for (
auto a:
m_val) {
if (att.length()) att+=
" "; att+=a;}
VectorULongLongAttribute(std::vector< unsigned long long > val)
Constructor initializing attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
LongAttribute(long val)
Constructor initializing attribute value.
std::vector< long long > value() const
get the value associated to this Attribute.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
Forward declaration of GenParticle.
void set_value(const double &d)
set the value associated to this Attribute.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
VectorLongIntAttribute(std::vector< long int > val)
Constructor initializing attribute value.
VectorIntAttribute(std::vector< int > val)
Constructor initializing attribute value.
Attribute that holds an unsigned long long.
string m_string
Raw (unparsed) string.
unsigned int value() const
get the value associated to this Attribute.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
virtual bool to_string(string &att) const =0
Fill string from class content.
void set_value(const std::vector< char > &i)
set the value associated to this Attribute.
LongAttribute()
Default constructor.
VectorFloatAttribute()
Default constructor.
UIntAttribute()
Default constructor.
ULongLongAttribute(unsigned long long val)
Constructor initializing attribute value.
std::vector< double > m_val
Attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const string &s)
set the value associated to this Attribute.
VectorLongDoubleAttribute(std::vector< long double > val)
Constructor initializing attribute value.
FloatAttribute(float val)
Constructor initializing attribute value.
void set_value(const bool &i)
set the value associated to this Attribute.
void set_value(const std::vector< long int > &i)
set the value associated to this Attribute.
string value() const
get the value associated to this Attribute.
BoolAttribute()
Default constructor.
Attribute that holds a vector of unsigned long longegers of type unsigned long long.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
Attribute that holds an unsigned int.
Attribute that holds a vector of charegers of type char.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const std::vector< double > &i)
set the value associated to this Attribute.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
std::vector< double > value() const
get the value associated to this Attribute.
VectorUIntAttribute(std::vector< unsigned int > val)
Constructor initializing attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
GenParticlePtr particle()
virtual bool from_string(const string &att)=0
Fill class content from string.
Attribute that holds a real number as a float.
LongLongAttribute(long long val)
Constructor initializing attribute value.
VectorLongIntAttribute()
Default constructor.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
LongDoubleAttribute(long double val)
Constructor initializing attribute value.
ULongAttribute()
Default constructor.
unsigned int m_val
Attribute value.
long m_val
Attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const std::vector< unsigned int > &i)
set the value associated to this Attribute.
Stores run-related information.
long value() const
get the value associated to this Attribute.
void set_value(const char &i)
set the value associated to this Attribute.
VectorCharAttribute()
Default constructor.
VectorLongLongAttribute(std::vector< long long > val)
Constructor initializing attribute value.
ConstGenVertexPtr vertex() const
Attribute that holds a vector of integers of type int.
bool m_val
Attribute value.
virtual bool init()
Optionally initialize the attribute after from_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const int &i)
set the value associated to this Attribute.
Attribute that holds a string.
void set_value(const unsigned int &i)
set the value associated to this Attribute.
LongLongAttribute()
Default constructor.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
VectorDoubleAttribute()
Default constructor.
void set_value(const std::vector< string > &i)
set the value associated to this Attribute.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_unparsed_string(const string &st)
Set unparsed string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
int value() const
get the value associated to this Attribute.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const unsigned long &i)
set the value associated to this Attribute.
GenParticlePtr m_particle
controlling GenEvent object.
int m_val
Attribute value.
VectorDoubleAttribute(std::vector< double > val)
Constructor initializing attribute value.
float m_val
Attribute value.
VectorIntAttribute()
Default constructor.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
long long m_val
Attribute value.
Attribute that holds a vector of unsigned integers of type unsigned int.
ConstGenParticlePtr particle() const
Attribute that holds an Chareger implemented as an int.
Attribute that holds a vector of unsigned longegers of type unsigned long.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
Attribute that holds an unsigned long.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
Attribute that holds a vector of long doubleegers of type long double.
std::vector< unsigned long > m_val
Attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
double m_val
Attribute value.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
VectorULongAttribute()
Default constructor.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
void set_value(const std::vector< int > &i)
set the value associated to this Attribute.
Stores event-related information.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
bool value() const
get the value associated to this Attribute.
DoubleAttribute()
Default constructor.
Attribute that holds a real number as a double.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
char m_val
Attribute value.
long double value() const
get the value associated to this Attribute.
void set_value(const std::vector< unsigned long long > &i)
set the value associated to this Attribute.
unsigned long long m_val
Attribute value.
const string & unparsed_string() const
Get unparsed string.
void set_value(const std::vector< long long > &i)
set the value associated to this Attribute.
VectorStringAttribute(std::vector< string > val)
Constructor initializing attribute value.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
std::vector< long double > value() const
get the value associated to this Attribute.
UIntAttribute(unsigned int val)
Constructor initializing attribute value.
CharAttribute(char val)
Constructor initializing attribute value.
const GenEvent * event() const
StringAttribute(const string &st)
String-based constructor.
ULongLongAttribute()
Default constructor.
void set_value(const float &f)
set the value associated to this Attribute.
std::vector< unsigned int > m_val
Attribute value.
void set_value(const unsigned long long &i)
set the value associated to this Attribute.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
void set_value(const std::vector< long double > &i)
set the value associated to this Attribute.
std::vector< float > m_val
Attribute value.
long double m_val
Attribute value.
Attribute that holds a real number as a double.
Attribute that holds a vector of long longegers of type long long.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
unsigned long long value() const
get the value associated to this Attribute.
virtual bool init(const GenRunInfo &)
Optionally initialize the attribute after from_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
void set_value(const long &l)
set the value associated to this Attribute.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
char value() const
get the value associated to this Attribute.
std::vector< char > value() const
get the value associated to this Attribute.
std::vector< char > m_val
Attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
VectorStringAttribute()
Default constructor.
std::vector< unsigned long long > value() const
get the value associated to this Attribute.
VectorUIntAttribute()
Default constructor.
VectorLongLongAttribute()
Default constructor.
void set_value(const std::vector< unsigned long > &i)
set the value associated to this Attribute.
std::vector< float > value() const
get the value associated to this Attribute.
long long value() const
get the value associated to this Attribute.
IntAttribute(int val)
Constructor initializing attribute value.
std::vector< long int > m_val
Attribute value.
GenVertexPtr m_vertex
Vertex to which assigned.
void set_is_parsed(bool flag)
Set is_parsed flag.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
VectorLongDoubleAttribute()
Default constructor.
void set_value(const std::vector< float > &i)
set the value associated to this Attribute.
unsigned long value() const
get the value associated to this Attribute.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
IntAttribute()
Default constructor.
BoolAttribute(bool val)
Constructor initializing attribute value.
std::vector< string > value() const
get the value associated to this Attribute.
std::vector< int > m_val
Attribute value.
virtual ~Attribute()
Virtual destructor.
float value() const
get the value associated to this Attribute.
FloatAttribute()
Default constructor.
Attribute that holds an Integer implemented as an int.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
std::vector< unsigned long long > m_val
Attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
std::vector< unsigned long > value() const
get the value associated to this Attribute.
std::vector< long int > value() const
get the value associated to this Attribute.
ULongAttribute(unsigned long val)
Constructor initializing attribute value.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
bool to_string(string &att) const override
Implementation of Attribute::to_string.
bool is_parsed() const
Check if this attribute is parsed.
double value() const
get the value associated to this Attribute.
VectorULongLongAttribute()
Default constructor.
std::vector< long long > m_val
Attribute value.
VectorFloatAttribute(std::vector< float > val)
Constructor initializing attribute value.
DoubleAttribute(double val)
Constructor initializing attribute value.
Attribute that holds an Integer implemented as an int.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
Attribute that holds a vector of floategers of type float.
std::vector< int > value() const
get the value associated to this Attribute.
std::vector< unsigned int > value() const
get the value associated to this Attribute.
bool m_is_parsed
Is this attribute parsed?
void set_value(const long double &d)
set the value associated to this Attribute.
VectorULongAttribute(std::vector< unsigned long > val)
Constructor initializing attribute value.
void set_value(const long long &l)
set the value associated to this Attribute.
std::vector< string > m_val
Attribute value.
Attribute(const string &st)
Protected constructor that allows to set string.
Attribute that holds an Integer implemented as an int.
Attribute that holds an Booleger implemented as an int.
LongDoubleAttribute()
Default constructor.
CharAttribute()
Default constructor.
std::vector< long double > m_val
Attribute value.
VectorCharAttribute(std::vector< char > val)
Constructor initializing attribute value.
bool from_string(const string &att) override
Implementation of Attribute::from_string.
StringAttribute()
Default constructor - empty string.
Attribute()
Default constructor.
unsigned long m_val
Attribute value.