Exemple #1
0
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;
}
Exemple #2
0
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;
}
Exemple #3
0
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 );
}