Geant4.10
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
HepMCEx01/src/HEPEvtcom.cc
Go to the documentation of this file.
1 //
2 // ********************************************************************
3 // * License and Disclaimer *
4 // * *
5 // * The Geant4 software is copyright of the Copyright Holders of *
6 // * the Geant4 Collaboration. It is provided under the terms and *
7 // * conditions of the Geant4 Software License, included in the file *
8 // * LICENSE and available at http://cern.ch/geant4/license . These *
9 // * include a list of copyright holders. *
10 // * *
11 // * Neither the authors of this software system, nor their employing *
12 // * institutes,nor the agencies providing financial support for this *
13 // * work make any representation or warranty, express or implied, *
14 // * regarding this software system or assume any liability for its *
15 // * use. Please see the license in the file LICENSE and URL above *
16 // * for the full disclaimer and the limitation of liability. *
17 // * *
18 // * This code implementation is the result of the scientific and *
19 // * technical work of the GEANT4 collaboration. *
20 // * By using, copying, modifying or distributing the software (or *
21 // * any work based on the software) you agree to acknowledge its *
22 // * use in resulting scientific publications, and indicate your *
23 // * acceptance of all terms of the Geant4 Software license. *
24 // ********************************************************************
25 //
26 /// \file eventgenerator/HepMC/HepMCEx01/src/HEPEvtcom.cc
27 /// \brief Implementation of the HEPEvtcom class
28 //
29 // $Id: HEPEvtcom.cc 73446 2013-08-27 11:32:59Z gcosmo $
30 //
31 // ======================================================================
32 // PARAMETER (NMXHEP=4000)
33 // COMMON/HEPEVT/NEVHEP,NHEP,ISTHEP(NMXHEP),IDHEP(NMXHEP),
34 // & JMOHEP(2,NMXHEP),JDAHEP(2,NMXHEP),PHEP(5,NMXHEP),VHEP(4,NMXHEP)
35 // ======================================================================
36 ///**********************************************************/
37 ///* D E S C R I P T I O N : */
38 ///*--------------------------------------------------------*/
39 ///* NEVHEP - event number (or some special meaning*/
40 ///* (see documentation for details) */
41 ///* NHEP - actual number of entries in current */
42 ///* event. */
43 ///* ISTHEP[IHEP] - status code for IHEP'th entry - see */
44 ///* documentation for details */
45 ///* IDHEP [IHEP] - IHEP'th particle identifier according*/
46 ///* to PDG. */
47 ///* JMOHEP[IHEP][0] - pointer to position of 1st mother */
48 ///* JMOHEP[IHEP][1] - pointer to position of 2nd mother */
49 ///* JDAHEP[IHEP][0] - pointer to position of 1st daughter */
50 ///* JDAHEP[IHEP][1] - pointer to position of 2nd daughter */
51 ///* PHEP [IHEP][0] - X momentum [Gev/c] */
52 ///* PHEP [IHEP][1] - Y momentum [Gev/c] */
53 ///* PHEP [IHEP][2] - Z momentum [Gev/c] */
54 ///* PHEP [IHEP][3] - Energy [Gev] */
55 ///* PHEP [IHEP][4] - Mass[Gev/c^2] */
56 ///* VHEP [IHEP][0] - X vertex [mm] */
57 ///* VHEP [IHEP][1] - Y vertex [mm] */
58 ///* VHEP [IHEP][2] - Z vertex [mm] */
59 ///* VHEP [IHEP][3] - production time [mm/c] */
60 ///*========================================================*/
61 //
62 // This interface to HEPEVT common block treats the block as
63 // an array of bytes --- the precision and number of entries
64 // is determined "on the fly" by the wrapper and used to decode
65 // each entry.
66 //
67 // HEPEVT_EntriesAllocation is the maximum size of the HEPEVT common block
68 // that can be interfaced. It is NOT the actual size of the HEPEVT common
69 // used in each individual application. The actual size can be changed on
70 // the fly using HepMC::HEPEVT_Wrapper::set_max_number_entries().
71 // Thus HEPEVT_EntriesAllocation should typically be set
72 // to the maximum possible number of entries --- 10000 is a good choice
73 // (and is the number used by ATLAS versions of Pythia).
74 
75 #include <ctype.h>
76 
77 enum {HEPEVT_EntriesAllocation=4000};
78 
79 const unsigned int hepevt_bytes_allocation =
80 sizeof(long int) * ( 2 + 4 * HEPEVT_EntriesAllocation )
81  + sizeof(double) * ( 9 * HEPEVT_EntriesAllocation );
82 
83 extern "C" struct hepevt{
85 };
86 
88 
typedef int(XMLCALL *XML_NotStandaloneHandler)(void *userData)
const unsigned int hepevt_bytes_allocation
const XML_Char const XML_Char * data
hepevt hepevt_