Changes between Initial Version and Version 1 of U_distribute_state


Ignore:
Timestamp:
Jan 21, 2015, 11:49:36 AM (10 years ago)
Author:
lnerger
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • U_distribute_state

    v1 v1  
     1= U_distribute_state =
     2
     3The page document the user-supplied call-back routine `U_distribute_state`.
     4
     5The routine `U_distribute_state` is a call-back routine that has to be provided by the user. In the simplified interface the predefined name of the routine is `distribute_state_pdaf`, but in the full interface, the user can choose the name of the routine.
     6`U_distribute_state` is called by `PDAF_get_state` and `PDAF_assimilate_X` with 'X' being the name of a filter method. The routine is called at the beginning of a forecast phase once for each ensemble member and as many times as there are states to be integrated by a model task. The purpose of the routine is to fill the model fields from the state information contained in the provided state vector.
     7
     8The interface is the following:
     9{{{
     10SUBROUTINE U_distribute_state(dim_p, state_p)
     11}}}
     12with
     13 * `dim_p` : `integer, intent(in)`[[BR]] Size of the provided state vector
     14 * `state_p`: `real, intent(inout), dimension(dim_p)`[[BR]] State vector for process-local model sub-domain
     15
     16Notes:
     17 * When the routine is called a state vector `state_p` and its size `dim_p` are provided. As the user has defined how the model fields are stored in the state vector, one can initialize the model fields from this information.
     18 * If the model is not parallelized, `state_p` will contain a full state vector. If the model is parallelized using domain decomposition, `state_p` will contain the part of the state vector that corresponds to the model sub-domain for the calling process.
     19 * The operations performed in `U_distribute_state` and `U_collect_state` are the inverse operations of each other.
     20 * The routine is executed by all processes that belong to model tasks.
     21
     22Some hints:
     23 * If the state vector does not include all model fields, it can be useful to keep a separate array to store those additional fields. This array has to be kept separate from PDAF, but can be defined using a module like `mod_assimilation`.
     24