Geant4  10.01.p02
tpia_misc.cc
Go to the documentation of this file.
1 /*
2 # <<BEGIN-copyright>>
3 # Copyright (c) 2010, Lawrence Livermore National Security, LLC.
4 # Produced at the Lawrence Livermore National Laboratory
5 # Written by Bret R. Beck, beck6@llnl.gov.
6 # CODE-461393
7 # All rights reserved.
8 #
9 # This file is part of GIDI. For details, see nuclear.llnl.gov.
10 # Please also read the "Additional BSD Notice" at nuclear.llnl.gov.
11 #
12 # Redistribution and use in source and binary forms, with or without modification,
13 # are permitted provided that the following conditions are met:
14 #
15 # 1) Redistributions of source code must retain the above copyright notice,
16 # this list of conditions and the disclaimer below.
17 # 2) Redistributions in binary form must reproduce the above copyright notice,
18 # this list of conditions and the disclaimer (as noted below) in the
19 # documentation and/or other materials provided with the distribution.
20 # 3) Neither the name of the LLNS/LLNL nor the names of its contributors may be
21 # used to endorse or promote products derived from this software without
22 # specific prior written permission.
23 #
24 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
25 # EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
26 # OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
27 # SHALL LAWRENCE LIVERMORE NATIONAL SECURITY, LLC, THE U.S. DEPARTMENT OF ENERGY OR
28 # CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 # OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
31 # AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
32 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
33 # EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34 # <<END-copyright>>
35 */
36 
37 #include "Randomize.hh"
38 
39 #include <float.h>
40 
41 #include <stdio.h>
42 #include <stdlib.h>
43 #include <string.h>
44 #include <cmath>
45 #include <tpia_target.h>
46 #include <tpia_misc.h>
47 
48 #include <string>
49 
50 #if defined __cplusplus
51 namespace GIDI {
52 using namespace GIDI;
53 #endif
54 
55 struct ZSymbol {
56  int Z;
57  //char *symbol;
58  std::string symbol;
59 };
60 
61 static const struct ZSymbol ZSymbols[] = { { 0, "n" }, { 1, "H" }, { 2, "He" }, { 3, "Li" }, { 4, "Be" }, { 5, "B" }, { 6, "C" },
62  { 7, "N" }, { 8, "O" }, { 9, "F" }, { 10, "Ne" }, { 11, "Na" }, { 12, "Mg" }, { 13, "Al" }, { 14, "Si" }, { 15, "P" },
63  { 16, "S" }, { 17, "Cl" }, { 18, "Ar" }, { 19, "K" }, { 20, "Ca" }, { 21, "Sc" }, { 22, "Ti" }, { 23, "V" }, { 24, "Cr" },
64  { 25, "Mn" }, { 26, "Fe" }, { 27, "Co" }, { 28, "Ni" }, { 29, "Cu" }, { 30, "Zn" }, { 31, "Ga" }, { 32, "Ge" }, { 33, "As" },
65  { 34, "Se" }, { 35, "Br" }, { 36, "Kr" }, { 37, "Rb" }, { 38, "Sr" }, { 39, "Y" }, { 40, "Zr" }, { 41, "Nb" }, { 42, "Mo" },
66  { 43, "Tc" }, { 44, "Ru" }, { 45, "Rh" }, { 46, "Pd" }, { 47, "Ag" }, { 48, "Cd" }, { 49, "In" }, { 50, "Sn" }, { 51, "Sb" },
67  { 52, "Te" }, { 53, "I" }, { 54, "Xe" }, { 55, "Cs" }, { 56, "Ba" }, { 57, "La" }, { 58, "Ce" }, { 59, "Pr" }, { 60, "Nd" },
68  { 61, "Pm" }, { 62, "Sm" }, { 63, "Eu" }, { 64, "Gd" }, { 65, "Tb" }, { 66, "Dy" }, { 67, "Ho" }, { 68, "Er" }, { 69, "Tm" },
69  { 70, "Yb" }, { 71, "Lu" }, { 72, "Hf" }, { 73, "Ta" }, { 74, "W" }, { 75, "Re" }, { 76, "Os" }, { 77, "Ir" }, { 78, "Pt" },
70  { 79, "Au" }, { 80, "Hg" }, { 81, "Tl" }, { 82, "Pb" }, { 83, "Bi" }, { 84, "Po" }, { 85, "At" }, { 86, "Rn" }, { 87, "Fr" },
71  { 88, "Ra" }, { 89, "Ac" }, { 90, "Th" }, { 91, "Pa" }, { 92, "U" }, { 93, "Np" }, { 94, "Pu" }, { 95, "Am" }, { 96, "Cm" },
72  { 97, "Bk" }, { 98, "Cf" }, { 99, "Es" }, { 100, "Fm" }, { 101, "Md" }, { 102, "No" }, { 103, "Lr" }, { 104, "Rf" }, { 105, "Db" },
73  { 106, "Sg" }, { 107, "Bh" }, { 108, "Hs" }, { 109, "Mt" } };
74 
75 /*
76 ************************************************************
77 */
79 
80  return( sizeof( ZSymbols ) / sizeof( struct ZSymbol ) );
81 }
82 /*
83 ************************************************************
84 */
85 const char *tpia_misc_ZToSymbol( int iZ ) {
86 
87  if( ( iZ < 0 ) || ( iZ >= tpia_misc_NumberOfZSymbols( ) ) ) return( NULL );
88  //return( ZSymbols[iZ].symbol );
89  return( ZSymbols[iZ].symbol.c_str() );
90 }
91 /*
92 ************************************************************
93 */
94 int tpia_misc_symbolToZ( const char *Z ) {
95 
96  int i, n = tpia_misc_NumberOfZSymbols( );
97 
98  for( i = 0; i < n; i++ ) {
99  //if( !strcmp( Z, ZSymbols[i].symbol ) ) return( ZSymbols[i].Z );
100  if( !strcmp( Z, ZSymbols[i].symbol.c_str() ) ) return( ZSymbols[i].Z );
101  }
102  return( -1 );
103 }
104 /*
105 ************************************************************
106 */
107 int tpia_miscNameToZAm( statusMessageReporting *smr, const char *name, int *Z, int *A, int *m ) {
108 
109  int i, n;
110  const char *p;
111  char s[1024] = "", *q, *e; /* Note 1) routine will fail when parts of a particle name can be longer than 1024. */
112 
113  n = sizeof( s ) - 1;
114 
115  *Z = *A = *m = 0;
116  if( !strncmp( "FissionProduct", name, 14 ) ) {
117  *Z = 99;
118  *A = 120;
119  return( 0 );
120  }
121  if( !strcmp( "gamma", name ) ) return( 0 );
122  for( p = name, q = s, i = 0; ( *p != '_' ) && ( i != n ); p++, q++, i++ ) *q = *p;
123  if( i == n ) { /* See note 1 above. */
124  smr_setMessageError( smr, NULL, __FILE__, __LINE__, 1, "Failed to find first '_' in particle name %s", name ); }
125  else {
126  *q = 0;
127  if( ( *Z = tpia_misc_symbolToZ( s ) ) < 0 ) {
128  smr_setMessageError( smr, NULL, __FILE__, __LINE__, 1, "Particle %s's symbol = '%s' not found", name, s ); }
129  else { /* Getting here implies that *p == '_'. */
130  for( p++, q = s; ( *p != '_' ) && ( *p != 0 ) && ( i != n ); p++, q++, i++ ) *q = *p;
131  if( i == n ) { /* See note 1 above. */
132  smr_setMessageError( smr, NULL, __FILE__, __LINE__, 1, "Failed to find second '_' in particle name %s", name ); }
133  else {
134  *q = 0;
135  if( strcmp( s, "natural" ) == 0 ) {
136  e = s;
137  while( *e ) e++; }
138  else {
139  *A = (int) strtol( s, &e, 10 );
140  }
141  if( *e != 0 ) {
142  smr_setMessageError( smr, NULL, __FILE__, __LINE__, 1, "Failed to convert A to integer in particle name %s", name ); }
143  else { /* Getting here implies that *p == '_' or 0. */
144  *m = 0;
145  if( *p == '_' ) {
146  p++;
147  if( *p != 'm' ) {
148  smr_setMessageError( smr, NULL, __FILE__, __LINE__, 1, "Particle name %s missing meta-stable label 'm'", name ); }
149  else {
150  p++;
151  *m = (int) strtol( p, &e, 10 );
152  if( *e != 0 ) smr_setMessageError( smr, NULL, __FILE__, __LINE__, 1, "Failed to convert m to integer in particle name %s", name );
153  }
154  }
155  }
156  }
157  }
158  }
159 
160  return( !smr_isOk( smr ) );
161 }
162 /*
163 ************************************************************
164 */
165 char *tpia_misc_pointerToAttributeIfAllOk( statusMessageReporting *smr, xData_element *element, const char *path, int required,
166  xData_attributionList *attributes, const char *name, const char *file, int line ) {
167 
168  char *value;
169 
170  if( !smr_isOk( smr ) ) return( NULL );
171  if( ( value = xData_getAttributesValue( attributes, name ) ) == NULL ) {
172  if( required ) {
173  if( element != NULL ) {
174  tpia_misc_setMessageError_Element( smr, NULL, element, file, line, 1, "element does not have attribute named %s", name ); }
175  else {
176  smr_setMessageError( smr, NULL, file, line, 1, "element does not have attribute named %s for file = %d", name, path );
177  }
178  }
179  }
180  return( value );
181 }
182 /*
183 ************************************************************
184 */
185 int tpia_misc_setMessageError_Element( statusMessageReporting *smr, void *userInterface, xData_element *element, const char *file, int line, int code,
186  const char *fmt, ... ) {
187 
188  int status = 0;
189  va_list args;
190  char *msg;
191 
192  va_start( args, fmt );
193  msg = smr_vallocateFormatMessage( fmt, &args );
194  va_end( args );
195  if( msg == NULL ) {
196  status = 1;
197  va_start( args, fmt );
198  smr_vsetMessageError( smr, userInterface, file, line, code, fmt, &args );
199  va_end( args ); }
200  else {
201  status = smr_setMessageError( smr, userInterface, file, line, code, "%s for element %s at line %d column %d", msg, element->fullName,
202  (int) element->docInfo.line, (int) element->docInfo.column );
203  free( msg );
204  }
205  return( status );
206 }
207 /*
208 ************************************************************
209 */
210 xData_Int tpia_misc_binarySearch( xData_Int n, double *ds, double d ) {
211 
212  xData_Int imin = 0, imid, imax = n - 1;
213 
214  if( d < ds[0] ) return( -2 );
215  if( d > ds[n-1] ) return( -1 );
216  while( 1 ) {
217  imid = ( imin + imax ) >> 1;
218  if( imid == imin ) break;
219  if( d < ds[imid] ) {
220  imax = imid; }
221  else {
222  imin = imid;
223  }
224  }
225  return( imin );
226 }
227 /*
228 ************************************************************
229 */
230 double *tpia_misc_get2dx_y_data( statusMessageReporting *smr, xData_element *element, xData_Int *length ) {
231 
232  xData_element *xDataElement;
233  double *d = NULL;
234  xData_Int length_;
235 
236  xData_addToAccessed( smr, element, 1 );
237  //if( ( xDataElement = xData_getOneElementByTagName( smr, element, "xData", 1 ) ) != NULL ) {
238  if( ( xDataElement = xData_getOneElementByTagName( smr, element, (char*)"xData", 1 ) ) != NULL ) {
239  xData_addToAccessed( smr, xDataElement, 1 );
240  if( xData_is_2d_xy( smr, &(xDataElement->xDataTypeInfo), 1 ) ) {
241  d = xData_2d_xy_allocateCopyData( smr, xDataElement, &length_ );
242  *length = (xData_Int) length_;
243  }
244  }
245  return( d );
246 }
247 /*
248 ************************************************************
249 */
250 double *tpia_misc_get2dxindex_y_data( statusMessageReporting *smr, xData_element *element, xData_Int *start, xData_Int *end, double *xValues ) {
251 
252  xData_element *xDataElement;
253  double *d = NULL;
254 
255  xData_addToAccessed( smr, element, 1 );
256  //if( ( xDataElement = xData_getOneElementByTagName( smr, element, "xData", 1 ) ) != NULL ) {
257  if( ( xDataElement = xData_getOneElementByTagName( smr, element, (char*) "xData", 1 ) ) != NULL ) {
258  xData_addToAccessed( smr, xDataElement, 1 );
259  if( xData_is_2d_xindex_y( smr, &(xDataElement->xDataTypeInfo), 1 ) ) {
260  if( start != NULL ) *start = xDataElement->xDataTypeInfo.start;
261  if( end != NULL ) *end = xDataElement->xDataTypeInfo.end;
262  d = xData_2d_xindex_y_toFilledYs( smr, xDataElement, xValues );
263  }
264  }
265  return( d );
266 }
267 /*
268 ************************************************************
269 */
270 double *tpia_misc_get2d_xShared_yHistogram_data( statusMessageReporting *smr, xData_element *element, xData_Int *start, xData_Int *end, xData_Int *length ) {
271 
272  xData_Int i;
273  xData_element *xDataElement;
274  double *d = NULL;
275 
276  xData_addToAccessed( smr, element, 1 );
277  //if( ( xDataElement = xData_getOneElementByTagName( smr, element, "xData", 1 ) ) != NULL ) {
278  if( ( xDataElement = xData_getOneElementByTagName( smr, element, (char*) "xData", 1 ) ) != NULL ) {
279  xData_addToAccessed( smr, xDataElement, 1 );
280  if( ( d = xData_2d_xShared_yHistogram_copyData( smr, xDataElement, &i ) ) != NULL ) {
281  if( start != NULL ) *start = xDataElement->xDataTypeInfo.start;
282  if( end != NULL ) *end = xDataElement->xDataTypeInfo.end;
283  if( length != NULL ) *length = xDataElement->xDataTypeInfo.length;
284  }
285  }
286  return( d );
287 }
288 /*
289 ************************************************************
290 */
291 int tpia_misc_get2d_xShared_yHistogram_data_Grouped( statusMessageReporting *smr, xData_element *element, tpia_1dData *group ) {
292 
293  if( ( group->data = tpia_misc_get2d_xShared_yHistogram_data( smr, element, &(group->start), &(group->end), &(group->length) ) ) == NULL ) return( 1 );
294  return( 0 );
295 }
296 /*
297 ************************************************************
298 */
299 //double tpia_misc_getPointwiseCrossSectionAtE( statusMessageReporting *smr, tpia_1dData *crossSection, double *energyGrid, xData_Int index, double e_in ) {
300 double tpia_misc_getPointwiseCrossSectionAtE( statusMessageReporting *, tpia_1dData *crossSection, double *energyGrid, xData_Int index, double e_in ) {
301 
302  double xsec = 0.0, e1, e2;
303 
304  if( ( index >= crossSection->start ) && ( index < crossSection->end ) ) {
305  e1 = energyGrid[index];
306  e2 = energyGrid[index + 1];
307  index -= crossSection->start;
308  if( e1 == e2 ) { /* Allow for future where step function may be allowed. */
309  xsec = 0.5 * ( crossSection->data[index] + crossSection->data[index + 1] ); }
310  else {
311  xsec = ( crossSection->data[index] * ( e2 - e_in ) + crossSection->data[index + 1] * ( e_in - e1 ) ) / ( e2 - e1 );
312  }
313  }
314  return( xsec );
315 }
316 /*
317 ************************************************************
318 */
319 tpia_EqualProbableBinSpectrum *tpia_misc_getEqualProbableBin( statusMessageReporting *smr, xData_element *parent, xData_Int *n, xData_Int *nBins ) {
320 
321  xData_element *element;
322 
323  xData_addToAccessed( smr, parent, 1 );
324  //if( ( element = xData_getOneElementByTagName( smr, parent, "equalProbableBins", 0 ) ) == NULL ) return( NULL );
325  if( ( element = xData_getOneElementByTagName( smr, parent, (char*) "equalProbableBins", 0 ) ) == NULL ) return( NULL );
326  if( xData_convertAttributeTo_xData_Int( smr, element, "nBins", nBins ) != 0 ) {
327  tpia_misc_setMessageError_Element( smr, NULL, element, __FILE__, __LINE__, 1, "missing or invalid nBins attribute" );
328  return( NULL );
329  }
330  return( tpia_misc_getEqualProbableBins( smr, element, "energy", *nBins, n ) );
331 }
332 /*
333 ************************************************************
334 */
335 tpia_EqualProbableBinSpectrum *tpia_misc_getEqualProbableBins( statusMessageReporting *smr, xData_element *parent, const char *name, xData_Int nBins,
336  xData_Int *n ) {
337 
338 
339  int i, j;
340  xData_Int index, size;
341  xData_elementList *list;
342  xData_element *element, *xData;
343  double *d;
344  tpia_EqualProbableBinSpectrum *epbs = NULL, *epb;
345 
346  xData_addToAccessed( smr, parent, 1 );
347  list = xData_getElementsByTagNameAndSort( smr, parent, name, NULL, NULL );
348  if( list->n == 0 ) {
349  tpia_misc_setMessageError_Element( smr, NULL, parent, __FILE__, __LINE__, 1, "bins does not contain any %s elements", name ); }
350  else {
351  *n = list->n;
352  size = list->n * ( sizeof( tpia_EqualProbableBinSpectrum ) + ( nBins + 1 ) * sizeof( double ) );
353  //if( ( epbs = xData_malloc2( smr, size, 0, "energies" ) ) != NULL ) {
354  if( ( epbs = (tpia_EqualProbableBinSpectrum*) xData_malloc2( smr, size, 0, "energies" ) ) != NULL ) {
355  d = (double *) &(epbs[list->n]);
356  for( i = 0, epb = epbs; i < list->n; i++, epb++ ) { /* Loop to test nBins and index are proper. */
357  element = list->items[i].element;
358  xData_addToAccessed( smr, element, 1 );
359  if( xData_convertAttributeTo_xData_Int( smr, element, "index", &index ) != 0 ) {
360  tpia_misc_setMessageError_Element( smr, NULL, element, __FILE__, __LINE__, 1, "missing or invalid index attribute" );
361  //epbs = xData_free( smr, epbs );
362  epbs = (tpia_EqualProbableBinSpectrum*) xData_free( smr, epbs );
363  break;
364  }
365  if( index != i ) {
366  tpia_misc_setMessageError_Element( smr, NULL, element, __FILE__, __LINE__, 1, "index = %lld is not incremental", index );
367  //epbs = xData_free( smr, epbs );
368  epbs = (tpia_EqualProbableBinSpectrum*) xData_free( smr, epbs );
369  break;
370  }
371  if( ( j = xData_convertAttributeToDouble( smr, element, "value", &(epb->value) ) ) != 0 ) {
372  if( j == 1 ) {
373  tpia_misc_setMessageError_Element( smr, NULL, element, __FILE__, __LINE__, 1, "element does not have value attribute" ); }
374  else {
375  tpia_misc_setMessageError_Element( smr, NULL, element, __FILE__, __LINE__, 1, "failed to convert value attribute to double" );
376  }
377  //epbs = xData_free( smr, epbs );
378  epbs = (tpia_EqualProbableBinSpectrum*) xData_free( smr, epbs );
379  break;
380  }
381  if( ( xData = xData_getElements_xDataElement( smr, element ) ) == NULL ) {
382  //epbs = xData_free( smr, epbs );
383  epbs = (tpia_EqualProbableBinSpectrum*) xData_free( smr, epbs );
384  break;
385  }
386  xData_addToAccessed( smr, xData, 1 );
387  epb->index = index;
388  epb->nBins = nBins;
389  epb->bins = d;
390  if( xData_1d_x_copyData( smr, xData, ( nBins + 1 ) * sizeof( double ), d ) != 0 ) {
391  //epbs = xData_free( smr, epbs );
392  epbs = (tpia_EqualProbableBinSpectrum*) xData_free( smr, epbs );
393  break;
394  }
395  d += nBins + 1;
396  }
397  }
398  }
399  xData_freeElementList( smr, list );
400  return( epbs );
401 }
402 /*
403 ************************************************************
404 */
405 double tpia_misc_drng( double (*rng)( void * ), void *rngState ) {
406 
407  double r;
408 
409  if( rng != NULL ) {
410  r = rng( rngState ); }
411  else {
412  //r = drand48( );
413  r = CLHEP::HepRandom::getTheEngine()->flat();
414 
415  }
416  return( r );
417 }
418 /*
419 ************************************************************
420 */
421 //int tpia_misc_sampleEqualProbableBin( statusMessageReporting *smr, tpia_decaySamplingInfo *decaySamplingInfo, double e_in, int nBins,
422 int tpia_misc_sampleEqualProbableBin( statusMessageReporting *, tpia_decaySamplingInfo *decaySamplingInfo, double e_in, int nBins,
423  tpia_EqualProbableBinSpectra *binned, double *value_ ) {
424 
425  int i, j, index1, index2, method = 0;
426  double fE = 1., r, value1, value2, value3, P12, P23, value = -2.;
427 
428  if( e_in <= binned->energies[0].value ) {
429  index1 = 0;
430  index2 = 0; }
431  else if( e_in >= binned->energies[binned->numberOfEs-1].value ) {
432  index1 = binned->numberOfEs - 1;
433  index2 = binned->numberOfEs - 1; }
434  else {
435  for( i = 0; i < binned->numberOfEs - 1; i++ ) {
436  if( e_in <= binned->energies[i].value ) break;
437  }
438  i--;
439  index1 = i;
440  index2 = i;
441  if( e_in != binned->energies[i].value ) {
442  index2++;
443  fE = ( e_in - binned->energies[i].value ) / ( binned->energies[i+1].value - binned->energies[i].value );
444  }
445  }
446  r = tpia_misc_drng( decaySamplingInfo->rng, decaySamplingInfo->rngState );
447  j = (int) (r * nBins);
448  if( j >= nBins ) j = nBins - 1;
449  if( j < 0 ) j = 0;
450  r = tpia_misc_drng( decaySamplingInfo->rng, decaySamplingInfo->rngState ); // Do not change r until after Point1 below.
451  if( tpia_samplingMethods_isLinear( decaySamplingInfo->samplingMethods->angular_equalProbableBinMethod ) ) {
452  method = 1;
453  if( ( ( j == 0 ) && ( r <= 0.5 ) ) || ( j == ( nBins - 1 ) && r > 0.5 ) ) method = 0;
454  }
455  if( method == 0 ) { /* Constant interpolaton. */
456  value1 = ( 1. - fE ) * binned->energies[index1].bins[j] + fE * binned->energies[index2].bins[j];
457  value2 = ( 1. - fE ) * binned->energies[index1].bins[j+1] + fE * binned->energies[index2].bins[j+1];
458  value = ( 1. - r ) * value1 + r * value2; }
459  else { /* Linear interpolation. */
460  if( r <= 0.5 ) j--; /* Point1: Above test insures that j is not 0 (nBins-1) if r <= 0.5 (> 0.5); */
461  value1 = ( 1. - fE ) * binned->energies[index1].bins[j] + fE * binned->energies[index2].bins[j];
462  value2 = ( 1. - fE ) * binned->energies[index1].bins[j+1] + fE * binned->energies[index2].bins[j+1];
463  value3 = ( 1. - fE ) * binned->energies[index1].bins[j+2] + fE * binned->energies[index2].bins[j+2];
464 //
465 //TK140602 Modified for protecting divided by 0 BEGIN
466  if ( value1 == value2 && value2 == value3 ) {
467  value = value1;
468  } else {
469 
470  if ( value2 != value1 )
471  P12 = 1. / ( value2 - value1 );
472  else
473  P12 =FLT_MAX;
474 
475  if ( value3 != value2 )
476  P23 = 1. / ( value3 - value2 );
477  else
478  P23 =FLT_MAX;
479 
480  r = tpia_misc_drng( decaySamplingInfo->rng, decaySamplingInfo->rngState );
481  if( 0.25 * ( 1.0 + 2.0 * ( value2 - value1 ) / ( value3 - value1 ) ) > r ) {
482  P23 = 2. / ( value3 - value1 );
483  value3 = value2; }
484  else {
485  P12 = 2. / ( value3 - value1 );
486  value1 = value2;
487  }
488  r = tpia_misc_drng( decaySamplingInfo->rng, decaySamplingInfo->rngState );
489  if( P23 != P12 ) r = ( -P12 + std::sqrt( P12 * P12 * ( 1. - r ) + r * P23 * P23 ) ) / ( P23 - P12 );
490  value = 0.5 * ( value1 + value2 + r * ( value3 - value1 ) );
491  }
492 //TK140602 Modified for protecting divided by 0 END
493  }
494  *value_ = value;
495  return( 0 );
496 }
497 
498 #if defined __cplusplus
499 }
500 #endif
std::string symbol
Definition: tpia_misc.cc:58
xData_Int xData_convertAttributeTo_xData_Int(statusMessageReporting *smr, xData_element *element, const char *name, xData_Int *n)
Definition: xData.cc:710
xData_element * xData_getOneElementByTagName(statusMessageReporting *smr, xData_element *element, char *name, int required)
Definition: xData.cc:810
int Z
Definition: tpia_misc.cc:56
int xData_addToAccessed(statusMessageReporting *, xData_element *element, int increment)
Definition: xData.cc:1078
G4String symbol
Definition: TRTMaterials.hh:40
char * tpia_misc_pointerToAttributeIfAllOk(statusMessageReporting *smr, xData_element *element, const char *path, int required, xData_attributionList *attributes, const char *name, const char *file, int line)
Definition: tpia_misc.cc:165
int tpia_misc_get2d_xShared_yHistogram_data_Grouped(statusMessageReporting *smr, xData_element *element, tpia_1dData *group)
Definition: tpia_misc.cc:291
int tpia_misc_NumberOfZSymbols(void)
Definition: tpia_misc.cc:78
xData_element * xData_getElements_xDataElement(statusMessageReporting *smr, xData_element *element)
Definition: xData.cc:622
double * xData_2d_xShared_yHistogram_copyData(statusMessageReporting *, xData_element *element, xData_Int *n)
G4String name
Definition: TRTMaterials.hh:40
int xData_is_2d_xy(statusMessageReporting *smr, xDataType *xDT, int setMsg)
Definition: xData_2d_xy.cc:70
tpia_EqualProbableBinSpectrum * tpia_misc_getEqualProbableBin(statusMessageReporting *smr, xData_element *parent, xData_Int *n, xData_Int *nBins)
Definition: tpia_misc.cc:319
int tpia_misc_setMessageError_Element(statusMessageReporting *smr, void *userInterface, xData_element *element, const char *file, int line, int code, const char *fmt,...)
Definition: tpia_misc.cc:185
int smr_setMessageError(statusMessageReporting *smr, void *userInterface, const char *file, int line, int code, const char *fmt,...)
static const G4double e2
char * xData_getAttributesValue(xData_attributionList *attributes, const char *name)
Definition: xData.cc:530
static const G4double P12[nE]
double tpia_misc_drng(double(*rng)(void *), void *rngState)
Definition: tpia_misc.cc:405
double * tpia_misc_get2d_xShared_yHistogram_data(statusMessageReporting *smr, xData_element *element, xData_Int *start, xData_Int *end, xData_Int *length)
Definition: tpia_misc.cc:270
int tpia_misc_symbolToZ(const char *Z)
Definition: tpia_misc.cc:94
double * xData_2d_xy_allocateCopyData(statusMessageReporting *smr, xData_element *element, xData_Int *length)
Definition: xData_2d_xy.cc:84
xData_elementList * xData_getElementsByTagNameAndSort(statusMessageReporting *smr, xData_element *element, const char *tagName, const char *sortAttributeName, xData_sortElementFunc sortFunction)
Definition: xData.cc:788
static const double s
Definition: G4SIunits.hh:150
double * xData_2d_xindex_y_toFilledYs(statusMessageReporting *smr, xData_element *element, double *Xs)
int smr_isOk(statusMessageReporting *smr)
int tpia_miscNameToZAm(statusMessageReporting *smr, const char *name, int *Z, int *A, int *m)
Definition: tpia_misc.cc:107
tpia_EqualProbableBinSpectrum * tpia_misc_getEqualProbableBins(statusMessageReporting *smr, xData_element *parent, const char *name, xData_Int nBins, xData_Int *n)
Definition: tpia_misc.cc:335
xData_Int tpia_misc_binarySearch(xData_Int n, double *ds, double d)
Definition: tpia_misc.cc:210
const G4int n
static const G4double A[nN]
static const G4double P23[nE]
static const G4double e1
int xData_1d_x_copyData(statusMessageReporting *smr, xData_element *element, xData_Int nAllocatedBytes, double *d)
Definition: xData_1d_x.cc:84
const char * tpia_misc_ZToSymbol(int iZ)
Definition: tpia_misc.cc:85
void * xData_free(statusMessageReporting *, void *p)
Definition: xDataMisc.cc:89
int tpia_misc_sampleEqualProbableBin(statusMessageReporting *, tpia_decaySamplingInfo *decaySamplingInfo, double e_in, int nBins, tpia_EqualProbableBinSpectra *binned, double *value_)
Definition: tpia_misc.cc:422
double * tpia_misc_get2dxindex_y_data(statusMessageReporting *smr, xData_element *element, xData_Int *start, xData_Int *end, double *xValues)
Definition: tpia_misc.cc:250
static const double m
Definition: G4SIunits.hh:110
double tpia_misc_getPointwiseCrossSectionAtE(statusMessageReporting *, tpia_1dData *crossSection, double *energyGrid, xData_Int index, double e_in)
Definition: tpia_misc.cc:300
int xData_convertAttributeToDouble(statusMessageReporting *smr, xData_element *element, const char *name, double *d)
Definition: xData.cc:730
static const G4int imax
double * tpia_misc_get2dx_y_data(statusMessageReporting *smr, xData_element *element, xData_Int *length)
Definition: tpia_misc.cc:230
int xData_is_2d_xindex_y(statusMessageReporting *smr, xDataType *xDT, int setMsg)
#define FLT_MAX
Definition: templates.hh:99
static const struct ZSymbol ZSymbols[]
Definition: tpia_misc.cc:61
int smr_vsetMessageError(statusMessageReporting *smr, void *userInterface, const char *file, int line, int code, const char *fmt, va_list *args)
char * smr_vallocateFormatMessage(const char *fmt, va_list *args)
void xData_freeElementList(statusMessageReporting *smr, xData_elementList *list)
Definition: xData.cc:832