source: trunk/ReleaseNotes/Beta4.9.4-1.txt@ 1345

Last change on this file since 1345 was 1337, checked in by garnier, 15 years ago

tag geant4.9.4 beta 1 + modifs locales

File size: 42.5 KB
Line 
1
2 Geant4 9.4-beta-01 Release Notes
3 --------------------------------
4
5 25 June 2010
6
7List of main features and fixes included in this Beta release since 9.3.p01:
8
9 o Configuration:
10 -------------
11 + Configure script:
12 o Protected echos on LD_LIBRARY_PATH so that output from use of
13 Configure post-install is clean.
14 o Added removal of quotes from make version string to handle non-English
15 language systems.
16 o Fixed selection of XERCESCROOT path for Windows.
17 o Added new data set G4NEUTRONXS (Evaluated neutron cross section
18 data, version 1.0), controlled by variable G4NEUTRONXSDATA.
19 o Updated data set G4EMLOW to version 6.13.
20 + Removed 'leading_particle' hadronic module from include paths list.
21 + Increased stack size on WIN32-VC setup (i.e. 8MB as on Linux), adding
22 the option to LDFLAGS.
23
24 o Digits+Hits:
25 -----------
26 + Added missing virtual destructor to G4VScoringMesh and removed
27 unnecessary virtual qualifiers to G4ScoringBox.
28
29 o Environments:
30 ------------
31 + G4Py:
32 o Revised usage of MultipleScattering classes to make use of new particle
33 based processes.
34 o Fixed bug in wrapping of G4GDMLParser.
35 o Updated run-manager and physics-lists.
36 + Momo:
37 o Revised obsolete trajectory drawing.
38
39 o Event:
40 -----
41 + Improved logic in G4PrimaryTransformer. Addressing problem report #1101.
42 + Fixed compilation warning in G4SmartTrackStack issued with gcc 4.5.0.
43 + Added few accessors methods to G4SPSEneDistribution class.
44 + Removed obsolete CLHEP_HepMC option from G4EventManager class.
45
46 o Geometry:
47 --------
48 + solids/Boolean:
49 o Introduced recursive algorithm in CreatePolyhedron() for Boolean
50 operations: it uses HepPolyhedronProcessor from 'graphics_reps' module,
51 using new technique in attempt to avoid numerical problems for the
52 calculation of the polyhedron in BooleanProcessor. It allows to try
53 all permutations, also for Booleans of Booleans.
54 Helps in reducing the number of cases of "Error in Boolean processor"
55 for visualization; still some stubborn cases are left.
56 + solids/CSG:
57 o G4Box: first implementation of speed improvements and corrections from
58 joint code review of G4Box class: introduced half-tolerance constants
59 and better logic in some conditional statements. Some code cleanup.
60 o G4Orb: modified DistanceToIn(p,v) to be more consistent with Inside(p).
61 + solids/specific:
62 o Introducing new G4GenericTrap shape, a new solid representing an
63 arbitrary trapezoid with up to 8 vertices standing on two parallel
64 planes perpendicular to the Z axis.
65 o Fix in G4TriangularFacet and G4TessellatedSolid to correct treatment of
66 optical photon transport related to internal reflection at surface.
67 Addresses problem report #1103.
68 o G4ExtrudedSolid: eliminated requirement for clockwise ordering of
69 polygon vertices. Added a check for vertices ordering; if vertices
70 are defined anti-clockwise their ordering is reverted.
71 Fix in polygon facet triangularization for consequent concave vertices.
72 o Fixed deletion of internal arrays in CreatePolyhedron() for G4Polycone
73 and G4Polyhedra.
74 + volumes:
75 o Make use of specialized allocator for handling internal vector in
76 G4NavigatorHistory, globally controlling the memory pool, to optimise
77 memory management and reduce fragmentation.
78 Measured ~2% average run-time speed-up.
79 o Added Reset() method to G4ReflectionFactory for clearing maps of
80 constituent and reflected volumes.
81
82 o Global:
83 ------
84 + Introduced G4PhysicsVectorCache, placeholder for cache R/W data in use
85 by G4PhysicsVector and derivates. Modified G4PhysicsVector and
86 G4LPhysicsFreeVector accordingly.
87 + Moved interpolation methods to inline in G4PhysicsVector.
88 + More safe numerical computation of A13() and logA() methods in G4Pow.
89 + Changed date for release 9.4-beta.
90
91 o Graphical Representations:
92 -------------------------
93 + Added support for new command "/vis/scene/add/digits", analogous to the
94 already-existing "/vis/scene/add/hits": added methods Draw() and
95 FilterDigi() for digits in G4VVisManager; added method AddCompound ()
96 in G4VGraphicsScene.
97 + Added method DispatchToModel(const G4VTrajectory&), i.e., without i_mode,
98 to G4VVisManager in order to distinguish usage and in preparation for
99 'i_mode' migration.
100
101 o Intercoms:
102 ---------
103 + G4UIManager: added field to get GUI Window session.
104 + Added used characters to 'tokenNum' in G4UItokenNum suppressing compiler
105 warnings of gcc-4.5.0.
106
107 o Interfaces:
108 ----------
109 + G4UIExective: changed order for session type; GUI session is prioritized.
110 + G4VBasicShell: implemented improvements for command completion.
111 + G4Qt: added a link to G4UIQt
112 + G4UIQt: added tab widgets for visualization. Added new command in help
113 tree for immediate update of the tree. Fixed warning in standard-output
114 during viewer creation and fixed flush problem. Fixed recursive repaint
115 problem. Fixed call to contructor QKeySequence() in AddButton() to
116 allow for porting on gcc-4.5.0.
117
118 o Materials:
119 ---------
120 + G4MaterialPropertyVector: removed allocation of temporary helper object
121 and modified GetAdjacentBins() to allow for a value to match a bin
122 exactly. Measured 21% CPU speed-up for optical processes.
123 + G4OpticalSurface: changed GetAngularDistributionValue(), no longer
124 dereferencing a pointer but returning the value at the array index.
125 + G4NistMaterialBuilder: added 6 new materials.
126 + G4NistMaterialBuilder, G4NistManager: added method
127 GetMeanIonisationEnergy(). Added material G4_LUCITE.
128 + G4ionisParamMat, G4DensityEffectData: added possibility to access density
129 effect data in the case when pure material is not defined via NIST; atom
130 number and state of such materials are checked.
131 + G4DensityEffectData: fixed method GetIndex(Z, state) for Hydrogen
132 and solid states, renamed it to GetElementIndex().
133 + G4IonisParamMat: added member and method GetInvA23(); use
134 GetElementIndex().
135 + G4IonisParamElm: use mean excitation energy from NIST DB; addressing a
136 problem reported for mean energy deposition in compound materials.
137 + G4AtomicShells: improved performance by adding indexing array.
138 + G4Element: moved include of G4AtomicShells header to the source.
139
140 o Particles:
141 ---------
142 + Allow creation of shortlived particles other than in 'PreInit' state.
143 + ElectronOccupancy in G4DynamicParticle is now created on demand, i.e.
144 it is not created at construction of G4DynamicParticle but when
145 AddElectron() or RemoveElectron() are invoked.
146 + Fixed problems that error messages appear in cout and not in cerr.
147 + Added anti-nuclei as short-lived particles.
148 + G4MuonRadiativeDecayChannelWithSpin: corrected sign error.
149 + Code cleanup in G4DynamicParticle constructors.
150
151 o Persistency:
152 -----------
153 + Added G4GenericTrap among the set of supported solids in both GDML reader
154 and writer, treating as 'arb8' GDML type.
155 + Corrected dump of division axis in GDML writer.
156 + ASCII module: added missing virtual destructor to G4tgbDetectorBuilder.
157
158 o Physics Lists:
159 -------------
160 + Moved QGSP_FTFP_BERT list to supported (was experimental).
161 + Removed previously blocked lists (FTFP_EMV, QGSC_EFLOW, QGSP_EMX).
162 + Remove obsolete lists, except QGSP (now blocked) and QGSC_CHIPS;
163 i.e. lists removed: FTFC, FTFP, LHEP_BERT_HP, LHEP_BERT, LHEP_PRECO_HP,
164 QGSC_EMV, QGSC, QGSC_QGSC, QGSP_BERT_DIF, QGSP_BERT_NQE,
165 QGSP_DIF, QGSP_EMV, QGSP_EMV_NQE, QGSP_NQE, QGSP_QE
166 + New physics list QGSP_BERT_CHIPS: use CHIPS inelastic for all "misc"
167 particles, including anti-proton, anti-neutron and hyperons.
168 Also use interface to CHIPS cross-sections for Kaons.
169 Added classes: QGSP_BERT_CHIPS, HadronPhysicsQGSP_BERT_CHIPS, and
170 G4MiscCHIPSBuilder; modifed G4PhysListFactory accordingly.
171 + Introduced new constructor for all builders with verbosity argument.
172 Existing constructors are kept, but updated default arguments to avoid
173 ambigous signatures. Changed physics-lists to use the new constructor.
174 Introduced new constructor for G4NeutronTrackingCut.
175 + Replaced G4HadronQElasticPhysics with G4QElasticPhysics and G4IonPhysics
176 with G4QIonPhysics in the CHIPS physics-list
177 Bug fix for the virtual destructor in G4QElasticPhysics & G4QIonPhysics.
178 Particles are restricted to SU(3) hadrons (no pi0 & eta) in
179 G4QElasticPhysics.
180 Fix in G4QPhotoNuclearPhysics to reset particles iterator.
181 + G4EmStandardPhysics_option2: added G4WentzelVIMscModel and 'RangeFactor'
182 set to 0.04 for e+-.
183 + G4EmLivermorePhysics, G4EmPenelopePhysics, G4EmDNAPhysics,
184 G4EmLivermorePolarizedPhysics: added G4GoudsmitSaundersonMscModel for e+-;
185 added 1 MeV upper limit for the Livermore ionisation model (was 1 GeV).
186 + Revised QGSP_FTFP_BERT and FTFP_BERT lists to use CHIPS G4QInelastic for
187 all "misc" particles, including anti-proton, anti-neutron and hyperons,
188 and use interface to CHIPS cross-sections G4QHadronInelasticDataSet for
189 kaons. Required changes to respective HadronPhysics* classes.
190 + LBE: substituted obsolete G4MultipleScattering by particle wise processes.
191 + QBBC: disabled multi-fragmentation model of deexcitation.
192 + G4FTFPNeutronBuilder, G4FTFPPiKBuilder, G4FTFPProtonBuilder,
193 G4QGSPNeutronBuilder, G4QGSPPiKBuilder, G4QGSPProtonBuilder, G4QGSBuilder:
194 added deletion of G4ExcitationHandler and G4QGSMFragmentation; added
195 deletion of neutron builder for QGSP_BERT, FTFP_BERT, QGSP_FTFP_BERT.
196
197 o Electromagnetic Processes:
198 -------------------------
199 + Adjoint:
200 o G4AdjointhMultipleScattering: removed unused header.
201 + High Energy:
202 o New model G4ICRU73NoDeltaModel, derived from G4ICRU73QOModel.
203 + Low Energy:
204 o Added four new models (gamma ray models Compton, GammaConversion,
205 PhotoElectric, Rayleigh), upgrades of G4Penelope from version 2001 to
206 version 2008.
207 o Added MinEnergyCut() method to G4PenelopeIonisationModel. Small (minor)
208 changes to other Penelope models (mainly clean-up).
209 Removed useless call in G4PenelopeIonisationModel which triggered fake
210 warning messages.
211 o Updated public interface of G4LivermorePhotoElectricModel.
212 Removed possibility to use custom cuts for fluorescence/Auger.
213 Main cuts from G4ProductionCutsTable are always used, for consistency.
214 o New G4PenelopeOscillator* classes (Beta version) to manage
215 multi-element atomic oscillators used in Penelope Compton and
216 Ionisation models. Compliant with Penelope-2008.
217 o Added dummy method ComputeCrossSectionPerAtom() in
218 G4PenelopeRayleighModel, never inkoved in tracking and issuing a
219 warning if users access it via G4EmCalculator.
220 o Clean-up in Penelope models; explicitely set Auger flag to false in
221 constructor.
222 o Fixed initialisation order in some models' constructor to fix Valgrind
223 run-time errors reports.
224 o Fixed bugs in G4AtomicDeexcitation and G4AugerTransition.
225 o G4DNA processes:
226 - Added new prototype excitation model for electrons in
227 G4DNABornExcitationModel. Will be fully released in December.
228 - Corrected G4DNABornIonisationModel for maximum kinetic energy
229 transfer.
230 - Modified method declaration in G4DNABornExcitation. Modified electron
231 correction in G4DNAMillerGreenExcitation.
232 - Extended search range for maximum of DCS in G4DNARuddIonisationModel.
233 - Changed default parameters in G4DNAEmfietzoglouExcitationModel.
234 Modified initialisation of e- Emfietzoglou excitation model to fix
235 memory leaks.
236 - Changed computation of scattering angle in G4DNAChampionElasticModel.
237 - Replaced hard coded masses in G4DNADingfelderCharge* classes.
238 o New PIXE developments:
239 - G4ecpssrKCrossSection and G4ecpssrLiCrossSection classes: these
240 classes substitute the G4ecpssrCrossSection class, fixing existing
241 bugs and improving the goodness of the results especially at higher
242 energies.
243 The Geant4 PIXE developers are really thankful to Maria Grazia Pia
244 for searching for bugs in the previous Geant4 release, pointing
245 existing problems and propose solution in a very collaborative way
246 in: M.G.Pia et al., CHEP-2009 conference, March 2009, Prague (Czech
247 Republic).
248 - G4empCrossSection and G4teoCrossSection classes: these two classes,
249 deriving from G4VhShellCrossSection, provide the interface to
250 empirical ionization cross sections (Orlic for L shells and Paul
251 for K).
252 - G4hShellCrossSection, G4hShellCrossSectionDoubleExp,
253 G4hShellCrossSectionDoubleExpData, G4hShellCrossSectionExp,
254 G4hShellCrossSectionExpData classes are now discontinued.
255 - G4hLowEnergyIonisation has been updated to follow the new design
256 and let the user chose which model to use for the calculation of shell
257 ionization cross section through the method SelectShellIonisationCS().
258 Dependencies on old methods for cross sectiuon calculation have been
259 removed.
260 - Bugs fixes in G4OrlicLiCrossSection and G4PaulKCrossSection.
261 o Fix in G4AugerTransition to cure crash on Windows.
262 o Added missing virtual destructors where necessary.
263 o Corrected return value case in method GetPhotoElectronDirection()
264 in G4PhotoElectricAngularGeneratorSauterGavrila.
265 Addressing problem report #1120.
266 o Requires new G4LEDATA data set, version 6.13.
267 + Muons:
268 o G4MuPairProductionModel: added sampling recoil of a primary particle
269 o G4MuIonisation: use G4ICRU73QOModel for mu- for E< 0.2 MeV.
270 + Polarisation:
271 o Fix in G4ePolarizedIonisation to use default vector size of
272 G4VEnergyLossProcess and avoid size mismatch in G4LossTableBuilder.
273 + Standard:
274 o G4GoudsmitSaundersonMscModel: fixed problems of small angle theta
275 distributions. Improved numerical stability of computations for small
276 angles by direct cross-section calculation, now inverse of the inverse
277 angular sampling without large angle rejection method longitudinal
278 displacement is computed exactly from <z>.
279 o G4GoudsmitSaundersonTable: improved numerical stability by minimum of
280 used arrays in computation within the dichotomy finding method.
281 Optimized code to improve speed by addition extra class members.
282 o G4eBremsstrahlungModel: reduced 'minThreshold' to 0.1 keV.
283 o G4MollerBhabhaModel: reduced minimum cut value to mean ionisation
284 potential.
285 o G4WentzelVIModel: added protections; added DefineMaterial() call to
286 cross-section class.
287 o G4ASTARStopping, G4PSTARTStopping: replaced C-arrays with
288 G4PhysicsVector with Spline interpolation. Reviewed names of materials
289 (G4_PHOTO_EMULSION, G4_He, G4_NYLON-6-6).
290 o Fixed G4_O data in G4ASTARStopping. Fixed G4_Pt and G4_PROPANE data in
291 G4PSTARStopping.
292 o Cleanup in GetElectronicDEDX() method in G4WaterStopping.
293 o G4eMultipleScattering, G4hMultipleScattering: improved printout at
294 initialisation. Removed old unused header of G4UrbanMscModel in
295 G4hMultipleScattering.
296 o G4eBremsstrahlungRelModel, G4MollerBhabhaModel: set minimum cut value
297 to 0.1 keV.
298 o G4eBremsstrahlungModel: fix in SelectRandomAtom() method.
299 Addressing problem report #1115.
300 o G4UrbanMscModel93: added randomization of step limit for the first
301 step in any volume for option "UseDistanceTo Boundary".
302 o G4BraggIonGasModel, G4BetheBlochIonGasModel: new ionisation models for
303 low density media.
304 o G4BraggModel: above 2 MeV use ICRU'49 parameterisation for all atoms.
305 o New model G4ICRU73QOModel for anti-particles
306 o G4hIonisation: use new G4ICRU73QOModel for negatively charged particles
307 instead of G4BraggModel, which used to be applied for positevely
308 charged particles only. This modification provides simulation of
309 Barkas effect at low energies (before the effect was simulated at
310 higher energies in G4BetheBlochModel).
311 The high energy limit for the new model is the same as for G4BraggModel
312 (2 MeV for protons/anti-protons).
313 o G4WentzelOKandVIxSection: new class to compute cross sections and
314 sample scattering angle.
315 o G4WentzelVIModel, G4eCoulombScatteringModel, G4CoulombScatteringModel:
316 use new class G4WentzelOKandVIxSection.
317 o G4WentzelVIModel: optimized method of step limitation.
318 o G4WentzelVIModel, G4eCoulombScatteringModel: added momentum dependent
319 limit of scattering angle between single and multiple scattering which
320 allows to use G4WentzelVIModel with optical model of hadron scattering.
321 o G4PAIModel, G4PAIPhotonModel: added printout for the model
322 initialisation.
323 o Removed obsolete models: G4UrbanMscModel, G4UrbanMscModel2,
324 G4UrbanMscModel71, G4MultipleScattering, G4ComptonScattering52,
325 G4PolarizedComptonScattering.
326 + Utils:
327 o G4VMscModel, G4VMultipleScattering: set skin=1.0 as default.
328 o G4LossTableManager: added new method GetNumberOfBinsPerDecade(), which
329 is used in G4VEmModel for initialisation of G4EmElementSelector.
330 Addressing problem report #1115.
331 Added methods PreparePhsyicsTables(), BuildPhysicsTables(), fixing
332 initialisation of models via G4EmConfigurator.
333 o G4EmProcessOptions: removed extra initialisation code, already existing
334 in G4LossTableManager.
335 o G4VEnergyLossProcess, G4VEmProcess, G4VMultipleScattering: added
336 calls to new G4LossTableManager methods PreparePhsyicsTables() and
337 BuildPhysicsTables().
338 o Added method GetCurrentElement() in G4VEmProcess, G4VEnergyLossProcess
339 and G4VEmModel classes.
340 o G4VEmProcess: cleanup printout at initialisation for scattering process.
341 o G4VEmModel: added method ChargeSquareRatio() to access current charge
342 of an ion; use this method in G4VEnergyLossProcess.
343 o G4VEnergyLossProcess: call CorrectionsAlongStep() only for ions (minor
344 CPU saving). Use the same method to build cross section table
345 as DEDX table (use copy constructors to reduce number of calls to exp()).
346 o G4EmCalculator: fix in GetCrossSection() method.
347 o G4EmElementSelector: use Spline flag to construct vectors probabilities.
348 o G4EmModelManager: do not use min energy cut defined by models, so
349 production threshold is defined only by range to energy conversion and
350 is limited only by low limit of energy threshold defined in 'cut'
351 category.
352 o G4EmConfigurator: fix for case of more than one model added per a
353 process.
354 o G4EmCorrections: moved G4AtomicShell header into source.
355 + Xrays:
356 o Included scintillation rise time to G4Scintillation.
357 o Use std namespace for mathematical functions explicitly.
358
359 o Hadronic Processes:
360 ------------------
361 + Removed obsolete code for 'leading_particle' model.
362 + cross_sections
363 o G4NeutronElasticXS, G4NeutronInelasticXS, G4NeutronCaptureXS: added
364 path to new data set through environment variable G4NEUTRONXSDATA.
365 o Implemented integer Z and A transition to G4CrossSectionDataStore.
366 o G4UPiNuclearCrossSection: fixed memory leak at destruction.
367 o Updated G4GlauberGribovCrossSection for anti-protons.
368 + management
369 o G4HadronicProcess: added methods CheckEnergyMomentumConservation(),
370 SetEpReportLevel(), SetEnergyMomentumCheckLevels() and
371 GetEnergyMomentumCheckLevels(), which implement energy/momentum
372 checking. Some code cleanup.
373 o New G4HadronicEPTestMessenger class to provide energy/momentum test
374 commands available in UI.
375 + models/cascade
376 o Replaced all uses of bindingEnergy() (local Bertini method) with the
377 Geant4 standard G4NucleiProperties::GetBindingEnergy(A,Z) in classes
378 G4IntraNuclearCascader, G4InuclCollider, G4NucleiModel, G4Fissioner,
379 G4EquilibriumModel and G4NonEquilibriumModel.
380 G4Fissioner still uses Bertini method bindingEnergyAsymptotic().
381 o G4Diproton, G4Dineutron, G4UnboundPN: new G4ParticleDefinition
382 subclasses, which implement the Bertini-specific dibaryon states.
383 o G4ElementaryParticleCollider: replaced original (incorrect) pp, pn, nn
384 2-body to 2-body scattering angular distributions with a new
385 parameterization of elastic scattering data using the sum of two
386 exponentials.
387 o Improved angular distributions for 2-body final states of pi-nucleon,
388 nucleon-nucleon, kaon-nucleon anf hyperon-nucleon scattering.
389 o Replaced G4CascadeMomentum internal class with G4LorentzVector.
390 o Completed first stage of migration from using internal Bertini particle
391 types to Geant4 standard particle types.
392 o Energy/momentum checks added which remove large energy non-conservation
393 events.
394 o Improved memory management: removed allocation of strings in various
395 constuctors; replaced several cases of return-by-value with const or
396 non-const reference, or by use of buffers.
397 o CPU speed improvements from the removal of unnecessary class
398 instantiations.. Code re-organization to permit more speed improvements
399 in the future.
400 + models/chiral_inv_phase_space
401 o Updated proton elastic and CHIPS parameters.
402 o Implemented anti-baryon elastic interactions.
403 o Added pion elastic and fixed a bug in CHIPS fragmentation.
404 o Implemented isotope wise CHIPS elastic for neutrons.
405 o Fix in G4QElasticCrossSection in parameter order for nH.
406 o Bug fix in G4QNeutronNuclearCrossSection for Ba isotopes.
407 o Bug fix for K0 in G4QKaonMinusElasticCrossSection::GetExchangeT().
408 o Bug fix in G4QNucleus::ChoosePosition() for looping.
409 o Fix to use of Z+N instead of N for A.
410 o Corrected Titanium and Zirconium isotopes in G4QIsotope.
411 o Added decay of Chipolino in the G4QEnvironment, when A_env=0.
412 o Bug fix following G4NucleiProperties warning for A=0, Z=0.
413 o Bug fix in G4QPDGCode and G4QEnvironment for Omega and Sigma;
414 when mass is small for Lambda andSigma+, use Xi0,p.
415 o Correction in G4QElastic for K0 elastic cross-sections.
416 o Corrected treatment of vacuum in fragmentation module.
417 o nn is decayed in G4QLowEnergy; Omega- is included in G4QElastic;
418 N neutrons (A=N, Z=0) are decayed in G4QLowEnergy.
419 o Bug-fix in G4QLowEnergy: pions as secondaries.
420 o Bug-fix in K0 elastic & Ion-Ion Elastic.
421 + models/coherent_elastic
422 o Use G4Q(Proton/Neutron)ElasticCrossSection instead of
423 G4QElasticCrossSection; fixed initialization problem for
424 G4QNeutronElasticCrossSection.
425 o G4UHadronElasticProcess: fixed CHIPS warning for Cu, due to wrong
426 isotope sected; addressing problem report from ALICE.
427 + models/de_excitation
428 o G4StatMFMacroTemperature: cleanup logic of solving equation for
429 temperature; moved constructors and destructor to source.
430 o G4ProtonEvaporationProbability, G4DeuteronEvaporationProbability,
431 G4TritonEvaporationProbability, G4He3EvaporationProbability,
432 G4AlphaEvaporationProbability: return back to published variant
433 parameterization of inverse cross section (OPT3, Kalbach).
434 o G4FermiFragmentsPool: extended list of stable fragments.
435 o G4UnstableFragmentBreakUp: new class to decay exotic fragment
436 (like 2n or 2p).
437 o G4DiscreteGammaTransition: make transition depended on Z and A (before
438 was only Z) and added energy tolerance
439 o G4VGammaDeexcitation: rewritten kinematic of 2-body decay.
440 Fix to take into account electron mass in the case of electron emission.
441 Take into account bounding energy of electron in the case of electron
442 emission; fixed kinematic.
443 o G4DiscreteGammaTransition, G4DiscreteGammaDeexcitation,
444 G4ContinuumGammaDeexcitation: set energy tolerance 1 keV. More accurate
445 Lorentz computations. Define destructors to be virtual.
446 o G4DiscreteGammaTransition: removed unphysical corrections of gamma
447 energy; fixed default particle as gamma; avoid subtracting binding
448 energy in case of electron emission.
449 o G4ExcitationHandler: apply FermiBreakUp to fragments with A>1 (before
450 was A>4) in order to reduce number of fake gamma produced in
451 deexcitation of light fragments; added parameter 'minExcitation' equal
452 to 1 keV. Added check on stability of primary; do evaporation if
453 FermiBreakUp cannot deexcite a fragment. Added SetParameters() method.
454 o G4Evaporation: rewritten BreakUp() method; added Initialise() method at
455 construction, to setup all options and not at run time.
456 Added InitialiseEvaporation() method to setup decay channels; changed
457 order of decay channels: first photon evaporation, then fission,
458 finally all other channels as before. Improved condition on how to
459 stop deexcitation loop.
460 Added call to G4UnstableFragmentBreakUp if natural abundances of cold
461 fragment is zero and Z < 20; optimized logic of stopping of evaporation
462 loop. Set as a default variant evaporation combining standard plus GEM
463 probabilities.
464 o G4PhotonEvaporation: added correction of electron state after emission.
465 o G4VEvaporationChannel, G4PhotonEvaporation: added two new virtual
466 methods EmittedFragment() and BreakUpFragment().
467 o G4FermiConfiguration: parameter of Coulomb energy Kappa is changed from
468 1 to 6 according to recommendation of original author of the model
469 A.Botvina.
470 o G4FermiPhaseSpaceDecay: improved model of sampling of kinetic energy.
471 Cleanup of the code to use G4Pow.
472 o G4FermiFragmentsPool: fix for fragment 111.
473 o G4StatMFFragment, G4CompetitiveFission, G4EvaporationProbability,
474 G4GEMProbability: corrected inclusion of headers.
475 o G4E1Probability: code cleanup and optimisation by usage of G4Pow,
476 integer A and introduction of const members. Added numerical protection
477 to avoid division by zero.
478 o G4GEMProbability: fixed numerical problem (division by zero), code
479 cleanup and optimisation by usage of G4Pow and integer Z,A.
480 o Code cleanup. Moved constructors and destructors to source files for
481 virtual interfaces.
482 + models/im_r_matrix
483 o Removed empty source file for G4VScatterer.
484 Synchronised developments to HEAD version.
485 + models/incl
486 o Nuclear deformation and shell effect data reader now constructs the
487 corresponding data tables correctly.
488 o Added some internal logging facilities to INCL (disabled by default).
489 o Added missing virtual destructor to base classes where necessary.
490 + models/management
491 o G4HadronicInteraction: added two methods, GetEnergyMomentumCheckLevels()
492 and SetEnergyMomentumCheckLevels() in order to implement checking
493 of energy/momentum conservation.
494 o G4VPreCompoundModel: moved constructor and destructor to source.
495 + models/neutron_hp
496 o Modified sampling in G4NeutronHPInelasticCompFS.
497 o Fix bug about incidence energy in G4NeutronHPEnAngCorrelation.
498 + models/parton_string/diffraction
499 o Added missing virtual destructor to G4DiffractiveHHScatterer.
500 + models/parton_string/hadronization
501 o Improved Lund string fragmentation.
502 o Fixed inconsistency between LightFragmentationTest and Lund
503 fragmentation. Fixed problems of energy non-conservation in FTF.
504 + models/parton_string/qgsm
505 o Remove unused class G4PartonStringAnnihilator.
506 + models/pre_equilibrium
507 o G4PreCompoundModel: moved constructor and destructor to source.
508 o Removed unused dummy classes G4VPreCompoundIon and
509 G4VPreCompoundNucleon.
510 o G4PreCompoundProton, G4PreCompoundDeuteron, G4PreCompoundTriton,
511 G4PreCompoundHe3, G4PreCompoundAlpha: return back to published variant
512 OPT3 (Kalbach) parameterization of inverse cross section.
513 + models/radioactive_decay
514 o G4RadioactiveDecay:
515 - In LoadDecayTable() create a decay table for isomers not included
516 in RDM database and assume they all under go IT decay.
517 - After DoDecay() check if there is any secondary produced.
518 Kill the track if not to prevent infinite loop.
519 - Insert a special treatment for K-40 beta decay; applied SetICM(),
520 SetARM() and SetHLThreshold() to a decay channel.
521 Addresses problem report #1068.
522 - Make sure the propertime is positive; negative case occures when the
523 isomer is not in RDM database and its f-l is set to -1 by default.
524 - Corrected typo in declaration.
525 o G4NuclearDecayChannel: added initialisation to all three constructors.
526 o G4RadioactiveDecay, G4NuclearDecayChannel:
527 - Limit the shell index to < 7, as required by the ARM. Changed to use
528 BreakUp() rather than BreakItUp() so to limit to one transition per
529 step when ICM is applied. Addresses problem report #1001.
530 - Added private member data 'applyICM', 'applyARM' and
531 'halflifethresold' with their modifiers.
532 o G4RadioactiveDecayMessenger: added the UI commands for SetICM, SETARM
533 and SetHLThreshold.
534 + models/util
535 o G4Fragment: do not add any shift to excitation energy but use direct
536 computation (this is needed to avoid infinite loop in gamma
537 deexcitation); use G4NucleiProperties to access or compute ground
538 state mass. Allow e- as a fragment.
539 Added inline method ComputeGroundStateMass(); added accessors for
540 integer Z and A; added ExcitationEnergyWarning() method.
541 Minor speedup by adding member and access method to GroundStateMass.
542 Some code cleanup: single return in inline methods.
543 + util
544 o Added interface for integer A&Z to G4Nucleus, and modified G4LightMedia,
545 G4HadronicWhiteBoard and G4ReactionDynamics to use the new interface.
546
547 o Optical Processes:
548 -----------------
549 + Fix for backpainted surfaces to avoid applying twice reflectivity.
550 Addressing problem report #1114.
551 + Refashioned code in the case of type 'dielectric_dielect'.
552 + Fixed sampling of 'theFacetNormal' for 'polishedbackpainted' material
553 in G4OpBoundaryProcess::DielectricDielectric() method. Address problem
554 reported on Hypernews Optical Processes Forum, thread #334.
555 + Modified G4OpBoundaryProcess to call ProposeLocalEnergyDeposit() every
556 time a photon is in 'fStopAndKill' state because of NoRINDEX. This will
557 trigger scoring when a photon encounters a volume not defined as an
558 optical medium.
559
560 o Run
561 ---
562 + Corrected printing of number of events processed on run abortion.
563 + Fixed definition of path for Windows in G4RunManager for random seeds
564 directory: use '\' instead of '/' and suitable system command.
565 + Use "const G4String&" as arguments and return value wherever applicable
566 in G4RunManager and G4RunManagerKernel.
567
568 o Tracking
569 --------
570 + G4VTrajectory, G4Trajectory, G4SmoothTrajectory: added deprecation
571 message, being printed via G4Exception only once, and only if a user
572 invokes with a non-zero value of 'i_mode' in DrawTrajectory().
573
574 o Visualization:
575 -------------
576 + management:
577 o Added new "/vis/open" command for OpenGL viewers, "/vis/open OGL".
578 This new form allows the same macro to be used whether one is on
579 Linux or Windows (calling OGLSX on Linux and OGLSWin32 on Windows).
580 When the application has been built with Qt, it will use the Qt form
581 of OpenGL; when built with Motif, it will use the Motif form of OpenGL.
582 Also added options OGLI and OGLS to force Immediate or Stored modes.
583 The user is still free to use the older, specific viewer names, such
584 as OGLIX, but the simple form, OGL, will give the most portable macros.
585 o Added new "/vis/open" command for OpenInventor, "/vis/open OI".
586 This new form allows the same macro to be used whether one is on Linux
587 or Windows (calling OIX on Linux and OIWin32 on Windows).
588 o Added "/vis/scene/add/digis" and "/vis/filtering/digi" commands,
589 analogous to the already-existing commands "/vis/scene/add/hits" and
590 "/vis/filtering/hits". As with hits, it remains the user's
591 responsibility to provide the digitisation classes.
592 Added method AddCompound(const G4VDigi&) to drivers.
593 o Introduced DispatchToModel without 'i_mode'. The archaic form
594 G4VTrajectory::DrawTrajectory(i_mode) is replaced by the newer form,
595 G4VTrajectory::DrawTrajectory(). 'i_mode' used to be a parameter to
596 control whether the trajectory was drawn as a line, a line plus step
597 points, or only step points:
598 - i_mode > 0 meant draw lines and points, size of points in
599 pixels = abs(i_mode)/1000
600 - i_mode = 0 meant draw only lines
601 - i_mode < 0 meant draw only points, size of points in
602 pixels = abs(i_mode)/1000
603 Since release 8.1, better control has been available from the command
604 "/vis/modeling/trajectories". Since release 5.0, 'i_mode' less than
605 1000 has in fact drawn no points and 'i_mode' of 1000 has drawn points
606 that were so small (a single pixel wide) that they were overshadowed
607 by the trajectory itself except at endpoints of the trajectory or
608 where the trajectory made a sharp change of direction.
609 Use of 'i_mode' is now trapped and a warning gets printed.
610 o Changed order of flags to follow G4UIExecutive.
611 o G4VisManager, G4VisExecutive: introduced optional verbosity string
612 argument in constructor; made 'fVerbosity' and GetVerbosity() static.
613 o Added virtual destructors to fix compilation warnings.
614 + modeling:
615 o Added G4DigiModel and G4DigiFilterFactories.
616 o Added default colours to G4TrajectoryDrawByParticleID.
617 o Replace polyhedra with solids for sections and cutaways.
618 o Trap use of 'i_mode' and print warning.
619 + HepRep:
620 o Added command "/vis/heprep/renderCylAsPolygons".
621 + gMocren:
622 o Removed dependency on G4VisManager. Improved printout.
623 + OpenGL:
624 o Some improvements with auto rotation mode.
625 o G4OpenGLQtViewer: better inclusion of new tabs in UI part.
626 Many improvements to OpenGL Qt.
627 o Speed improvements for polymarkers (e.g., trajectories).
628 o Corrected strdup usage in G4OpenGLViewer.
629 o Use generic section and cutaway algorithm.
630 o Added protection against multiple repaint call, and protection against
631 resizeGl with bad values.
632 + OpenInventor:
633 o Added protection against repeated initialisation.
634 + RayTracer:
635 o Added missing virtual destructor to G4VRTScanner, G4RTXScanner and
636 G4RTSimpleScanner classes.
637
638 o Data Sets:
639 ---------
640 + G4EMLOW-6.13:
641 o Updated PDF.dat to msc_GS module.
642 o New directory and data files needed by ionisation cross section
643 models for PIXE; added data tables in the directories uf, kpcsPaul
644 and kacsPaul included in the 'pixe' dir.
645 o Added 'sigmadiff_cumulated_elastic_e_champion.dat' and
646 temporary 'sigma_excitation_e_born.dat' to dna module.
647 o Added data files in the penelope module, necessary for
648 Penelope08 models for gamma rays.
649 + G4NEUTRONXS-1.0:
650 o New data set for Evaluated neutron cross section data on natural
651 composition of elements.
652
653 o Examples:
654 --------
655 + Various fixes, improvements, adoption of new features.
656 + Updated visualization usage in most examples, including macro sections
657 the user can uncomment to activate additional features.
658 + Adopt G4UIExecutive to initialise UI sessions.
659 + Migrated physics-lists to use particle-based multiple-scattering
660 processes.
661 + advanced/human_phantom
662 o Added missing includes, causing compilation error.
663 o Corrected commands in some macros.
664 + extended/electromagnetic/TestEm0
665 o New physics-lists for EM standard options 0,1,2,3.
666 o RunAction: printout both GetCrossSection() and ComputeCrossSection().
667 Reverse order of calls, first ComputeCrossSection(), then
668 GetCrossSection().
669 + extended/electromagnetic/TestEm1
670 o RunAction: replaced 'ProcessCount' with a map.
671 o Introduction of G4UIExecutive in main().
672 + extended/electromagnetic/TestEm2
673 o Added histos rms on profiles (histos numbering is changed)
674 and new scripts.
675 + extended/electromagnetic/TestEm3
676 o Added PhysListEmStandardGS and PhysListEmStandardWVI.
677 o Added printout of mean number of gamma, e-, e+.
678 + extended/electromagnetic/TestEm7
679 o Added extra EM option "ionGasModels", which disables effective ion
680 charge and enables use of new models G4BraggIonGasModel,
681 G4BetheBlochIonGasModel.
682 o Added extra macro ionGasC12.mac.
683 o Fixed setup for histograms through JAIDA.
684 + extended/electromagnetic/TestEm8
685 o PhysicsList, Em8DetectorConstruction: renamed "VertexDetector" with
686 "GasDetector"
687 o Added cut per region in TestEm8.in.
688 + extended/electromagnetic/TestEm11
689 + extended/electromagnetic/TestEm12
690 o Added lists PhysListStandardGS, PhysListStandardSS, PhysListStandardWVI.
691 + extended/electromagnetic/TestEm13
692 + extended/electromagnetic/TestEm14
693 o PhysicsList: extend 'ProductionCuts' down to 100 eV.
694 Removed non pertinent EmOptions.
695 o PhysListEmStandard, Livermore, Penelope: all processes registered as
696 discrete (i.e., no continuous Eloss).
697 o RunAction: replaced 'ProcessCount' with a map.
698 o Cleanup in SteppingAction. Updated README.
699 + extended/eventgenerator/HepMC
700 o Updated to make use of HepMC-2.06.00.
701 o Use QGSP physics-list.
702 + extended/eventgenerator/particleGun
703 o New example demonstrating three different ways of usage of
704 G4ParticleGun, shooting primary particles in different cases.
705 + extended/exoticphysics/monopole
706 o Substituted QGSP list by QGSP_BERT.
707 o Added new classes for monopole G4MonopoleEquation,
708 G4MonopoleFieldSetup and G4MonopoleTransportation.
709 o Added test on ionisation of heavy highly charged particle; some cleanup.
710 + extended/hadronic/Hadr01
711 o Cleanup of physics-list according to last update to physics_list
712 library.
713 + extended/medical/DICOM
714 o Added function to read nested items (defined and undefined)
715 o Removed dependencies on CONQUEST
716 o DICOM handler can now read whichever DICOM file (PT,CT,DR,CR,US,MR... )
717 + extended/medical/electronScattering
718 o Added PhysListEmStandardWVI.
719 o RunAction::PrintFluence(): print unormalized fluence per event.
720 + extended/medical/electronScattering2
721 o New example for simulation of precision electron scattering benchmark
722 with minimal user code.
723 + extended/medical/fanoCavity
724 + extended/medical/fanoCavity2
725 o Introduced PhysListEmStandard_option2 (UrbanMscModel93 without options)
726 and PhysListEmStandard_WVI (using WentzelVIModel).
727 o Added to run01.mac all physics lists choice.
728 + extended/parallel/MPI
729 o General code review.
730 o mpi_interface: OpenMPI as default MPI library instead of LAM/MPI;
731 improved /mpi/status command (added waste of CPU, time measurement);
732 introduced /mpi/wait command for waiting until "beamOn" ends;
733 improved macro file parser (same parser as G4UIbatch; fixed unexpected
734 behavior at the end of batch mode); changed "beamOn" behavior for better
735 performance (thread-out for interactive, on-thread for batch).
736 o exMPI01: use G4UIcsh instead of G4UItcsh since OpenMPI is now default;
737 use G4eMultipleScattering instead of obsolete G4MultipleScattering.
738 o exMPI02: use G4UIcsh instead of G4UItcsh since OpenMPI is now default.
739 + examples/extended/persistency/gdml/G01
740 o Added G4GenericTrap to the solids.gdml sample.
741 + examples/extended/persistency/gdml/G03
742 o Corrected selection of G4UItcsh in main(), to fix problem on Windows.
743 + examples/novice/N04
744 o Replaced QGSP list with QGSP_BERT.
745
746
747 ----------------------------------------------------------------------------
748 Migration Notes
749 ---------------
750
751 o Obsolete classes G4MultipleScattering, G4UrbanMscModel and G4UrbanMscModel2
752 are removed in this release; multiple-scattering particle-based processes,
753 G4eMultipleScattering, G4hMultipleScattering and G4MuMultipleScattering are
754 now mandatory; G4UrbanMscModel93 is now introduced.
755 o The visualization trajectory modeling command
756 "/vis/modeling/trajectories/create/drawByParticleID"
757 used to default all trajectories to grey, with the user having to
758 explicitly set any other color code. While the user can still set any
759 wished color code, the default has been improved to:
760 [e-/red; e+/blue; proton/cyan; gamma/green; neutron/yellow;
761 pi+,pi-,pi0/magenta; other/grey].
762 o In some examples, visualization that used to draw trajectories as simple
763 lines now also draws step points. Users who wish to disable step point
764 drawing can do so by commenting out a line in the visualization macro.
765
766 ----------------------------------------------------------------------------
767
768 Technical Notes
769 ---------------
770
771 o Official platforms:
772 + Linux, gcc-4.1.2, gcc-4.3.2.
773 Tested on 32 bits architectures and 64 bits architectures
774 (Intel or AMD) with the Scientific Linux CERN 5 (SLC5) distribution
775 (based on RedHat Linux Enterprise 5).
776 Versions of Geant4 have also been compiled successfully on other
777 Linux distributions, like Debian, Suse or other RedHat systems.
778 + MacOSX 10.6, gcc-4.2.1
779 + Windows/XP and CygWin Tools with: Visual C++ 9.0 (Visual Studio 2008)
780
781 o More verified configurations:
782 + Linux, gcc-4.5.0
783 + Linux, Intel-icc 11.1
784
785 o Geant4 9.4-beta-01 requires the installation of CLHEP-2.0.4.6.
786
787 Please refer to the Geant4 User Documentation:
788 http://cern.ch/geant4/support/userdocuments.shtml
789 for further information about using Geant4.
Note: See TracBrowser for help on using the repository browser.