11 mySettings = settings;
14 char *gmcroot, *originalpath, *buf=
new char[300];
16 bool errorFlag =
true;
18 cout <<
"Preparing to read magnetic field map file...\n";
21 gmcroot = (
char *)getenv(
"GMCROOT");
24 originalpath = getcwd(buf, size);
28 cout <<
"Reading field maps..." << endl;
36 cout <<
"No magnetic field input file found! \nPlease check your field map file location and your GMCROOT environment variable." << endl;
43 G4cout <<
"Preparing to read magnetic field map files...\n";
44 G4cout <<
"Reading field maps...\n";
48 G4cout <<
"Finished loading magnetic field map files!\n";
52 zValues[0] = -204.0*cm;
53 zValues[1] = 403.74*cm;
54 zValues[2] = 712.0*cm;
55 zValues[3] = 1572.26*cm;
72 if (Point[2]>zValues[0] && Point[2]<zValues[1])
74 Mag1Field->GetFieldValue( Point, Bfield );
77 if ((Point[2]>zValues[2])&&(Point[2]<zValues[3]))
79 Mag2Field->GetFieldValue( Point, Bfield );
82 if ((Point[2]>zValues[1])&&(Point[2]<zValues[2]))
84 Mag2Field->GetFieldValue( Point, Bfield );
88 Mag1Field->GetFieldValue( Point, Bfield );
89 Bfield[0] = Bfield[0] + xTemp;
90 Bfield[1] = Bfield[1] + yTemp;
91 Bfield[2] = Bfield[2] + zTemp;
void GetFieldValue(const double Point[3], double *Bfield) const