fcs:fpad
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
fcs:fpad [2016/03/18 16:09] – [Visualizing events with Jas+Wired] asc | fcs:fpad [2016/03/22 04:17] (current) – [FPaDsoft] asc | ||
---|---|---|---|
Line 7: | Line 7: | ||
The package does not require | The package does not require | ||
- | It is a merge of several open-source Java projects, such as [[http:// | + | It is a merge of several open-source Java projects, such as [[http:// |
- | + | This program | |
- | You can find Monte Carlo samples in the LCIO format using the [[http:// | + | |
- | This link prints all event samples after full detector simulations ("tag rfull001" | + | |
- | Select " | + | |
- | You can download such samples as discussed in [[http:// | + | |
- | + | ||
- | + | ||
- | + | ||
- | The installation does not have external dependencies besides Java. Make sure Java7 and above is installed. | + | |
- | Then run these commands to install the package (on Linux) | + | |
- | <code bash> | + | |
- | wget http:// | + | |
- | cd fpadsoft/ | + | |
- | source setup.sh # takes 5 sec for first-time optimization | + | |
- | </ | + | |
- | The last command optimizes Java packages for the Python language. | + | |
- | Now you are ready to run over any file with truth-level and datector-simulation files, such as LCIO and ProMC. | + | |
- | You can also use Windows. | + | |
- | + | ||
- | ====== Examples ====== | + | |
- | All examples are publicly available from [[http:// | + | |
- | They are also located in the " | + | |
- | Many examples are based on [[http:// | + | |
- | We assume that the working directory is " | + | |
- | + | ||
- | + | ||
- | ===== Z-peak using MC truth ===== | + | |
- | Let's calculate Z peak from thuth-level electrons. | + | |
- | Get 4 files (in 2 threads) and copy all files to the directory " | + | |
- | + | ||
- | <code bash> | + | |
- | source setup.sh | + | |
- | cd examples | + | |
- | hs-get gev250ee_pythia6_zpole_ee%rfull001 gev250ee_pythia6_zpole_ee 2 4 # download 4 files | + | |
- | ../fpad mc_truth.py | + | |
- | </ | + | |
- | + | ||
- | + | ||
- | Alternatively, | + | |
- | + | ||
- | <code bash> | + | |
- | ../ | + | |
- | </ | + | |
- | It will pop-up an editor to edit the script. Then press " | + | |
- | The result of this file is: | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | ===== Z-peak using PFA ===== | + | |
- | Let's calculate Z peak from particle-flow objects after full reconstruction using Pandora. | + | |
- | You do not run " | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_zpole_ee%rfull001 gev250ee_pythia6_zpole_ee 2 4 # download 4 files | + | |
- | ../fpad mc_pflow.py | + | |
- | </ | + | |
- | + | ||
- | + | ||
- | {{: | + | |
- | + | ||
- | you can also make a simple fit: | + | |
- | + | ||
- | <code bash> | + | |
- | ../fpad mc_pflow_fit.py | + | |
- | </ | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | ===== Z-peak using tracks ===== | + | |
- | + | ||
- | Let's calculate Z peak from reconstructed tracks (no Pandora and no particle identification) | + | |
- | You do not run " | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_zpole_ee%rfull001 gev250ee_pythia6_zpole_ee 2 4 # download 4 files | + | |
- | ../fpad mc_tracks.py | + | |
- | </ | + | |
- | + | ||
- | + | ||
- | {{: | + | |
- | + | ||
- | ===== Higgs from γ γ===== | + | |
- | + | ||
- | Let's calculate the Higgs peak from reconstructed photons after the PFA algorithm. This time | + | |
- | you will need H-> gamma+gamma sample [[http:// | + | |
- | We set pT(γ)> | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_higgs_gamgam%rfull001 gev250ee_pythia6_higgs_gamgam 2 10 # get 10 files in 2 threads | + | |
- | ../fpad mc_gammagamma.py | + | |
- | </ | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | ===== Z-peak using b-jets ===== | + | |
- | Let's calculate Z peak from reconstructed b-jets. Jets are reconstructed using the Durham kT algorithm with ycut=0.05. | + | |
- | This time we will download Z-> bbar sample. Look at [[http:// | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_zpole_bbar%rfull001 gev250ee_pythia6_zpole_bbar | + | |
- | ../fpad mc_jets.py | + | |
- | </ | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | No any optimization for jet reconstruction was used. Consider other approaches to make more realistic dijet mass. | + | |
- | + | ||
- | + | ||
- | ===== Z-peak using tau-tau ===== | + | |
- | Let's calculate Z peak from two Durham jets as in the previous example, but using Z-> | + | |
- | Should see shift from 90 GeV (neutrino). | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_zpole_tautau%rfull001 gev250ee_pythia6_zpole_tautau 2 50 # download 50 files | + | |
- | ../fpad mc_tautau.py | + | |
- | </ | + | |
- | + | ||
- | + | ||
- | {{: | + | |
- | + | ||
- | No any optimization for jet reconstruction was used. Consider other approaches to make more realistic tau reconstruction.. | + | |
- | + | ||
- | ===== Higgs from 4 leptons===== | + | |
- | Let's calculate Higgs peak from reconstructed leptons in the channel H(125)-> ZZ* -> 4L (electrons and muons). | + | |
- | We will use particle flow objects to reconstruct and identify electrons and muons. | + | |
- | This time we will download Higgs-> 4 lepton | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_higgs_zz_4l%rfull001 gev250ee_pythia6_higgs_zz_4l 2 100 # download 100 files in 2 threads | + | |
- | ../fpad mc_higgs_zz.py | + | |
- | </ | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | You can also look at some exotic configurations. For example, let's reconstruct Higgs at 100 TeV using SLIC: | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get tev100_pythia6_higgs_zz_4l%rfull001 tev100_pythia6_higgs_zz_4l # get 100 TeV sample | + | |
- | ../fpad mc_higgs_zz_100tev.py | + | |
- | </ | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | + | ||
- | ===== Higgs from bbar===== | + | |
- | + | ||
- | This example uses the Jade algorithm to force 2 jets, and uses H-> bbar sample: | + | |
- | + | ||
- | <code bash> | + | |
- | hs-get gev250ee_pythia6_higgs_bbar%rfull001 gev250ee_pythia6_higgs_bbar | + | |
- | ../fpad mc_higgs_bbar.py | + | |
- | </ | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | + | ||
- | + | ||
- | ===== Jet energy resolutions===== | + | |
- | + | ||
- | This example shows the jet energy resolution in 2 pT(truth) regions. It is based on inclusive jet sample | + | |
- | [[http:// | + | |
- | Jet are constructed from PFA objects. Truth jet and reco jets are matched using dR<0.05 in phi and rapidity. | + | |
- | + | ||
- | {{: | + | |
- | ===== Showing calorimeter hits in 3D===== | + | |
- | + | ||
- | One can also visualize calorimter-level objects, such as hits. | + | |
- | For example, here are calorimeter hits for Z-> bbar event | + | |
- | (only one event is shown) | + | |
- | + | ||
- | <code bash> | + | |
- | ../fpad mc_hits3D.py # hits in 3D for 1 events | + | |
- | ../fpad mc_hits.py | + | |
- | </ | + | |
- | + | ||
- | Location of calorimeter hits for 1 event: | + | |
- | + | ||
- | + | ||
- | {{: | + | |
- | + | ||
- | Phi angle of calorimeter hits for all events: | + | |
- | + | ||
- | {{: | + | |
- | ====== How to download all files ====== | + | |
- | + | ||
- | Use the [[http:// | + | |
- | You can list and download files for Z to e+e- automatically as | + | |
- | + | ||
- | <code bash> | + | |
- | hs-ls gev250ee_pythia6_zpole_ee%rfull001 # list all files | + | |
- | hs-get gev250ee_pythia6_zpole_ee%rfull001 # download all files (can be large sample!) | + | |
- | </ | + | |
- | Here " | + | |
- | ====== How to find MC after full simulation ====== | + | |
- | + | ||
- | + | ||
- | To find event samples with full simulations, | + | |
- | For example, use the [[http:// | + | |
- | with a full detector simulation. | + | |
- | + | ||
- | + | ||
- | ====== LCIO event structure ====== | + | |
- | + | ||
- | + | ||
- | The standard set of containers is available from the LCIO files posted on HepSim. Read | + | |
- | [[http:// | + | |
- | [[http:// | + | |
- | + | ||
- | Look the Java API definition of the needed objects in [[http:// | + | |
- | + | ||
- | < | + | |
- | BeamCalHits | + | |
- | CalorimeterHitRelations | + | |
- | EM_BARREL | + | |
- | EM_ENDCAP | + | |
- | EcalBarrelHits | + | |
- | EcalEndcapHits | + | |
- | HAD_BARREL | + | |
- | HAD_ENDCAP | + | |
- | HcalBarrelHits | + | |
- | HcalEndcapHits | + | |
- | HelicalTrackHitRelations | + | |
- | HelicalTrackHits | + | |
- | HelicalTrackMCRelations | + | |
- | LumiCalHits | + | |
- | MCParticle | + | |
- | MUON_BARREL | + | |
- | MUON_ENDCAP | + | |
- | MuonBarrelHits | + | |
- | MuonEndcapHits | + | |
- | PandoraPFOCollection | + | |
- | ReconClusters | + | |
- | SiTrackerBarrelHits | + | |
- | SiTrackerEndcapHits | + | |
- | SiTrackerForwardHits | + | |
- | SiVertexBarrelHits | + | |
- | SiVertexEndcapHits | + | |
- | StateAtECal | + | |
- | StateAtEnd | + | |
- | StateAtStart | + | |
- | TKR_RawTrackerHits | + | |
- | TKR_TrackerHits | + | |
- | Tracks | + | |
- | VXD_RawTrackerHits | + | |
- | VXD_TrackerHits | + | |
- | </ | + | |
- | + | ||
- | ====== Detector geometry ====== | + | |
- | The Monte Carlo files located in [[http:// | + | |
- | using the sidloi3 detector: [[http:// | + | |
- | [[http:// | + | |
- | + | ||
- | The SiD detector is shown here {{: | + | |
- | + | ||
- | You can view detector geometries posted in [[http:// | + | |
- | Download zip file and extract it. Find file " | + | |
- | + | ||
- | < | + | |
- | ./ | + | |
- | </ | + | |
- | + | ||
- | Now you can open this file in the Jas and view it. Look at other options by running " | + | |
- | + | ||
- | Here are a few links to the description of this detector. | + | |
- | + | ||
- | + | ||
- | {{: | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | ====== Java API for scripts ====== | + | |
- | + | ||
- | ===== Plots and histograms ===== | + | |
- | + | ||
- | + | ||
- | FPadSoft uses histogram packages supported by both DMelt (community edition) or JAIDA (FreeHep). | + | |
- | DMelt provides programming API similar to PyROOT and with classes named conveniently to reduce code verbosity. | + | |
- | + | ||
- | Here are a few most common classes: | + | |
- | + | ||
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | + | ||
- | The main canvas to show histograms [[http:// | + | |
- | In addition, data are saved in the form of XML (with the extension " | + | |
- | + | ||
- | ===== Lorentz particles and Jets ===== | + | |
- | + | ||
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | + | ||
- | + | ||
- | Java implementation of the longitudinally invariant kT and anti-kT clustering algorithms uses the E-scheme to combine particles (p1+p2) and Eta-Phi space (not Rapidity-Phi). Also, Cambridge/ | + | |
- | + | ||
- | + | ||
- | You can build the standard kt-jets using [[http:// | + | |
- | [[http:// | + | |
- | + | ||
- | ===== Working with ProMC files ===== | + | |
- | + | ||
- | To work with ProMC files, look at the ProMC Java API that is used to store data on the HepSim web page | + | |
- | + | ||
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | * [[http:// | + | |
- | + | ||
- | + | ||
- | It is simplified compared to full MC simulations, | + | |
- | information on event weights and uncertainties. | + | |
- | + | ||
- | The project uses the community edition of [[http:// | + | |
- | + | ||
- | + | ||
- | + | ||
- | + | ||
- | ====== Using C++/ROOT with LCIO files====== | + | |
- | + | ||
- | If you need to read LCIO files in C++ code with ROOT/ | + | |
- | + | ||
- | <code bash> | + | |
- | wget http:// | + | |
- | cd lcio-cpp; make | + | |
- | </ | + | |
- | It will compile " | + | |
- | + | ||
- | + | ||
- | + | ||
- | ====== Analysing truth-level files ====== | + | |
- | + | ||
- | You can run over the original truth-level files from HepSim: | + | |
- | + | ||
- | <code bash> | + | |
- | wget http:// | + | |
- | ../fpad pythia6_zpole_tautau.py | + | |
- | </ | + | |
- | This example prints the pT distribution of e, mu, taus. | + | |
- | Typically, HepSim contains validation files with the extension py that can check the validity of truth-level samples. | + | |
- | See the description in [[http:// | + | |
- | + | ||
- | + | ||
- | + | ||
- | ====== Visualizing events with Jas+Wired ====== | + | |
- | + | ||
- | You can run Jas+Wired to visualize the simulated events. | + | |
- | <code bash> | + | |
- | ./fjas | + | |
- | </ | + | |
- | This will start Jas3 with all needed plugins. | + | |
- | Then copy the detector geometry file to the local directory where the file " | + | |
- | <code bash> | + | |
- | wget http:// | + | |
- | </ | + | |
- | This will create a directory " | + | |
- | + | ||
- | Now we can visualize the detector as **[File]-[Open data source]-[HepRep]** XML and select the file " | + | |
- | This is how to do this using the command line: | + | |
- | + | ||
- | <code bash> | + | |
- | ./fjas detector/ | + | |
- | </ | + | |
- | You will see the detector layout: | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | Now, we will read the event: Open any *.slcio file you copied from HepSim as | + | |
- | **[File]-[Open data source]-[LCIO]** file. Then click a small button [Go] (top menu bar). It will process | + | |
- | | + | |
- | + | ||
- | {{: | + | |
- | + | ||
- | Now press [Go] again to look at next event. | + | |
- | + | ||
- | If you want to see how data records are organized inside the slcio file, | + | |
- | do this **[File]-[New]-[LCSim Event browser]** | + | |
- | + | ||
- | ====== People ====== | + | |
- | + | ||
- | This collection of tools for future collider studies | + | |
- | in collaboration with Jan Strube (PNNL) ([email protected]) and Ashutosh Kotwal (Duke U) [email protected]. | + | |
- | The Java part of the simulator for the linear collider was designed N. Graf, J. McCormick, T.Jonson | + | |
- | + | ||
- | + | ||
- | ====== FAQ ====== | + | |
- | + | ||
- | For some help with SLIC, read: | + | |
- | + | ||
- | https:// | + | |
- | + | ||
- | https:// | + | |
fcs/fpad.1458317377.txt.gz · Last modified: 2016/03/18 16:09 by asc