8 #error "Cannot compile with HAVE_CONFIG_H symbol! run configure first!"
14 #include "../../shared/shared.h"
15 #include "../Params/Parameters.h"
45 this->
inputs = xNew<Input2*>(N);
46 for(
int i=0;i<N;i++) this->
inputs[i] = NULL;
62 xDelete<Input2*>(this->
inputs);
152 Input2 **old_inputs = NULL;
159 xDelete<Input2*>(this->
inputs);
170 xDelete<Input2*>(old_inputs);
194 Input2 **old_inputs = NULL;
201 xDelete<Input2*>(this->
inputs);
212 xDelete<Input2*>(old_inputs);
236 input->
SetInput(interp_in,numindices,indices,values_in);
254 input->
SetInput(interp_in,numindices,indices,values_in);
286 _error_(
"Cannot return a TriaInput2");
300 _error_(
"Cannot return a TriaInput2");
310 _error_(
"Cannot return input for offset "<<offset);
317 return xDynamicCast<TriaInput2*>(input);
336 _error_(
"Cannot return a PentaInput2");
347 _error_(
"Cannot return input for offset "<<offset);
353 return xDynamicCast<PentaInput2*>(input);
365 _error_(
"Cannot return a PentaInput2");
381 _error_(
"Input not found (is TransientInput sorted ?)");
398 else if(offset==(this->
numtimesteps-1) || !linear_interp){
404 if(this->
current_step==reCast<IssmDouble>(offset))
return;
418 IssmDouble this_step = reCast<IssmDouble>(offset) + (time - this->timesteps[offset])/deltat;
427 IssmDouble alpha2=(time-this->timesteps[offset])/deltat;
444 int found,start_offset,end_offset,input_offset;
448 if(!found)
_error_(
"Input not found (is TransientInput sorted ?)");
450 if(!found)
_error_(
"Input not found (is TransientInput sorted ?)");
452 if(start_offset==-1){
453 timespan=this->
timesteps[end_offset]-start_time;
458 mid_step=reCast<IssmDouble>(start_offset)+0.5*timespan;
466 int offset=start_offset;
467 while(offset < end_offset){
468 if(offset==start_offset){
471 if(offset==end_offset-1){
472 dt=end_time-start_time;
476 else if(offset==end_offset-1){
486 switch(averaging_method){
488 if(offset==start_offset){
497 if(offset==start_offset){
502 stepinput->
Scale(dt);
507 if(offset==start_offset){
517 _error_(
"averaging method is not recognised");
525 switch(averaging_method){
536 _error_(
"averaging method is not recognised");
540 if(offset<0) offset=0;
552 if(!found)
_error_(
"Input not found (is TransientInput sorted ?)");