void well_segment_collection_add_connections(well_segment_collection_type * segment_collection , const char * grid_name , const well_conn_collection_type * connections) { int iconn; for (iconn = 0; iconn < well_conn_collection_get_size( connections ); iconn++) { well_conn_type * conn = well_conn_collection_iget( connections , iconn ); if (well_conn_MSW( conn )) { int segment_id = well_conn_get_segment_id( conn ); well_segment_type * segment = well_segment_collection_get( segment_collection , segment_id ); well_segment_add_connection( segment , grid_name , conn ); } } }
int main(int argc , char ** argv) { const char * Xfile = argv[1]; bool MSW; ecl_file_type * rst_file = ecl_file_open( Xfile , 0 ); ecl_rsthead_type * rst_head = ecl_rsthead_alloc( ecl_file_get_global_view(rst_file) , ecl_util_filename_report_nr( Xfile )); test_install_SIGNALS(); test_assert_true( util_sscanf_bool( argv[2] , &MSW )); test_assert_not_NULL( rst_file ); test_assert_not_NULL( rst_head ); { int iwell; const ecl_kw_type * iwel_kw = ecl_file_iget_named_kw( rst_file , IWEL_KW , 0 ); const ecl_kw_type * icon_kw = ecl_file_iget_named_kw( rst_file , ICON_KW , 0 ); ecl_kw_type * scon_kw = NULL; bool caseMSW = false; for (iwell = 0; iwell < rst_head->nwells; iwell++) { const int iwel_offset = rst_head->niwelz * iwell; int num_connections = ecl_kw_iget_int( iwel_kw , iwel_offset + IWEL_CONNECTIONS_INDEX ); int iconn; well_conn_collection_type * wellcc = well_conn_collection_alloc( ); well_conn_collection_type * wellcc_ref = well_conn_collection_alloc(); for (iconn = 0; iconn < num_connections; iconn++) { well_conn_type * conn = well_conn_alloc_from_kw( icon_kw , scon_kw , rst_head , iwell , iconn ); test_assert_true( well_conn_is_instance( conn )); test_assert_not_NULL( conn ); if (!MSW) test_assert_bool_equal( well_conn_MSW( conn ) , MSW); else caseMSW |= well_conn_MSW( conn ); well_conn_collection_add( wellcc , conn ); well_conn_collection_add_ref( wellcc_ref , conn ); test_assert_int_equal( iconn + 1 , well_conn_collection_get_size( wellcc )); test_assert_ptr_equal( well_conn_collection_iget_const( wellcc , iconn) , conn); test_assert_ptr_equal( well_conn_collection_iget_const( wellcc_ref , iconn) , conn); } well_conn_collection_free( wellcc_ref ); { int i; for (i=0; i < well_conn_collection_get_size( wellcc ); i++) test_assert_true( well_conn_is_instance( well_conn_collection_iget_const( wellcc , i ))); } { well_conn_collection_type * wellcc2 = well_conn_collection_alloc(); int i; test_assert_int_equal( well_conn_collection_get_size( wellcc ) , well_conn_collection_load_from_kw( wellcc2 , iwel_kw , icon_kw , scon_kw , iwell , rst_head)); for (i=0; i < well_conn_collection_get_size( wellcc2 ); i++) { test_assert_true( well_conn_is_instance( well_conn_collection_iget_const( wellcc2 , i ))); test_assert_true( well_conn_equal( well_conn_collection_iget_const( wellcc2 , i ) , well_conn_collection_iget_const( wellcc , i ))); } well_conn_collection_free( wellcc2 ); } well_conn_collection_free( wellcc ); } test_assert_bool_equal( caseMSW , MSW); } exit( 0 ); }
int main(int argc , char ** argv) { int i = 10; int j = 5; int k = 16; double CF = 0; bool open = true; test_install_SIGNALS(); { well_conn_dir_enum dir = well_conn_dirX; well_conn_type * conn = well_conn_alloc(i,j,k,CF,dir,open); well_conn_type * conn2 = well_conn_alloc(i,j,k,CF,dir,open); well_conn_type * conn3 = well_conn_alloc(i,j,k+1,CF,dir,open); test_assert_not_NULL( conn ); test_assert_true( well_conn_is_instance( conn )); test_assert_int_equal( i , well_conn_get_i( conn )); test_assert_int_equal( j , well_conn_get_j( conn )); test_assert_int_equal( k , well_conn_get_k( conn )); test_assert_int_equal( dir , well_conn_get_dir( conn )); test_assert_bool_equal( open , well_conn_open( conn )); test_assert_false( well_conn_MSW( conn )); test_assert_true( well_conn_matrix_connection( conn )); test_assert_true( well_conn_equal( conn , conn2 )); test_assert_false( well_conn_equal( conn , conn3 )); test_assert_double_equal( CF , well_conn_get_connection_factor( conn )); well_conn_free( conn3 ); well_conn_free( conn2 ); well_conn_free( conn ); } { well_conn_dir_enum dir = well_conn_fracX; well_conn_type * conn = well_conn_alloc(i,j,k,CF,dir,open); test_assert_NULL( conn ); } { well_conn_dir_enum dir = well_conn_fracX; well_conn_type * conn = well_conn_alloc_fracture(i,j,k,CF,dir,open); test_assert_not_NULL( conn ); test_assert_int_equal( i , well_conn_get_i( conn )); test_assert_int_equal( j , well_conn_get_j( conn )); test_assert_int_equal( k , well_conn_get_k( conn )); test_assert_bool_equal( open , well_conn_open( conn )); test_assert_int_equal( dir , well_conn_get_dir( conn )); test_assert_false( well_conn_MSW( conn )); test_assert_false( well_conn_matrix_connection( conn )); test_assert_true( well_conn_fracture_connection( conn )); well_conn_free( conn ); } { well_conn_dir_enum dir = well_conn_dirX; well_conn_type * conn = well_conn_alloc_fracture(i,j,k,CF,dir,open); test_assert_not_NULL( conn ); well_conn_free( conn ); } { int segment = 16; well_conn_dir_enum dir = well_conn_dirX; well_conn_type * conn = well_conn_alloc_MSW(i,j,k,CF,dir,open,segment); test_assert_not_NULL( conn ); test_assert_int_equal( i , well_conn_get_i( conn )); test_assert_int_equal( j , well_conn_get_j( conn )); test_assert_int_equal( k , well_conn_get_k( conn )); test_assert_int_equal( segment , well_conn_get_segment_id( conn )); test_assert_bool_equal( open , well_conn_open( conn )); test_assert_int_equal( dir , well_conn_get_dir( conn )); test_assert_true( well_conn_MSW( conn )); test_assert_true( well_conn_matrix_connection( conn )); well_conn_free( conn ); } { int segment = 16; well_conn_dir_enum dir = well_conn_fracX; well_conn_type * conn = well_conn_alloc_fracture_MSW(i,j,k,CF,dir,open,segment); test_assert_not_NULL( conn ); test_assert_int_equal( i , well_conn_get_i( conn )); test_assert_int_equal( j , well_conn_get_j( conn )); test_assert_int_equal( k , well_conn_get_k( conn )); test_assert_int_equal( segment , well_conn_get_segment_id( conn )); test_assert_bool_equal( open , well_conn_open( conn )); test_assert_int_equal( dir , well_conn_get_dir( conn )); test_assert_true( well_conn_MSW( conn )); test_assert_false( well_conn_matrix_connection( conn )); well_conn_free( conn ); } test_conn_rate(); }