ecl_kw_type * ecl_nnc_export_get_tranx_kw( const ecl_grid_type * grid , const ecl_file_type * init_file , int lgr_nr1, int lgr_nr2 ) { if (lgr_nr1 == lgr_nr2) return ecl_nnc_export_get_tran_kw( init_file , TRANNNC_KW , lgr_nr2 ); else { if (lgr_nr1 == 0) return ecl_nnc_export_get_tran_kw( init_file , TRANGL_KW , lgr_nr2 ); else return ecl_nnc_export_get_tranll_kw( grid , init_file , lgr_nr1 , lgr_nr2 ); } }
void test_get_tran(const char * name) { char * grid_file_name = ecl_util_alloc_filename(NULL , name , ECL_EGRID_FILE , false , -1); char * init_file_name = ecl_util_alloc_filename(NULL , name , ECL_INIT_FILE , false , -1); ecl_grid_type * grid = ecl_grid_alloc( grid_file_name ); ecl_file_type * grid_file = ecl_file_open( grid_file_name , 0 ); ecl_file_type * init_file = ecl_file_open( init_file_name , 0 ); /* Get global */ { ecl_kw_type * tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANNNC_KW , 0 ); test_assert_true( ecl_kw_is_instance( tran_kw )); test_assert_double_equal( 0.85582769 , ecl_kw_iget_as_double( tran_kw , 0 )); test_assert_double_equal( 0.24635284 , ecl_kw_iget_as_double( tran_kw , 7184 )); } test_assert_NULL( ecl_nnc_export_get_tran_kw( init_file , TRANGL_KW , 0 )); test_assert_NULL( ecl_nnc_export_get_tran_kw( init_file , TRANLL_KW , 0 )); test_assert_NULL( ecl_nnc_export_get_tran_kw( init_file , "INVALID" , 1)); /* Get lgr_nr: 48 */ { ecl_kw_type * tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANNNC_KW , 48 ); test_assert_true( ecl_kw_is_instance( tran_kw )); test_assert_int_equal( 0 , ecl_kw_get_size( tran_kw )); tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANGL_KW , 48 ); test_assert_int_equal( 282 , ecl_kw_get_size( tran_kw )); test_assert_double_equal( 22.922695 , ecl_kw_iget_as_double( tran_kw , 0 )); test_assert_double_equal( 16.720325 , ecl_kw_iget_as_double( tran_kw , 281 )); } /* Get lgr_nr: 99 */ { ecl_kw_type * tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANNNC_KW , 99 ); test_assert_true( ecl_kw_is_instance( tran_kw )); test_assert_int_equal( 0 , ecl_kw_get_size( tran_kw )); tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANGL_KW , 99 ); test_assert_int_equal( 693 , ecl_kw_get_size( tran_kw )); test_assert_double_equal( 0.25534782 , ecl_kw_iget_as_double( tran_kw , 0 )); test_assert_double_equal( 0.12677453 , ecl_kw_iget_as_double( tran_kw , 692 )); } /* Get lgr_nr: 10 */ { ecl_kw_type * tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANNNC_KW , 10 ); test_assert_true( ecl_kw_is_instance( tran_kw )); test_assert_int_equal( 0 , ecl_kw_get_size( tran_kw )); tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANGL_KW , 10 ); test_assert_int_equal( 260 , ecl_kw_get_size( tran_kw )); test_assert_double_equal( 0.87355447 , ecl_kw_iget_as_double( tran_kw , 0 )); test_assert_double_equal( 26.921568 , ecl_kw_iget_as_double( tran_kw , 259 )); } /* Get lgr_nr: 110 */ { ecl_kw_type * tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANNNC_KW , 110 ); test_assert_true( ecl_kw_is_instance( tran_kw )); test_assert_int_equal( 0 , ecl_kw_get_size( tran_kw )); tran_kw = ecl_nnc_export_get_tran_kw( init_file , TRANGL_KW , 110 ); test_assert_int_equal( 208 , ecl_kw_get_size( tran_kw )); test_assert_double_equal( 17.287283 , ecl_kw_iget_as_double( tran_kw , 0 )); test_assert_double_equal( 569.26312 , ecl_kw_iget_as_double( tran_kw , 207 )); } free( init_file_name ); free(grid_file_name); ecl_grid_free( grid ); ecl_file_close( grid_file ); ecl_file_close( init_file ); }