19#ifndef BDSFIELDLOADERBDSIM_H
20#define BDSFIELDLOADERBDSIM_H
22#include "BDSDimensionType.hh"
23#include "BDSFieldValue.hh"
32#include "src-external/gzstream/gzstream.h"
70 void Terminate(
const G4String& message =
"");
73 void Load(
const G4String& fileName,
74 const unsigned int nDim);
79 const unsigned long xIndex,
80 const unsigned long yIndex = 0,
81 const unsigned long zIndex = 0);
93 const std::vector<G4String> headerMustBePositiveKeys;
94 unsigned long indexOfFirstFieldValue;
102 std::map<BDSDimensionType, DimensionKeys> dimKeyMap;
103 std::map<BDSDimensionType, G4double> dimUnitsMap;
1D array with spatial mapping derived from BDSArray4DCoords.
2D array with spatial mapping derived from BDSArray4DCoords.
3D array with spatial mapping derived from BDSArray4DCoords.
Overlay of 4D array that provides uniform only spatial coordinate mapping.
Loader for BDSIM format fields.
std::map< G4String, double > header
Header keys and values.
BDSFieldValue fv
Temporary field value.
BDSArray3DCoords * Load3D(const G4String &fileName)
Load a 3D array.
BDSArray4DCoords * result
Resultant array from loading.
void CleanUp()
Ensure any member variables are reset between usages.
BDSArray4DCoords * Load4D(const G4String &fileName)
Load a 4D array.
BDSArray1DCoords * Load1D(const G4String &fileName)
Load a 1D array.
void Terminate(const G4String &message="")
Close file and exit program in case of an error.
void Load(const G4String &fileName, const unsigned int nDim)
General loader for any number of dimensions.
void ProcessData(const std::string &line, const unsigned long xIndex, const unsigned long yIndex=0, const unsigned long zIndex=0)
unsigned long nColumns
Number of columns to read.
std::vector< G4float > lineData
Vector to store line data during loading.
G4String loopOrder
String for looping order when loading.
BDSArray2DCoords * Load2D(const G4String &fileName)
Load a 2D array.
T file
Templated iostream for std::ifstream and gzstream as well.