/************************************************************************************* Grid physics library, www.github.com/paboyle/Grid Source file: ./lib/parallelIO/NerscIO.h Copyright (C) 2015 Author: Peter Boyle This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. See the full license in the file "LICENSE" in the top level distribution directory *************************************************************************************/ /* END LEGAL */ #include #include #include #include #include #include #include #include namespace Grid { //////////////////////////////////////////////////////////////////////////////// // header specification/interpretation //////////////////////////////////////////////////////////////////////////////// class FieldMetaData : Serializable { public: GRID_SERIALIZABLE_CLASS_MEMBERS(FieldMetaData, int, nd, std::vector, dimension, std::vector, boundary, int, data_start, std::string, hdr_version, std::string, storage_format, double, link_trace, double, plaquette, uint32_t, checksum, uint32_t, scidac_checksuma, uint32_t, scidac_checksumb, unsigned int, sequence_number, std::string, data_type, std::string, ensemble_id, std::string, ensemble_label, std::string, ildg_lfn, std::string, creator, std::string, creator_hardware, std::string, creation_date, std::string, archive_date, std::string, floating_point); }; namespace QCD { using namespace Grid; ////////////////////////////////////////////////////////////////////// // Bit and Physical Checksumming and QA of data ////////////////////////////////////////////////////////////////////// inline void GridMetaData(GridBase *grid,FieldMetaData &header) { int nd = grid->_ndimension; header.nd = nd; header.dimension.resize(nd); header.boundary.resize(nd); for(int d=0;d_fdimensions[d]; } for(int d=0;d inline void GaugeStatistics(GaugeField & data,FieldMetaData &header) { // How to convert data precision etc... header.link_trace=Grid::QCD::WilsonLoops::linkTrace(data); header.plaquette =Grid::QCD::WilsonLoops::avgPlaquette(data); } inline void MachineCharacteristics(FieldMetaData &header) { // Who struct passwd *pw = getpwuid (getuid()); if (pw) header.creator = std::string(pw->pw_name); // When std::time_t t = std::time(nullptr); std::tm tm_ = *std::localtime(&t); std::ostringstream oss; // oss << std::put_time(&tm_, "%c %Z"); header.creation_date = oss.str(); header.archive_date = header.creation_date; // What struct utsname name; uname(&name); header.creator_hardware = std::string(name.nodename)+"-"; header.creator_hardware+= std::string(name.machine)+"-"; header.creator_hardware+= std::string(name.sysname)+"-"; header.creator_hardware+= std::string(name.release); } #define dump_meta_data(field, s) \ s << "BEGIN_HEADER" << std::endl; \ s << "HDR_VERSION = " << field.hdr_version << std::endl; \ s << "DATATYPE = " << field.data_type << std::endl; \ s << "STORAGE_FORMAT = " << field.storage_format << std::endl; \ for(int i=0;i<4;i++){ \ s << "DIMENSION_" << i+1 << " = " << field.dimension[i] << std::endl ; \ } \ s << "LINK_TRACE = " << std::setprecision(10) << field.link_trace << std::endl; \ s << "PLAQUETTE = " << std::setprecision(10) << field.plaquette << std::endl; \ for(int i=0;i<4;i++){ \ s << "BOUNDARY_"< using iLorentzColour2x3 = iVector, 2>, Nd >; typedef iLorentzColour2x3 LorentzColour2x3; typedef iLorentzColour2x3 LorentzColour2x3F; typedef iLorentzColour2x3 LorentzColour2x3D; template struct GaugeSimpleMunger{ void operator()(fobj &in, sobj &out) { for (int mu = 0; mu < Nd; mu++) { for (int i = 0; i < Nc; i++) { for (int j = 0; j < Nc; j++) { out(mu)()(i, j) = in(mu)()(i, j); }} } }; }; template struct GaugeSimpleUnmunger { void operator()(sobj &in, fobj &out) { for (int mu = 0; mu < Nd; mu++) { for (int i = 0; i < Nc; i++) { for (int j = 0; j < Nc; j++) { out(mu)()(i, j) = in(mu)()(i, j); }} } }; }; template struct Gauge3x2munger{ void operator() (fobj &in,sobj &out){ for(int mu=0;mu struct Gauge3x2unmunger{ void operator() (sobj &in,fobj &out){ for(int mu=0;mu