static int __conf_instance_get_restart_nr(const conf_instance_type * conf_instance, const char * obs_key , time_map_type * time_map , bool prefer_restart) { int obs_restart_nr = -1; /* To shut up compiler warning. */ if(conf_instance_has_item(conf_instance, "RESTART")) { obs_restart_nr = conf_instance_get_item_value_int(conf_instance, "RESTART"); if (obs_restart_nr > time_map_get_last_step( time_map)) util_abort("%s: Observation %s occurs at restart %i, but history file has only %i restarts.\n", __func__, obs_key, obs_restart_nr, time_map_get_last_step( time_map )); } else { time_t obs_time = time_map_get_start_time( time_map ); if(conf_instance_has_item(conf_instance, "DATE")) { obs_time = conf_instance_get_item_value_time_t(conf_instance, "DATE" ); if (prefer_restart) obs_vector_prefer_RESTART_warning(); } else if (conf_instance_has_item(conf_instance, "DAYS")) { double days = conf_instance_get_item_value_double(conf_instance, "DAYS"); util_inplace_forward_days( &obs_time , days ); if (prefer_restart) obs_vector_prefer_RESTART_warning(); } else if (conf_instance_has_item(conf_instance, "HOURS")) { double hours = conf_instance_get_item_value_double(conf_instance, "HOURS"); util_inplace_forward_seconds( &obs_time , hours * 3600 ); if (prefer_restart) obs_vector_prefer_RESTART_warning(); } else util_abort("%s: Internal error. Invalid conf_instance?\n", __func__); obs_restart_nr = time_map_lookup_time_with_tolerance( time_map , obs_time , 30 , 30 ); } if (obs_restart_nr < 0) util_abort("%s: Failed to look up restart nr correctly \n",__func__); return obs_restart_nr; }
time_t_vector_type * ecl_sum_alloc_time_solution( const ecl_sum_type * ecl_sum , const char * gen_key , double cmp_value , bool rates_clamp_lower) { time_t_vector_type * solution = time_t_vector_alloc( 0 , 0); { double_vector_type * seconds = ecl_sum_alloc_seconds_solution( ecl_sum , gen_key , cmp_value , rates_clamp_lower ); time_t start_time = ecl_sum_get_start_time(ecl_sum); for (int i=0; i < double_vector_size( seconds ); i++) { time_t t = start_time; util_inplace_forward_seconds( &t , double_vector_iget( seconds , i )); time_t_vector_append( solution , t ); } double_vector_free( seconds ); } return solution; }
static void ecl_sum_tstep_set_time_info_from_seconds( ecl_sum_tstep_type * tstep , time_t sim_start , float sim_seconds) { tstep->sim_seconds = sim_seconds; tstep->sim_time = sim_start; util_inplace_forward_seconds( &tstep->sim_time , tstep->sim_seconds ); }