Geant4 Cross Reference |
1 // 1 2 // ******************************************* 3 // * License and Disclaimer 4 // * 5 // * The Geant4 software is copyright of th 6 // * the Geant4 Collaboration. It is provided 7 // * conditions of the Geant4 Software License 8 // * LICENSE and available at http://cern.ch/ 9 // * include a list of copyright holders. 10 // * 11 // * Neither the authors of this software syst 12 // * institutes,nor the agencies providing fin 13 // * work make any representation or warran 14 // * regarding this software system or assum 15 // * use. Please see the license in the file 16 // * for the full disclaimer and the limitatio 17 // * 18 // * This code implementation is the result 19 // * technical work of the GEANT4 collaboratio 20 // * By using, copying, modifying or distri 21 // * any work based on the software) you ag 22 // * use in resulting scientific publicati 23 // * acceptance of all terms of the Geant4 Sof 24 // ******************************************* 25 // 26 /* 27 # <<BEGIN-copyright>> 28 # <<END-copyright>> 29 */ 30 #include <string.h> 31 #include <iostream> 32 #include <string> 33 #include <vector> 34 #include <statusMessageReporting.h> 35 #include <MCGIDI.h> 36 #include <MCGIDI_misc.h> 37 #include "G4GIDI_Misc.hh" 38 using namespace std; 39 using namespace GIDI; 40 41 /* 42 ********************************************** 43 */ 44 char *G4GIDI_Misc_Z_A_m_ToName( int iZ, int iA 45 46 const char *Z = MCGIDI_misc_ZToSymbol( iZ 47 char S[128], mS[32], *name; 48 49 if( Z == NULL ) return( NULL ); 50 if( iA == 0 ) { 51 if( im != 0 ) return( NULL ); 52 snprintf( S, sizeof S, "%s_natural", Z 53 else { 54 snprintf( S, sizeof S, "%s%d", Z, iA ) 55 if( im != 0 ) { 56 //snprintf( mS, sizeof mS, "_m%d", 57 //TK 170509 58 //Fix inconsistency of name of exc 59 snprintf( mS, sizeof mS, "m%d", im 60 strcat( S, mS ); 61 } 62 } 63 name = (char *) smr_malloc2( NULL, strlen( 64 if( name != NULL ) strcpy( name, S ); 65 return( name ); 66 } 67 /* 68 ********************************************** 69 */ 70 char *G4GIDI_Misc_channelCompound( char *parti 71 72 int Z1, A1, m1, Z2, A2, m2, level1, level2 73 74 if( MCGIDI_miscNameToZAm( NULL, particle1, 75 if( MCGIDI_miscNameToZAm( NULL, particle2, 76 if( A1 == 0 ) A2 = 0; 77 if( A2 == 0 ) A1 = 0; 78 return( G4GIDI_Misc_Z_A_m_ToName( Z1 + Z2, 79 } 80 #if 0 81 /* 82 ********************************************** 83 */ 84 int G4GIDI_Misc_channelProductsCompare( tpia_c 85 86 int i; 87 tpia_product *product; 88 89 if( channel->decayChannel.numberOfProducts 90 for( product = tpia_channel_getFirstProduc 91 if( strcmp( product->productID->name, 92 } 93 return( 1 ); 94 } 95 #endif 96 /* 97 ********************************************** 98 */ 99 int getNamesOfAvailableTargets_walker( MCGIDI_ 100 101 vector<string> *listOfTargets = (vector<st 102 vector<string>::iterator iter; 103 104 if( entry->type != MCGIDI_mapEntry_type_ta 105 for( iter = listOfTargets->begin( ); iter 106 if( entry->targetName == iter->c_str( 107 } 108 listOfTargets->push_back( entry->targetNam 109 return( 0 ); 110 } 111