Newer
Older
* Distributed under the OSI-approved Apache License, Version 2.0. See
* accompanying file Copyright.txt for details.
*
* Created on: Jan 9, 2017
* Author: Jason Wang
#include <chrono>
#include <iostream>
#include <numeric>
#include <thread>
// matches Signature1 in ADIOS2
template <class T>
void UserCallBack(const T *data, const std::string &doid,
const std::string &var, const std::string &dtype,
const std::vector<std::size_t> &varshape)
std::cout << "data object ID = " << doid << "\n";
std::cout << "variable name = " << var << "\n";
std::cout << "data type = " << dtype << "\n";
std::size_t varsize = std::accumulate(varshape.begin(), varshape.end(), 1,
std::multiplies<std::size_t>());
for (unsigned int i = 0; i < varsize; ++i)
std::cout << ((float *)data)[i] << " ";
MPI_Comm_rank(MPI_COMM_WORLD, &rank);
adios2::Operator &callbackFloat = adios.DefineOperator(
"Print float Variable callback",
std::function<void(const float *, const std::string &,
const std::string &, const std::string &,
const adios2::Dims &)>(UserCallBack<float>));
adios2::IO &dataManIO = adios.DeclareIO("WAN");
dataManIO.SetEngine("DataManReader");
dataManIO.SetParameters({{"real_time", "yes"},
{"method_type", "stream"},
{"method", "dump"}});
adios2::Engine &dataManReader =
dataManIO.Open("myDoubles.bp", adios2::Mode::Read);
// dataManReader.SetCallBack(UserCallBack);
for (unsigned int i = 0; i < 3; ++i)
{
std::this_thread::sleep_for(std::chrono::milliseconds(1000));
}
dataManIO.InquireVariable<double>("ioMyDoubles");
std::cout << "Variable ioMyDoubles not read...yet\n";
dataManReader.Close();
}
catch (std::invalid_argument &e)
std::cout << "Invalid argument exception, STOPPING PROGRAM from rank "
<< rank << "\n";
std::cout << e.what() << "\n";
catch (std::ios_base::failure &e)
std::cout << "IO System base failure exception, STOPPING PROGRAM "
"from rank "
<< rank << "\n";
std::cout << "Exception, STOPPING PROGRAM from rank " << rank << "\n";
std::cout << e.what() << "\n";