Release notes for GEANT 1.4 May 5th 2001 =====TWISTGEANT 1.4 Geometry and Kinematics changes========= Dave Gill New ffcards have been introduced for the user to control various aspects of a GEANT run.The details of the use of each of these cards is given below and in the .ffcards file. Two of these new cards are used to control the generation of particles in gukine.F COSM controls the generation of cosmic rays. SORC controls the generation of the muon beam (i.e. the source). A card DPOL has been introduced which controls the depolarization of the muons. At present it only allows for the possibility of spin flip for a stopped muon. Four other cards are used to control aspects of the geometry for design studies. ROOM controls the atmospheric pressure and temperature of all the gases in the detector and beamline. HEBG installs a helium bag (which by default contains air) between the end of the beamline and the first detector foil. PABR installs a plastice absorber/degrader upstream of the muon scintillator. Both this plastic degrader and the scintillator are in the helium bag(HEBG). In addition a scintillator to be employed for positron timing studies has been installed in the helium bag. This scintillator is refered to as the t0 scintillator. The size and shape of all scintillators are controlled in the dt_geo file. TECM installs a time expansion chamber as defined by the itams on this card. YOKE has a single entry to allow for not installing the yoke in the tracking geometry. In addition the functions of two of the existing cards have been modified. STPL controls the tracking step length limiting parameters tmaxfd, stemax, deemax, epsil and stmin. The modification accomodates a second set of inputs so these parameters can be independently controlled for the stopping target. GABS now controls the type of gas mixture, the length of the gas absorber and the mixture ratio of the gases in the gas absorber. >>>>>>>>>>>>>>>>>>>>>>>>>>>>>> ============ C C ============= COSM C Cosmic Rays: C 1st entry : any positive integer to use cosmic generator C (0 or -ve to be ignored) C 2nd-3rd : minimum and maximum momenta allowed (respectively, MeV) C for the cosmic ray C 4th : 'window' height above detector (y) in cm C 5th-6th : the z coordinates of the ends of the 'window' C (assumed to be rectangular) C [enter the more negative coordinate first] C 7th-8th : the x coordinates of the ends of the window C C Assumes independant 1/E**2 and cos**theta distributions C COSM -1 1000.0 100000.0 130.8 -146.5 146.5 -132.0 132.0 C >>>>>>>>>>>>>>>>>>>>>>>>>>>>>> C ========== SORC: ISORC PSORC(14) ========== C C For iswit(4).eq.0 and iswit(5).eq.0 C ----------------------------------- C ISORC = GEANT Particle type C PSORC( 1) = Particle gun origin x [cm] C PSORC( 2) = Particle gun origin y [cm] C PSORC( 3) = Particle gun origin z [cm] C PSORC( 4) = Particle gun aim - rotation around x-axis (deg) C PSORC( 5) = Particle gun aim - rotation around y-axis (deg) C PSORC( 6) = Particle gun aim - rotation around z-axis (deg) C PSORC( 7) = sigma of x position (cm) C PSORC( 8) = sigma of y position (cm) C PSORC( 9) = horizontal emittance [mr] C PSORC(10) = vertical emittance [mr] C PSORC(11) = Particle momentum [MeV/c] C PSORC(12) = 1 +- deltaP/P C PSORC(13) = Beam focus position in z C PSORC(14) = Surface muons no = 0, yes > 0 C SORC 65 0. 0. -300. 0. 0. 0. 2.5 1.0 15.0 10.0 29.7 1.01 -142.5 1. C >>>>>>>>>>>>>>>>>>>>>>>>>>> C ============= DPOL C Set muon depolarization parameters C 1st flag to turn on depolarization > 0 = on, 0 or < 0 = off C 2nd polarization mean life(sec) [example is muon lifetime] C DPOL 0 0.0000022 C >>>>>>>>>>>>>>>>>>>>>>>>>>> C C ========== ROOM: P_ATM TEMP_C ========== C C Dummy integer == iatmos C Atmospheric pressure == P_atm [Torr] C Room temperature == temp_C [deg C] C ROOM 1 760.0 20.0 C >>>>>>>>>>>>>>>>>>>>>>>>>>> C C ========== HEBG: ========== C Helium bag between end of beampipe and detector volume C ihebag > 0 means insert HEBG. C < 1 means insert HEBG full of air. C ibag_gas - type of gas in bag C 13 magnetic air C 16 magnetic helium C HEBG 1 13 C >>>>>>>>>>>>>>>>>>>>>>>>>>> C C ========== PABR: IPLASTIC PLAS_LNGTH PLAS_POSITN ========== C C ipalstic == 0 -> no plastic degrader C == 31 -> Mylar C == 26 -> Scintillator C plas_lngth == [cm] (full length) C plas_radius == [cm] C plas_positn == position of plastic degrader [cm] C PABR 31 0.004 8.0 -78.1 C >>>>>>>>>>>>>>>>>>>>>>>>>>> C ========== TECM: ========== C Time Expansion Chamber properties inputs via ffcard TECM C itecm - 0 means do not insert a TEC. C tec_length - TEC length in cm. C P_tecm - TEC operating pressure C TECM 0 20.0 20.0 C >>>>>>>>>>>>>>>>>>>>>>>>>>> C C ========== YOKE: ========== C iyoke > 0 means insert YOKE etc. C YOKE 0 C +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ <<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<< +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ C ================ Modified ffcards ================ C ============= STPL C Step length limiting parameters C 1st entry: > 0 enable parameter change, < 0 - disable (use defaults) C 1st entry should be one of: (if want different values for C 9 = High Purity Aluminium, 21 = Mylar, 17 = Gold, 6 = Graphite C 10 = Iron, 22 Aluminized Mylar, others to come in future. C 2nd-6th: tmaxfd, stemax, deemax, epsil, stmin C 7th-10th: stemax, deemax, epsil and stmin for the target material C 11th-13th: 3 spares C STPL 21 -1.0 -.5 -.25 .0001 -.1 -0.1 .0001 .0001 .0001 0. 0. 0. C >>>>>>>>>>> C C ========== GABS: IGAS ABS_LENGTH GAS_MIXTURE ========== C C Identity of Gas == igas = 20 -> He/CO2 C = 21 -> He/Ar C = 22 -> He/Xe C Absorber gas length == abs_length [cm] (full length) C Gas mixture ratio == gas_mixture (fraction of heavier gas) C GABS 21 15.0 0.5 C XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX =================Changes to run script=================================== Renee Poutissou Apart from the "ffcards", the program gets input from files defined by environment variables: setenv CHGEOM $CAL_DB/dt_geo.00014 setenv ISOMAP1 dc_drift_times.00001 setenv ISOMAP2 pc_drift_times.00000 setenv RAYFILE testbeam.dat setenv TDCMAP1 $CAL_DB/fbc1_map.00007 setenv TDCMAP2 $CAL_DB/fbc2_map.00007 Files dt_geo.00014, fbc1_map.00007 and fbc2_map.00007 have been substantially changed. These 3 files should normally be found in the calibration area $CAL_DB but they have also been included in CVS in case you do not have an uptodate calibration area. Output files will be created in directory defined by E614GEANT example: setenv E614GEANT ./ selects the current directory setenv E614GEANT /twist/data4/renee/ selects a data disk The output file names are automatically created using the run number you have selected in the ffcards. XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX ============= Monte Carlo data banks =================================== Maxim Vasiliev, Renee Poutissou, Roy Wilds The "YBOS" data file contains data banks simulating the banks produced by the DAQ system. Banks 'EVID' - the event header, 'FBU1' - TDC data from FB crate 1, 'FBU2' - TDC data from FB crate 2 Data banks containing data known by GEANT have been added to help in debugging and understanding the analysis program. Banks 'MCEV' - random number seed, spin info, initial momentum and position for each particle 'MCWH' - list of wires that have been HIT by a particle 'MCSP' - Space point information for every cell traversed by a particle Format details ======================================================= C Fill MCEV banks C MCEV bank format (INTEGER) C Word Value C 1 nrun - run number C 2 nevt - event number C 3 rand1 - initial random number #1 C 4 rand2 - initial random number #2 C 5 pol*p_scale - muon spin info C--------------------- C 6 itrack1 - track number C 7 pid1 - GEANT particle ID C 8-10 vert(3) - xyz coordinates at origin of particle C 11-13 pmom(3)- xyz momentum components at origin C-------------------- C 14 itrack2 - repeat for each track C ... ================================================= C MCWH bank format (INTEGER) C Word Value C 1 nevt C------------------------- C For each track which has hit a wire C 2 track # - track number C 3 # wires hit - how many wires are hit C ----------------- C For each wire hit C 4 names(nlevel) - name of volume C 5 number(nlevel)- wire # (should always be 1) C 6 number(nlevel-1)- cell # C 7 number(nlevel_2)- plane # C----------------------------- C Repeat ... ======================================================== C Fill Space Point banks C MCSP bank (FLOAT) C For each cell traversed by a particle, there will be C 7 words of data C Word Value C 1 (plane-1)*#CellsPerPlane + cell C 2 x coord at min drift time (global coords) C 3 y coord at min drift time (global coords) C 4 z coord at min drift time (global coords) C 5 min drift time (ns) C 6 min drift distance C 7 left-right status and detector type. See below for explanation. C .... C Left-Right status and detector type: C -1. -> DC with a left hit C +1. -> DC with a right hit C -2. -> PC with a left hit C +2. -> PC with a right hit XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX ==================Monte Carlo Changes======================= Roy Wilds Summary of changes to GEANT 1.3 The simulation now has the scintillators as active detector elements. Some of the PC planes have Multiplexed wires, and ADC enabled wires(see below for specific listing of wires). (Note ADC refers to taking the energy deposited in a hit, and creating a TDC signal from it). DC wire efficiencies have been added. Multiple hits on a wire are allowed. Signal overlap is handled so that overlapping TDC signals are correctly digitized, and overlapping of ADC signals is handled. The geometry has been altered to position the old and new scintillators. The minimum and maximum drift times are determined at the GUSTEP stage, and passed to the digitization through the GEANT hits structure (previously the hits structure passed a series of cluster points for each cell, and the min and max were calculated in the digitization step). A new MC Bank is written out in GUOUT called MCSP, which contains the global coords of the minimum drift time point for each hit in a PC or DC, as well as the plane,cell of the hit, which detector type, if it is a right-handed or left-handed hit, and the minimum drift time, and the distance from the wire of the above stated coords(see release_mcbanks.txt for more information on the new MC Banks). Specifics of changes: -Changes in the initialization have occured. -Geometry has been altered. -Fastbus Crate Maps have been changed. -Multiplexing of PC wires has been implemented. -ADC digitization of PC wires has been implemented. -4 Scinitillators are now present. They all have TDC and ADC output. -Storage of hits in structures is now different. -Multiple hits on a single wire by same track are allowed and dealt with. -DC chamber efficiencies are read in, and used in digitization(if flag is set). -TDC window is implemented and ADC gate is implemented. -New MC Bank is written out. ***************************************************************************** A. Files added: 1.) adc_digitize.par Contains parameters for converting energy lost for a hit, into a TDC signal. Parameters have been chosen arbitrarily to produce TDC widths of approximately 1000 to 10000 channels. 2.) check_instrumented_wires.F Takes the map of instrumented wires of DC and PC planes (read_tdcmaps) and compares them with the geometry specs on instrumented wires from the dt_geo.000## file. If a discrepancy is present, it complains and continues on, using the fastbus crate data as the "true" data. This check is not necessary to any other code, and the call to it in UGINIT can be removed if one does not want it used. 3.) dc_efficiencies.inc (Paul Nord) Contains variables used in the determination of Drift Chamber efficiencies. 4.) driftpoints.inc (Rob Macdonald) Contains variables used in: the determination of MIN and MAX drift time, the digitization of hits. 5.) driftpoints.par (Rob Macdonald) Parameters used in determination of MIN and MAX drift time. 6.) multiplexing.inc Parameters and map array for finding Multiplexed (MXd) wires. See read_tdcmaps for explanation of contents. 7.) process_**_digitization.F Retrieves the hits data from the GEANT hits structure, and resolves any signal overlap caused by a wire being hit multiple times (or in the case of Multiplexed PC wires, a group of wires being hit multiple times). If wires are hooked up to ADCs then these signals are processed if they lie entirely within the ADC gate (defined in GUKINE). The processed hits are then place in the hit_times_** array, which is used in SIMULATE_1877_TDC for writing out the digitized data. If ASCII data output is enabled (ie. iswit(10)=2) then the hit_times_** array data is written at the end of process_**_digitization routine. For the DCs, if the effs_on flag is on, then efficiencies are utilized. The efficiency of the chamber is used to determine if a wire "fires" for a given hit. All muon hits are automatically fired, and no check is made to handle possible charge integration overlap in the efficiency determinations. Called from GUDIGI. 8.) read_dc_eff.F (Paul Nord) Reads in the DC efficiencies from a file (specified by environment variable DCEFF). 9.) resolve_adc_signals.F Takes all ADC signals, determines if they lie within the ADC gate, and combines them. If there are multiple hits on a cell (or group if MXd) then the ADC signal is placed in the first processed position in hit_times_** array Called from PROCESS_PC_DIGITIZATION and PROCESS_SC_DIGITIZATION. 10.) resolve_tdc_signals.F Takes multiple TDC signals and consolidates them if overlapping. The returned signals array contains only those signals that are seperate. Called from PROCESS_**_DIGITIZATION. 11.) signal_processing.inc Contains parameters and signals() array used in processing of multiple signals on a wire (or group of wires, if MXd). 12.) sp_words.inc Contains array and pointer for new MC Bank containing space point data. 13.) store_cell_points.F (Rob Macdonald) Replaces store_track_segments.F. Handles checking for sensitive volumes, initialization at cell entry, etc. Calls store_one_point.F. Stores energy lost for ADC calculations. Also handles Scintillator hits, and the scintillator hits are placed into the GEANT hits structure in this routine. The DCs and PCs are handled differently since drift times have to be taken into account for these detectors. Called from GUSTEP 14.) store_hit_**.F Digitizes hit data from current detector volume. Only stores TDC signal if within TDC window. For the DCs and PCs the information of the hit, consisting of-- (plane,cell) ;x ;y ;z (global coords); min drift time (ns); distance corresponding to min drift time; detector type (PC or DC) and identifier of whether the hit was on the left or right of the wire --is written into the sp_words array, and later entered into the MCSP bank. If the number of space points exceeds the maximum number stored, then they are no longer stored. Called from STORE_CELL_POINTS when the particle is leaving the cell or when it has come to a stop within the cell. 15.) store_one_point.F (Rob Macdonald) Checks each GEANT step's drift time, and stores it if appropriate. Called by STORE_CELL_POINTS ************************************************************************* B. Files removed: 1.) digitize_**.F Replaced by store_hit_**.F and process_**_digitization.F 2.) store_track_segments.F Replaced by store_cell_points.F ************************************************************************* C. Files changed: 1.) Makefile Added new subroutines: check_instrumented_wires.o, store_cell_points.o, store_one_point.o, store_hit_dc.o, store_hit_pc.o, process_dc_digitization.o, process_pc_digitization.o, process_sc_digitization.o, resolve_adc_signals.o, resolve_tdc_signals.o read_dc_eff.o Removed subroutines: store_track_segments.o, digitize_dc.o, digitize_pc.o 2.) bcs.inc Added pointer variable for the writing of the new MCSP bank. 3.) define_data_format.F Scintillators are now active detector elements, as well as the DCs and PCs. Changed definitions for hits storage. All that is now stored is: -DCs: particle type, min time (ns), max time (ns) -PCs: particle type, min time (ns), max time (ns), energy lost (keV) -SCs: particle type, entry time (ns), energy lost (keV) Note that for all the times above, they are the total time = drift time + time of flight. 4.) dc_cluster_time.F (Rob Macdonald) Re-designed. Now made up of DC_MIN_CLUSTER_TIME, and DC_MAX_CLUSTER_TIME which function as original DC_CLUSTER_TIME did, but for the minimum and maximum drift times (and their respective points). If a wire is physically hit, then this is addressed. As well the minimum drifttime is set by a parameter in driftpoints.par (cascademin) To accomodate the new GEANT bank it was necessary to have the dc_min_cluster_time routine return the minimum drift time(min_dtime). This has been added. 5.) detect_geom.inc Altered scintillator geometry variables to handle the increased number of scintillators. 6.) detect_geom.par Maximum number of scintillators increased. 7.) dt_geo.00014 Added new specifications for scintillators. 8.) fbc1_map.00007 Re-mapped with Multiplexing of wires 65->96 of PC planes 1->4 and ADC wiring of wires 57->104 of PC planes 5&6. (PC ADC wiring is subsystem 4) 9.) fbc2_map.00007 Re-mapped with Multiplexing of wires 65->96 of PC planes 9->12 and ADC wiring of wires 57->104 of PC planes 7&8.(PC ADC wiring is subsystem 4) ADC and TDC wiring of the 4 scintillators is included (TDC is subsystem 3, ADC is subsystem 5) 10.) gudigi.F Removed calls to DIGITIZE_** and put in calls to PROCESS_**_DIGITIZATION 11.) gutrev.F The TDC window, and ADC gate are set here (in the code). Initialization of the pointer for the MCSP (MC space point) bank is done here as well. 12.) guout.F Added in writing of the MCSP bank. 13.) gustep.F (Rob Macdonald) Replaced call to STORE_TRACK_SEGMENTS with STORE_CELL_POINTS. 14.) hit_elements.par Changed the parameters for the number of parameters for hits data in detector elements. The changes are: nhd=3,nhp=4,nhs=3. The parameter nhel was eliminated, since the method of storing hits has changed, and this parameter (which was the max number of cluster points in a cell) is no longer used. 15.) pc_cluster_time.F (Rob Macdonald) Re-designed. Now made up of PC_MIN_CLUSTER_TIME, and PC_MAX_CLUSTER_TIME which function as original PC_CLUSTER_TIME did, but for the minimum and maximum drift times (and their respective points). If a wire is physically hit, then this is addressed. As well the minimum drifttime is set by a parameter in driftpoints.par (cascademin) To accomodate the new GEANT bank it was necessary to have the pc_min_cluster_time routine return the minimum drift time (min_dtime). This has been added. 16.) read_tdcmaps.F Altered to handle new FBC maps (see above) and to fill up the DC,PC instrumented wire arrays, and the PC ADC wire map, and the PC Multiplexed array map. 17.) scint_geom.F Altered to handle new positioning of all 4 scintillators (they are now in a different mother volume. See UGEOM for more details). 18.) simulate_1877_tdc.F Now writes: PC ADC data; Scintillator TDC, ADC data; all into YBOS format (in addition to the DC,PC TDC data from before). As well a check is done to see if the number of words written to a slot exceeds the maximum allowed. 19.) tdc_times.inc Now contains TDC window and ADC gate boundary variables(these are set in the code in GUTREV). Also increased parameter nhmax (max number of hits per event per detector type(ie. DC,PC,SC) ) to 600. 20.) tdcmap.inc Added PC ADC map, Scintillator ADC and TDC maps. DC and PC wires instrumented maps. PC wires instrumented with ADCs map. Parameter for maximum number of scintillator channels. 21.) uginit.F Placed call to CHECK_INSTRUMENTED_WIRES after reading the geometry specs and the FBC maps. The FBC maps are read regardless of what the value of iswit(10) is, since they are necessary in the processing of hits in PC planes. Reads in the DC efficiencies (if specified in e614.com file). ***************************************************************** Notes regarding detector set definitions for the PCs and SCintillators The scintillators have been divided into 2 groups. The disks are called beam or mu scintillators, and the annulus' are called t0 scintillators. Since the volume definitions of them are different, they had to be defined as detector ELEMENTS seperately. They are both defined as belonging to detector SET "SCNT", and hits in either type are treated without distinction being made between them until the process_sc_digitization routine. In there, the mu scintillator hits are retrieved and processed, and then the t0 scintillator hits are retrieved and processed. A similar situation exists with the Proportional Chambers. PC planes 6&7 (which straddle the target) are defined as thinner than the rest of the PC planes (and hence are defined as different volumes: PLNT instead of PPLN with cells defined as TCEL instead of PCEL). As with the 2 types of scintillators above, the 2 different volumes are defined as belonging to the same detector set PROP, and are treated without distinction until the process_pc_digitization routine. In prop_geom there are no thick planes defined for volume id #s 6&7, but instead the thin planes are identified as volume id #s 6&7. So, in process_pc_digitization, as the planes are being cycled thru, hits are retrieved from the thin planes storage for only planes 6&7. The only difference in processing occurs in the retrieval of the hits data, since different volume identifiers are required for these 2 planes, than the rest of the PC planes. Note that throughout the simulation, the fact that PC planes 6&7 are different is "hard-coded" in, and NOT read from a file. If any changes are to be made, then the consequences should be thoroughly examined. The subroutines that will be directly affected are: For the scints: scint_geom.F,define_data_format.F,process_sc_digitization.F For the PCs: prop_geom.F,define_data_format.F,process_pc_digitization.F