]> git.uio.no Git - u/mrichter/AliRoot.git/blobdiff - JETAN/fastjet/fastjet/EECambridgePlugin.hh
Fastjet headers
[u/mrichter/AliRoot.git] / JETAN / fastjet / fastjet / EECambridgePlugin.hh
diff --git a/JETAN/fastjet/fastjet/EECambridgePlugin.hh b/JETAN/fastjet/fastjet/EECambridgePlugin.hh
new file mode 100644 (file)
index 0000000..9ccfbee
--- /dev/null
@@ -0,0 +1,87 @@
+#ifndef __EECAMBRIDGEPLUGIN_HH__
+#define __EECAMBRIDGEPLUGIN_HH__
+
+//STARTHEADER
+// $Id: EECambridgePlugin.hh 1491 2009-03-11 17:04:38Z salam $
+//
+// Copyright (c) 2009, Matteo Cacciari, Gavin 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, write to the Free Software
+//  Foundation, Inc.:
+//      59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+//----------------------------------------------------------------------
+//ENDHEADER
+
+
+#include "fastjet/JetDefinition.hh"
+
+namespace fastjet {      // defined in fastjet/internal/base.hh
+
+// forward declaration to reduce includes
+class ClusterSequence;
+
+//----------------------------------------------------------------------
+//
+/// EECambridgePlugin is a plugin for fastjet (v2.4 upwards)
+///
+/// It implements the Cambridge algorithm, as defined in 
+/// 
+/// Better jet clustering algorithms
+/// Yuri Dokshitzer, Garth Leder, Stefano Moretti,  Bryan Webber 
+/// JHEP 9708 (1997) 001
+/// http://www-spires.slac.stanford.edu/spires/find/hep/www?rawcmd=FIND+j+JHEPA%2C9708%2C001
+///
+/// On construction one must supply a ycut value.
+///
+/// To get the jets at the end call ClusterSequence::inclusive_jets();
+/// 
+class EECambridgePlugin : public JetDefinition::Plugin {
+public:
+  /// Main constructor for the EECambridge Plugin class.  
+  /// It takes the dimensionless parameter ycut (the Q value for normalisation
+  /// of the kt-distances is taken from the sum of all particle energies).
+  EECambridgePlugin (double ycut) : _ycut(ycut) {}
+
+  /// copy constructor
+  EECambridgePlugin (const EECambridgePlugin & plugin) {
+    *this = plugin;
+  }
+
+  // the things that are required by base class
+  virtual std::string description () const;
+  virtual void run_clustering(ClusterSequence &) const;
+
+  double ycut() const {return _ycut;}
+
+  /// the plugin mechanism's standard way of accessing the jet radius.
+  /// This must be set to return something sensible, even if R
+  /// does not make sense for this algorithm!
+  virtual double R() const {return 1.0;}
+
+private:
+  double _ycut;
+};
+
+} // fastjet namespace 
+
+#endif // __EECAMBRIDGEPLUGIN_HH__
+