2016-12-15 18:26:39 +00:00
|
|
|
/*************************************************************************************
|
|
|
|
|
2016-02-25 12:07:21 +00:00
|
|
|
Grid physics library, www.github.com/paboyle/Grid
|
|
|
|
|
2016-12-15 18:26:39 +00:00
|
|
|
Source file: extras/Hadrons/Global.cc
|
2016-02-25 12:07:21 +00:00
|
|
|
|
2017-12-26 13:16:47 +00:00
|
|
|
Copyright (C) 2015-2018
|
2016-02-25 12:07:21 +00:00
|
|
|
|
|
|
|
Author: Antonin Portelli <antonin.portelli@me.com>
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
2016-12-15 18:26:39 +00:00
|
|
|
See the full license in the file "LICENSE" in the top level distribution directory
|
|
|
|
*************************************************************************************/
|
2016-12-15 18:21:52 +00:00
|
|
|
/* END LEGAL */
|
2015-10-27 17:33:18 +00:00
|
|
|
|
2016-11-28 07:02:15 +00:00
|
|
|
#include <Grid/Hadrons/Global.hpp>
|
2015-10-27 17:33:18 +00:00
|
|
|
|
|
|
|
using namespace Grid;
|
2016-05-03 03:31:21 +01:00
|
|
|
using namespace QCD;
|
2015-10-27 17:33:18 +00:00
|
|
|
using namespace Hadrons;
|
|
|
|
|
|
|
|
HadronsLogger Hadrons::HadronsLogError(1,"Error");
|
|
|
|
HadronsLogger Hadrons::HadronsLogWarning(1,"Warning");
|
|
|
|
HadronsLogger Hadrons::HadronsLogMessage(1,"Message");
|
2016-05-09 14:49:06 +01:00
|
|
|
HadronsLogger Hadrons::HadronsLogIterative(1,"Iterative");
|
2015-10-27 17:33:18 +00:00
|
|
|
HadronsLogger Hadrons::HadronsLogDebug(1,"Debug");
|
2018-02-27 13:46:59 +00:00
|
|
|
HadronsLogger Hadrons::HadronsLogIRL(1,"IRL");
|
2016-05-10 19:07:41 +01:00
|
|
|
|
2017-12-29 15:58:23 +00:00
|
|
|
void Hadrons::initLogger(void)
|
|
|
|
{
|
2018-02-27 14:43:51 +00:00
|
|
|
auto w = std::string("Hadrons").length();
|
|
|
|
int cw = 8;
|
|
|
|
|
|
|
|
|
2017-12-29 15:58:23 +00:00
|
|
|
GridLogError.setTopWidth(w);
|
|
|
|
GridLogWarning.setTopWidth(w);
|
|
|
|
GridLogMessage.setTopWidth(w);
|
|
|
|
GridLogIterative.setTopWidth(w);
|
|
|
|
GridLogDebug.setTopWidth(w);
|
2018-02-27 13:46:59 +00:00
|
|
|
GridLogIRL.setTopWidth(w);
|
2018-02-27 14:43:51 +00:00
|
|
|
GridLogError.setChanWidth(cw);
|
|
|
|
GridLogWarning.setChanWidth(cw);
|
|
|
|
GridLogMessage.setChanWidth(cw);
|
|
|
|
GridLogIterative.setChanWidth(cw);
|
|
|
|
GridLogDebug.setChanWidth(cw);
|
|
|
|
GridLogIRL.setChanWidth(cw);
|
2018-04-23 12:48:17 +01:00
|
|
|
HadronsLogError.Active(true);
|
|
|
|
HadronsLogWarning.Active(true);
|
2017-12-29 15:58:23 +00:00
|
|
|
HadronsLogMessage.Active(GridLogMessage.isActive());
|
|
|
|
HadronsLogIterative.Active(GridLogIterative.isActive());
|
|
|
|
HadronsLogDebug.Active(GridLogDebug.isActive());
|
2018-02-27 13:46:59 +00:00
|
|
|
HadronsLogIRL.Active(GridLogIRL.isActive());
|
2018-02-27 14:43:51 +00:00
|
|
|
HadronsLogError.setChanWidth(cw);
|
|
|
|
HadronsLogWarning.setChanWidth(cw);
|
|
|
|
HadronsLogMessage.setChanWidth(cw);
|
|
|
|
HadronsLogIterative.setChanWidth(cw);
|
|
|
|
HadronsLogDebug.setChanWidth(cw);
|
|
|
|
HadronsLogIRL.setChanWidth(cw);
|
2017-12-29 15:58:23 +00:00
|
|
|
}
|
|
|
|
|
2016-12-14 18:02:18 +00:00
|
|
|
// type utilities //////////////////////////////////////////////////////////////
|
|
|
|
constexpr unsigned int maxNameSize = 1024u;
|
|
|
|
|
|
|
|
std::string Hadrons::typeName(const std::type_info *info)
|
|
|
|
{
|
|
|
|
char *buf;
|
|
|
|
std::string name;
|
|
|
|
|
|
|
|
buf = abi::__cxa_demangle(info->name(), nullptr, nullptr, nullptr);
|
|
|
|
name = buf;
|
|
|
|
free(buf);
|
|
|
|
|
|
|
|
return name;
|
|
|
|
}
|
2018-01-10 10:59:58 +00:00
|
|
|
|
|
|
|
// default writers/readers /////////////////////////////////////////////////////
|
|
|
|
#ifdef HAVE_HDF5
|
|
|
|
const std::string Hadrons::resultFileExt = "h5";
|
|
|
|
#else
|
|
|
|
const std::string Hadrons::resultFileExt = "xml";
|
|
|
|
#endif
|
2018-04-23 17:36:43 +01:00
|
|
|
|
|
|
|
// recursive mkdir /////////////////////////////////////////////////////////////
|
|
|
|
int Hadrons::mkdir(const std::string dirName)
|
|
|
|
{
|
2018-04-23 18:45:39 +01:00
|
|
|
if (!dirName.empty() and access(dirName.c_str(), R_OK|W_OK|X_OK))
|
2018-04-23 17:36:43 +01:00
|
|
|
{
|
|
|
|
mode_t mode755;
|
|
|
|
char tmp[MAX_PATH_LENGTH];
|
|
|
|
char *p = NULL;
|
|
|
|
size_t len;
|
|
|
|
|
|
|
|
mode755 = S_IRWXU|S_IRGRP|S_IXGRP|S_IROTH|S_IXOTH;
|
|
|
|
|
|
|
|
snprintf(tmp, sizeof(tmp), "%s", dirName.c_str());
|
|
|
|
len = strlen(tmp);
|
|
|
|
if(tmp[len - 1] == '/')
|
|
|
|
{
|
|
|
|
tmp[len - 1] = 0;
|
|
|
|
}
|
|
|
|
for(p = tmp + 1; *p; p++)
|
|
|
|
{
|
|
|
|
if(*p == '/')
|
|
|
|
{
|
|
|
|
*p = 0;
|
|
|
|
::mkdir(tmp, mode755);
|
|
|
|
*p = '/';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ::mkdir(tmp, mode755);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
std::string Hadrons::basename(const std::string &s)
|
|
|
|
{
|
|
|
|
constexpr char sep = '/';
|
|
|
|
size_t i = s.rfind(sep, s.length());
|
|
|
|
|
|
|
|
if (i != std::string::npos)
|
|
|
|
{
|
|
|
|
return s.substr(i+1, s.length() - i);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
}
|
2018-04-23 18:45:39 +01:00
|
|
|
|
|
|
|
std::string Hadrons::dirname(const std::string &s)
|
|
|
|
{
|
|
|
|
constexpr char sep = '/';
|
|
|
|
size_t i = s.rfind(sep, s.length());
|
|
|
|
|
|
|
|
if (i != std::string::npos)
|
|
|
|
{
|
|
|
|
return s.substr(0, i);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return "";
|
|
|
|
}
|
|
|
|
}
|
2018-05-07 19:43:40 +01:00
|
|
|
|
|
|
|
void Hadrons::makeFileDir(const std::string filename, GridBase *g)
|
|
|
|
{
|
|
|
|
if (g->IsBoss())
|
|
|
|
{
|
|
|
|
std::string dir = dirname(filename);
|
|
|
|
int status = mkdir(dir);
|
|
|
|
|
|
|
|
if (status)
|
|
|
|
{
|
|
|
|
HADRONS_ERROR(Io, "cannot create directory '" + dir
|
|
|
|
+ "' ( " + std::strerror(errno) + ")");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-08-10 16:07:30 +01:00
|
|
|
|
|
|
|
void Hadrons::printTimeProfile(const std::map<std::string, GridTime> &timing,
|
|
|
|
GridTime total)
|
|
|
|
{
|
|
|
|
typedef decltype(total.count()) Count;
|
|
|
|
|
|
|
|
std::map<Count, std::string, std::greater<Count>> rtiming;
|
|
|
|
const double dtotal = static_cast<double>(total.count());
|
|
|
|
auto cf = std::cout.flags();
|
2018-08-13 20:17:24 +01:00
|
|
|
auto p = std::cout.precision();
|
2018-08-10 16:07:30 +01:00
|
|
|
unsigned int width = 0;
|
|
|
|
|
|
|
|
for (auto &t: timing)
|
|
|
|
{
|
|
|
|
width = std::max(width, static_cast<unsigned int>(t.first.length()));
|
|
|
|
rtiming[t.second.count()] = t.first;
|
|
|
|
}
|
|
|
|
for (auto &rt: rtiming)
|
|
|
|
{
|
|
|
|
LOG(Message) << std::right << std::setw(width) << rt.second << ": "
|
|
|
|
<< rt.first << " us (" << std::fixed
|
|
|
|
<< std::setprecision(1)
|
|
|
|
<< static_cast<double>(rt.first)/dtotal*100 << "%)"
|
|
|
|
<< std::endl;
|
|
|
|
}
|
|
|
|
std::cout.flags(cf);
|
2018-08-13 20:17:24 +01:00
|
|
|
std::cout.precision(p);
|
2018-08-10 16:07:30 +01:00
|
|
|
}
|