// // ******************************************************************** // * License and Disclaimer * // * * // * The Geant4 software is copyright of the Copyright Holders of * // * the Geant4 Collaboration. It is provided under the terms and * // * conditions of the Geant4 Software License, included in the file * // * LICENSE and available at http://cern.ch/geant4/license . These * // * include a list of copyright holders. * // * * // * Neither the authors of this software system, nor their employing * // * institutes,nor the agencies providing financial support for this * // * work make any representation or warranty, express or implied, * // * regarding this software system or assume any liability for its * // * use. Please see the license in the file LICENSE and URL above * // * for the full disclaimer and the limitation of liability. * // * * // * This code implementation is the result of the scientific and * // * technical work of the GEANT4 collaboration. * // * By using, copying, modifying or distributing the software (or * // * any work based on the software) you agree to acknowledge its * // * use in resulting scientific publications, and indicate your * // * acceptance of all terms of the Geant4 Software license. * // ******************************************************************** // // // $Id: G4EMDataSet.cc,v 1.12 2006/06/29 19:39:44 gunter Exp $ // GEANT4 tag $Name: geant4-09-01-patch-02 $ // // Author: Maria Grazia Pia (Maria.Grazia.Pia@cern.ch) // // History: // ----------- // 31 Jul 2001 MGP Created // // ------------------------------------------------------------------- #include "G4EMDataSet.hh" #include "G4VDataSetAlgorithm.hh" #include #include G4EMDataSet :: G4EMDataSet(G4int argZ, G4VDataSetAlgorithm * argAlgorithm, G4double argUnitEnergies, G4double argUnitData) : z(argZ), energies(0), data(0), algorithm(argAlgorithm), unitEnergies(argUnitEnergies), unitData(argUnitData) { if (algorithm == 0) G4Exception("G4EMDataSet::G4EMDataSet - interpolation == 0"); } G4EMDataSet :: G4EMDataSet(G4int argZ, G4DataVector * argEnergies, G4DataVector * argData, G4VDataSetAlgorithm * argAlgorithm, G4double argUnitEnergies, G4double argUnitData) : z(argZ), energies(argEnergies), data(argData), algorithm(argAlgorithm), unitEnergies(argUnitEnergies), unitData(argUnitData) { if (algorithm==0) G4Exception("G4EMDataSet::G4EMDataSet - interpolation == 0"); if ((energies==0) ^ (data==0)) G4Exception("G4EMDataSet::G4EMDataSet - different size for energies and data (zero case)"); if (energies==0) return; if (energies->size()!=data->size()) G4Exception("G4EMDataSet::G4EMDataSet - different size for energies and data"); } G4EMDataSet :: ~G4EMDataSet() { delete algorithm; if (energies) delete energies; if (data) delete data; } G4double G4EMDataSet :: FindValue(G4double argEnergy, G4int /* argComponentId */) const { if (!energies) G4Exception("G4EMDataSet::FindValue - energies == 0"); if (energies->empty()) return 0; if (argEnergy <= (*energies)[0]) return (*data)[0]; size_t i(energies->size()-1); if (argEnergy >= (*energies)[i]) return (*data)[i]; return algorithm->Calculate(argEnergy, FindLowerBound(argEnergy), *energies, *data); } void G4EMDataSet :: PrintData(void) const { if (!energies) { G4cout << "Data not available." << G4endl; return; } size_t size = energies->size(); for (size_t i(0); isize()!=data->size()) G4Exception("G4EMDataSet::SetEnergiesData - different size for energies and data"); } G4bool G4EMDataSet :: LoadData(const G4String & argFileName) { // The file is organized into two columns: // 1st column is the energy // 2nd column is the corresponding value // The file terminates with the pattern: -1 -1 // -2 -2 G4String fullFileName(FullFileName(argFileName)); std::ifstream in(fullFileName); if (!in.is_open()) { G4String message("G4EMDataSet::LoadData - data file \""); message+=fullFileName; message+="\" not found"; G4Exception(message); } G4DataVector * argEnergies=new G4DataVector; G4DataVector * argData=new G4DataVector; G4double a; bool energyColumn(true); do { in >> a; if (a!=-1 && a!=-2) { if (energyColumn) argEnergies->push_back(a*unitEnergies); else argData->push_back(a*unitData); energyColumn=(!energyColumn); } } while (a != -2); SetEnergiesData(argEnergies, argData, 0); return true; } G4bool G4EMDataSet :: SaveData(const G4String & argFileName) const { // The file is organized into two columns: // 1st column is the energy // 2nd column is the corresponding value // The file terminates with the pattern: -1 -1 // -2 -2 G4String fullFileName(FullFileName(argFileName)); std::ofstream out(fullFileName); if (!out.is_open()) { G4String message("G4EMDataSet::SaveData - cannot open \""); message+=fullFileName; message+="\""; G4Exception(message); } out.precision(10); out.width(15); out.setf(std::ofstream::left); if (energies!=0 && data!=0) { G4DataVector::const_iterator i(energies->begin()); G4DataVector::const_iterator endI(energies->end()); G4DataVector::const_iterator j(data->begin()); while (i!=endI) { out.precision(10); out.width(15); out.setf(std::ofstream::left); out << ((*i)/unitEnergies) << ' '; out.precision(10); out.width(15); out.setf(std::ofstream::left); out << ((*j)/unitData) << std::endl; i++; j++; } } out.precision(10); out.width(15); out.setf(std::ofstream::left); out << -1.f << ' '; out.precision(10); out.width(15); out.setf(std::ofstream::left); out << -1.f << std::endl; out.precision(10); out.width(15); out.setf(std::ofstream::left); out << -2.f << ' '; out.precision(10); out.width(15); out.setf(std::ofstream::left); out << -2.f << std::endl; return true; } size_t G4EMDataSet :: FindLowerBound(G4double argEnergy) const { size_t lowerBound(0); size_t upperBound(energies->size() - 1); while (lowerBound <= upperBound) { size_t midBin((lowerBound + upperBound)/2); if (argEnergy < (*energies)[midBin]) upperBound = midBin-1; else lowerBound = midBin+1; } return upperBound; } G4String G4EMDataSet :: FullFileName(const G4String & argFileName) const { char* path = getenv("G4LEDATA"); if (!path) G4Exception("G4EMDataSet::FullFileName - G4LEDATA environment variable not set"); std::ostringstream fullFileName; fullFileName << path << '/' << argFileName << z << ".dat"; return G4String(fullFileName.str().c_str()); }