Files
ResInsight/ThirdParty/Ert/lib/ecl/ecl_rsthead.cpp

248 lines
8.3 KiB
C++

/*
Copyright (C) 2011 Statoil ASA, Norway.
The file 'ecl_rsthead.c' is part of ERT - Ensemble based Reservoir Tool.
ERT 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 3 of the License, or
(at your option) any later version.
ERT 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 at <http://www.gnu.org/licenses/gpl.html>
for more details.
*/
#include <stdlib.h>
#include <ert/util/util.h>
#include <ert/ecl/ecl_file.hpp>
#include <ert/ecl/ecl_file_view.hpp>
#include <ert/ecl/ecl_kw.hpp>
#include <ert/ecl/ecl_rsthead.hpp>
#include <ert/ecl/ecl_kw_magic.hpp>
static time_t rsthead_date( int day , int month , int year) {
return ecl_util_make_date( day , month, year );
}
time_t ecl_rsthead_date( const ecl_kw_type * intehead_kw ) {
return rsthead_date( ecl_kw_iget_int( intehead_kw , INTEHEAD_DAY_INDEX) ,
ecl_kw_iget_int( intehead_kw , INTEHEAD_MONTH_INDEX) ,
ecl_kw_iget_int( intehead_kw , INTEHEAD_YEAR_INDEX) );
}
time_t ecl_rsthead_get_sim_time( const ecl_rsthead_type * header ) {
return header->sim_time;
}
double ecl_rsthead_get_sim_days( const ecl_rsthead_type * header ) {
return header->sim_days;
}
int ecl_rsthead_get_report_step( const ecl_rsthead_type * header ) {
return header->report_step;
}
ecl_rsthead_type * ecl_rsthead_alloc_from_kw( int report_step , const ecl_kw_type * intehead_kw , const ecl_kw_type * doubhead_kw , const ecl_kw_type * logihead_kw ) {
ecl_rsthead_type * rsthead = (ecl_rsthead_type*)util_malloc( sizeof * rsthead );
rsthead->report_step = report_step;
{
const int * data = (const int *) ecl_kw_get_void_ptr( intehead_kw );
rsthead->day = data[INTEHEAD_DAY_INDEX];
rsthead->month = data[INTEHEAD_MONTH_INDEX];
rsthead->year = data[INTEHEAD_YEAR_INDEX];
rsthead->version = data[INTEHEAD_IPROG_INDEX];
rsthead->phase_sum = data[INTEHEAD_PHASE_INDEX];
rsthead->nx = data[INTEHEAD_NX_INDEX];
rsthead->ny = data[INTEHEAD_NY_INDEX];
rsthead->nz = data[INTEHEAD_NZ_INDEX];
rsthead->nactive = data[INTEHEAD_NACTIVE_INDEX];
rsthead->nwells = data[INTEHEAD_NWELLS_INDEX];
rsthead->niwelz = data[INTEHEAD_NIWELZ_INDEX];
rsthead->nxwelz = data[INTEHEAD_NXWELZ_INDEX];
rsthead->nzwelz = data[INTEHEAD_NZWELZ_INDEX];
rsthead->nsconz = data[INTEHEAD_NSCONZ_INDEX];
rsthead->nxconz = data[INTEHEAD_NXCONZ_INDEX];
rsthead->niconz = data[INTEHEAD_NICONZ_INDEX];
rsthead->ncwmax = data[INTEHEAD_NCWMAX_INDEX];
rsthead->nisegz = data[INTEHEAD_NISEGZ_INDEX];
rsthead->nsegmx = data[INTEHEAD_NSEGMX_INDEX];
rsthead->nswlmx = data[INTEHEAD_NSWLMX_INDEX];
rsthead->nrsegz = data[INTEHEAD_NRSEGZ_INDEX];
// The only derived quantity
rsthead->sim_time = rsthead_date( rsthead->day , rsthead->month , rsthead->year );
}
if (doubhead_kw)
rsthead->sim_days = ecl_kw_iget_double( doubhead_kw , DOUBHEAD_DAYS_INDEX );
if (logihead_kw)
rsthead->dualp = ecl_kw_iget_bool( logihead_kw , LOGIHEAD_DUALP_INDEX);
return rsthead;
}
/*
- If the rst_view corresponds to a block of an underlying unified
restart file the report_step value will be inferred from the
SEQNUM keyword.
- If the rst_view corresponds to an underlying non-unified restart
file the report step must have been inferred from the filename
*prior* to calling this function.
*/
ecl_rsthead_type * ecl_rsthead_alloc( const ecl_file_view_type * rst_view, int report_step) {
const ecl_kw_type * intehead_kw = ecl_file_view_iget_named_kw( rst_view , INTEHEAD_KW , 0);
const ecl_kw_type * doubhead_kw = NULL;
const ecl_kw_type * logihead_kw = NULL;
if (ecl_file_view_has_kw(rst_view, LOGIHEAD_KW))
logihead_kw = ecl_file_view_iget_named_kw( rst_view , LOGIHEAD_KW , 0);
if (ecl_file_view_has_kw(rst_view, DOUBHEAD_KW))
doubhead_kw = ecl_file_view_iget_named_kw(rst_view, DOUBHEAD_KW, 0);
if (ecl_file_view_has_kw( rst_view , SEQNUM_KW)) {
const ecl_kw_type * seqnum_kw = ecl_file_view_iget_named_kw( rst_view , SEQNUM_KW , 0);
report_step = ecl_kw_iget_int( seqnum_kw , 0);
}
return ecl_rsthead_alloc_from_kw( report_step , intehead_kw , doubhead_kw , logihead_kw );
}
ecl_rsthead_type * ecl_rsthead_alloc_empty() {
ecl_rsthead_type * rsthead = (ecl_rsthead_type*)util_malloc( sizeof * rsthead );
rsthead->day = 0;
rsthead->month = 0;
rsthead->year = 0;
rsthead->version = 0;
rsthead->phase_sum = 0;
rsthead->nx = 0;
rsthead->ny = 0;
rsthead->nz = 0;
rsthead->nactive = 0;
rsthead->nwells = 0;
rsthead->niwelz = 0;
rsthead->nzwelz = 0;
rsthead->nsconz = 0;
rsthead->niconz = 0;
rsthead->ncwmax = 0;
rsthead->nisegz = 0;
rsthead->nsegmx = 0;
rsthead->nswlmx = 0;
rsthead->nrsegz = 0;
rsthead->sim_time = 0;
rsthead->dualp = false;
rsthead->sim_days = 0.0;
return rsthead;
}
void ecl_rsthead_fprintf( const ecl_rsthead_type * header , FILE * stream) {
fprintf(stream , "nx %d \n",header->nx);
fprintf(stream , "nwells %d \n",header->nwells);
fprintf(stream , "niwelz %d \n\n",header->niwelz);
}
bool ecl_rsthead_equal( const ecl_rsthead_type * header1 , const ecl_rsthead_type * header2) {
bool equal = true;
equal = equal && (header1->day == header2->day);
equal = equal && (header1->year == header2->year);
equal = equal && (header1->month == header2->month);
equal = equal && (header1->sim_time == header2->sim_time);
equal = equal && (header1->version == header2->version);
equal = equal && (header1->phase_sum == header2->phase_sum);
equal = equal && (header1->nx == header2->nx);
equal = equal && (header1->ny == header2->ny);
equal = equal && (header1->nz == header2->nz);
equal = equal && (header1->nactive == header2->nactive);
equal = equal && (header1->nwells == header2->nwells);
equal = equal && (header1->niwelz == header2->niwelz);
equal = equal && (header1->nzwelz == header2->nzwelz);
equal = equal && (header1->niconz == header2->niconz);
equal = equal && (header1->ncwmax == header2->ncwmax);
equal = equal && (header1->nisegz == header2->nisegz);
equal = equal && (header1->nsegmx == header2->nsegmx);
equal = equal && (header1->nswlmx == header2->nswlmx);
equal = equal && (header1->nlbrmx == header2->nlbrmx);
equal = equal && (header1->nilbrz == header2->nilbrz);
equal = equal && (header1->dualp == header2->dualp);
equal = equal && util_double_approx_equal(header1->sim_days , header2->sim_days );
return equal;
}
void ecl_rsthead_fprintf_struct( const ecl_rsthead_type * header , FILE * stream) {
fprintf(stream , "{.day = %d,\n",header->day);
fprintf(stream , ".year = %d,\n",header->year);
fprintf(stream , ".month = %d,\n",header->month);
fprintf(stream , ".sim_time = %ld,\n",header->sim_time);
fprintf(stream , ".version = %d,\n",header->version);
fprintf(stream , ".phase_sum = %d,\n",header->phase_sum);
fprintf(stream , ".nx = %d,\n",header->nx);
fprintf(stream , ".ny = %d,\n",header->ny);
fprintf(stream , ".nz = %d,\n",header->nz);
fprintf(stream , ".nactive = %d,\n",header->nactive);
fprintf(stream , ".nwells = %d,\n",header->nwells);
fprintf(stream , ".niwelz = %d,\n",header->niwelz);
fprintf(stream , ".nzwelz = %d,\n",header->nzwelz);
fprintf(stream , ".niconz = %d,\n",header->niconz);
fprintf(stream , ".ncwmax = %d,\n",header->ncwmax);
fprintf(stream , ".nisegz = %d,\n",header->nisegz);
fprintf(stream , ".nsegmx = %d,\n",header->nsegmx);
fprintf(stream , ".nswlmx = %d,\n",header->nswlmx);
fprintf(stream , ".nlbrmx = %d,\n",header->nlbrmx);
fprintf(stream , ".nilbrz = %d,\n",header->nilbrz);
fprintf(stream , ".dualp = %d,\n",header->dualp);
fprintf(stream , ".sim_days = %g};\n",header->sim_days);
}
void ecl_rsthead_free( ecl_rsthead_type * rsthead ) {
free( rsthead );
}
int ecl_rsthead_get_nxconz( const ecl_rsthead_type * rsthead ) {
return rsthead->nxconz;
}
int ecl_rsthead_get_ncwmax( const ecl_rsthead_type * rsthead ) {
return rsthead->ncwmax;
}