Fork me on GitHub

source: svn/trunk/Utilities/Fastjet/include/fastjet/ClusterSequence1GhostPassiveArea.hh@ 642

Last change on this file since 642 was 11, checked in by severine ovyn, 16 years ago

Fastjet added; CDFCones directory has been changed

File size: 3.5 KB
Line 
1//STARTHEADER
2// $Id: ClusterSequence1GhostPassiveArea.hh,v 1.1 2008-11-06 14:32:07 ovyn Exp $
3//
4// Copyright (c) 2005-2007, Matteo Cacciari, Gavin Salam and Gregory Soyez
5//
6//----------------------------------------------------------------------
7// This file is part of FastJet.
8//
9// FastJet is free software; you can redistribute it and/or modify
10// it under the terms of the GNU General Public License as published by
11// the Free Software Foundation; either version 2 of the License, or
12// (at your option) any later version.
13//
14// The algorithms that underlie FastJet have required considerable
15// development and are described in hep-ph/0512210. If you use
16// FastJet as part of work towards a scientific publication, please
17// include a citation to the FastJet paper.
18//
19// FastJet is distributed in the hope that it will be useful,
20// but WITHOUT ANY WARRANTY; without even the implied warranty of
21// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22// GNU General Public License for more details.
23//
24// You should have received a copy of the GNU General Public License
25// along with FastJet; if not, write to the Free Software
26// Foundation, Inc.:
27// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
28//----------------------------------------------------------------------
29//ENDHEADER
30
31#ifndef __FASTJET_CLUSTERSEQUENCE1GHOSTPASSIVEAREA_HH__
32#define __FASTJET_CLUSTERSEQUENCE1GHOSTPASSIVEAREA_HH__
33
34
35#include "Utilities/Fastjet/include/fastjet/PseudoJet.hh"
36#include "Utilities/Fastjet/include/fastjet/ClusterSequenceAreaBase.hh"
37#include "Utilities/Fastjet/include/fastjet/ClusterSequenceActiveArea.hh"
38#include<iostream>
39#include<vector>
40
41FASTJET_BEGIN_NAMESPACE // defined in fastjet/internal/base.hh
42
43//using namespace std;
44
45/// Class that behaves essentially like ClusterSequence except
46/// that it also provides access to the area of a jet (which
47/// will be a random quantity... Figure out what to do about seeds
48/// later...)
49class ClusterSequence1GhostPassiveArea : public ClusterSequenceActiveArea {
50public:
51
52 ClusterSequence1GhostPassiveArea() {}
53
54 /// constructor based on JetDefinition and 1GhostPassiveAreaSpec
55 template<class L> ClusterSequence1GhostPassiveArea
56 (const std::vector<L> & pseudojets,
57 const JetDefinition & jet_def,
58 const GhostedAreaSpec & area_spec,
59 const bool & writeout_combinations = false) ;
60
61 /// return an estimate for the number of empty jets -- one uses the
62 /// AreaBase one rather than the ActiveArea one (which for which we
63 /// do not have the information).
64 virtual double n_empty_jets(const RangeDefinition & range) const {
65 return ClusterSequenceAreaBase::n_empty_jets(range);
66 }
67
68protected:
69 /// does the initialisation and running specific to the passive
70 /// areas class
71 void _initialise_and_run_1GPA (const JetDefinition & jet_def,
72 const GhostedAreaSpec & area_spec,
73 const bool & writeout_combinations = false);
74
75private:
76
77 void _run_1GPA(const GhostedAreaSpec & area_spec);
78};
79
80
81
82
83template<class L> ClusterSequence1GhostPassiveArea::ClusterSequence1GhostPassiveArea
84(const std::vector<L> & pseudojets,
85 const JetDefinition & jet_def,
86 const GhostedAreaSpec & area_spec,
87 const bool & writeout_combinations) {
88
89 // transfer the initial jets (type L) into our own array
90 _transfer_input_jets(pseudojets);
91
92 // run the clustering for passive areas
93 _initialise_and_run_1GPA(jet_def, area_spec, writeout_combinations);
94
95}
96
97
98
99FASTJET_END_NAMESPACE
100
101#endif // __FASTJET_CLUSTERSEQUENCE1GHOSTPASSIVEAREA_HH__
Note: See TracBrowser for help on using the repository browser.