/usr/include/fastjet/FunctionOfPseudoJet.hh is in libfastjet-dev 3.0.6+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 | #ifndef __FASTJET_FUNCTION_OF_PSEUDOJET_HH__
#define __FASTJET_FUNCTION_OF_PSEUDOJET_HH__
//STARTHEADER
// $Id: FunctionOfPseudoJet.hh 2577 2011-09-13 15:11:38Z salam $
//
// Copyright (c) 2005-2011, Matteo Cacciari, Gavin P. Salam and Gregory Soyez
//
//----------------------------------------------------------------------
// This file is part of FastJet.
//
// FastJet is free software; you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation; either version 2 of the License, or
// (at your option) any later version.
//
// The algorithms that underlie FastJet have required considerable
// development and are described in hep-ph/0512210. If you use
// FastJet as part of work towards a scientific publication, please
// include a citation to the FastJet paper.
//
// FastJet is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with FastJet. If not, see <http://www.gnu.org/licenses/>.
//----------------------------------------------------------------------
//ENDHEADER
#include <fastjet/PseudoJet.hh>
#include <fastjet/Selector.hh>
FASTJET_BEGIN_NAMESPACE
/// \class FunctionOfPseudoJet
/// base class providing interface for a generic function of a PseudoJet
///
/// This class serves as a base class to provide a standard interface
/// for a function that returns an object of a given (templated) type
/// that depends on a PseudoJet argument. The rationale for using a
/// class (rather than a pointer to a function) is that a class can be
/// constructed with (and store) additional arguments.
template<typename TOut>
class FunctionOfPseudoJet{
public:
/// default ctor
FunctionOfPseudoJet(){}
/// ctor that creates a constant function
FunctionOfPseudoJet(const TOut &constant_value);
/// default dtor (virtual to allow safe polymorphism)
virtual ~FunctionOfPseudoJet(){}
/// returns a description of the function (an empty string by
/// default)
virtual std::string description() const{ return "";}
/// the action of the function
/// this _has_ to be overloaded in derived classes
/// \param pj the PseudoJet input to the function
virtual TOut result(const PseudoJet &pj) const = 0;
/// apply the function using the "traditional" () operator.
/// By default, this just calls the apply(...) method above.
/// \param pj the PseudoJet input to the function
TOut operator()(const PseudoJet &pj) const { return result(pj);}
/// apply the function on a vector of PseudoJet, returning a vector
/// of the results.
/// This just calls apply on every PseudoJet in the vector.
/// \param pjs the vector of PseudoJet inputs to the function
std::vector<TOut> operator()(const std::vector<PseudoJet> &pjs) const {
std::vector<TOut> res(pjs.size());
for (unsigned int i=0; i<pjs.size(); i++)
res[i] = result(pjs[i]);
return res;
}
};
// The following functions will not be for FJ3.0, because passing a
// reference does not work when the argument is a temporary, which can
// lead to hard-to-diagnose run-time errors. A workaround is to to
// have a pointer rather than a reference as argument, since this
// provides a clearer signal to the user that the object must remain
// in scope.
//
//
// // Selectors created from the ordering between a FunctionOfPseudoJet
// // and a constant
// //----------------------------------------------------------------------
//
// /// 'larger than' operator
// ///
// /// Select jets for which the given function returns a result larger
// /// than the specified constant
// Selector operator >(const FunctionOfPseudoJet<double> & fn, const double & cut);
//
// /// 'smaller than' operator
// ///
// /// Select jets for which the given function returns a result smaller
// /// than the specified constant
// Selector operator <(const FunctionOfPseudoJet<double> & fn, const double & cut);
//
// /// 'larger or equal' operator
// ///
// /// Select jets for which the given function returns a result larger or equal
// /// to the specified constant
// Selector operator >=(const FunctionOfPseudoJet<double> & fn, const double & cut);
//
// /// 'smaller or equal' operator
// ///
// /// Select jets for which the given function returns a result smaller or equal
// /// to the specified constant
// Selector operator <=(const FunctionOfPseudoJet<double> & fn, const double & cut);
FASTJET_END_NAMESPACE
#endif // __FASTJET_FUNCTION_OF_PSEUDOJET_HH__
|