mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-07 06:33:05 -06:00
133 lines
4.2 KiB
C++
133 lines
4.2 KiB
C++
#ifdef USE_HDF5
|
|
|
|
#include "gtest/gtest.h"
|
|
|
|
#include "RiaTestDataDirectory.h"
|
|
#include "RifHdf5Exporter.h"
|
|
#include "RifHdf5SummaryReader.h"
|
|
#include "RifOpmHdf5Summary.h"
|
|
#include "RifReaderEclipseSummary.h"
|
|
|
|
#include "H5Cpp.h"
|
|
|
|
#include <iostream>
|
|
|
|
#include "RifHdf5SummaryExporter.h"
|
|
#include "opm/io/eclipse/ESmry.hpp"
|
|
#include <numeric>
|
|
|
|
static const QString H5_TEST_DATA_DIRECTORY = QString( "%1/h5-file/" ).arg( TEST_DATA_DIR );
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST( DISABLED_HDFTests, WriteToHdf5SummaryExporter )
|
|
{
|
|
QString file_path = H5_TEST_DATA_DIRECTORY + "NORNE_ATW2013_RFTPLT_V2.SMSPEC";
|
|
|
|
// RifReaderEclipseSummary eclReader;
|
|
// eclReader.open( file_path, true, nullptr );
|
|
|
|
Opm::EclIO::ESmry esmry( file_path.toStdString() );
|
|
|
|
RifHdf5SummaryExporter exporter;
|
|
std::string exportFileName = "e:/project/scratch_export/hdf_complete.h5";
|
|
|
|
exporter.writeSummaryDataToHdf( exportFileName, esmry );
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
///
|
|
//--------------------------------------------------------------------------------------------------
|
|
TEST( DISABLED_HDFTests, WriteDataToH5 )
|
|
{
|
|
QString file_path = H5_TEST_DATA_DIRECTORY + "NORNE_ATW2013_RFTPLT_V2.SMPEC";
|
|
|
|
try
|
|
{
|
|
RifReaderEclipseSummary summaryReader;
|
|
summaryReader.open( file_path, true, nullptr );
|
|
|
|
{
|
|
std::string exportFileName = "e:/project/scratch_export/hdf-test.h5";
|
|
|
|
H5::H5File file( exportFileName, H5F_ACC_TRUNC ); // Overwrite existing
|
|
|
|
// General group
|
|
{
|
|
std::vector<int> values( 7 );
|
|
|
|
int day = 1;
|
|
int month = 2;
|
|
int year = 3;
|
|
int hour = 4;
|
|
int minute = 5;
|
|
int second = 6;
|
|
int unknown = 7;
|
|
|
|
values[0] = day;
|
|
values[1] = month;
|
|
values[2] = year;
|
|
values[3] = hour;
|
|
values[4] = minute;
|
|
values[5] = second;
|
|
values[6] = 0;
|
|
|
|
auto generalGroup = file.createGroup( "/general" );
|
|
|
|
// start_date
|
|
{
|
|
hsize_t dimsf[1];
|
|
dimsf[0] = values.size();
|
|
H5::DataSpace dataspace( 1, dimsf );
|
|
|
|
H5::DataType datatype( H5::PredType::NATIVE_INT );
|
|
H5::DataSet dataset = generalGroup.createDataSet( "start_date", datatype, dataspace );
|
|
dataset.write( values.data(), H5::PredType::NATIVE_INT );
|
|
}
|
|
}
|
|
|
|
{
|
|
auto summaryGroup = file.createGroup( "/summary_vectors" );
|
|
auto myVectorGroup = summaryGroup.createGroup( "BPR" );
|
|
auto dataGroup = myVectorGroup.createGroup( "66" );
|
|
|
|
std::vector<float> a( 10 );
|
|
std::iota( a.begin(), a.end(), 10 );
|
|
|
|
// dataset dimensions
|
|
hsize_t dimsf[1];
|
|
dimsf[0] = a.size();
|
|
H5::DataSpace dataspace( 1, dimsf );
|
|
|
|
H5::DataType datatype( H5::PredType::NATIVE_FLOAT );
|
|
H5::DataSet dataset = dataGroup.createDataSet( "values", datatype, dataspace );
|
|
|
|
dataset.write( a.data(), H5::PredType::NATIVE_FLOAT );
|
|
}
|
|
}
|
|
}
|
|
|
|
catch ( H5::FileIException& error ) // catch failure caused by the H5File operations
|
|
{
|
|
std::cout << error.getCDetailMsg();
|
|
}
|
|
|
|
catch ( H5::DataSetIException& error ) // catch failure caused by the DataSet operations
|
|
{
|
|
std::cout << error.getCDetailMsg();
|
|
}
|
|
|
|
catch ( H5::DataSpaceIException& error ) // catch failure caused by the DataSpace operations
|
|
{
|
|
std::cout << error.getCDetailMsg();
|
|
}
|
|
|
|
catch ( H5::DataTypeIException& error ) // catch failure caused by the DataSpace operations
|
|
{
|
|
std::cout << error.getCDetailMsg();
|
|
}
|
|
}
|
|
|
|
#endif // USE_HDF5
|