libsim Versione 7.2.1

◆ volgrid6dv_transform()

subroutine volgrid6dv_transform ( type(transform_def), intent(in)  this,
type(griddim_def), intent(in), optional  griddim,
type(volgrid6d), dimension(:), intent(inout)  volgrid6d_in,
type(volgrid6d), dimension(:), pointer  volgrid6d_out,
type(vol7d_level), dimension(:), intent(in), optional  lev_out,
type(volgrid6d), intent(in), optional  volgrid6d_coord_in,
real, dimension(:,:), intent(in), optional  maskgrid,
real, dimension(:), intent(in), optional  maskbounds,
logical, intent(in), optional  clone,
logical, intent(in), optional  decode,
character(len=*), intent(in), optional  categoryappend 
)

Performs the specified abstract transformation on the arrays of data provided.

The abstract transformation is specified by this parameter; the corresponding specifical transformation (grid_transform object) is created and destroyed internally. The output transformed object is created internally and it does not require preliminary initialisation. According to the input data and to the transformation type, the output array may have of one or more volgrid6d elements on different grids.

Parametri
[in]thisobject specifying the abstract transformation
[in]griddimgriddim specifying the output grid (required by most transformation types)
[in,out]volgrid6d_inobject to be transformed, it is an array of volgrid6d objects, each of which will be transformed, it is not modified, despite the INTENT(inout)
volgrid6d_outtransformed object, it is a non associated pointer to an array of volgrid6d objects which will be allocated by the method
[in]lev_outvol7d_level object defining target vertical grid
[in]volgrid6d_coord_inobject providing time constant input vertical coordinate for some kind of vertical interpolations
[in]maskgrid2D field to be used for defining subareas according to its values, it must have the same shape as the field to be interpolated (for transformation subtype 'maskfill')
[in]maskboundsarray of boundary values for defining a subset of valid points where the values of maskgrid are within the first and last value of maskbounds (for transformation type 'metamorphosis:maskfill')
[in]cloneif provided and .TRUE. , clone the gaid's from volgrid6d_in to volgrid6d_out
[in]decodeif provided and .FALSE. the data volume is not allocated, but work is performed on grid_id's
[in]categoryappendappend this suffix to log4fortran namespace category

Definizione alla linea 2084 del file volgrid6d_class.F90.

2086!! is created internally and it does not require preliminary
2087!! initialisation.
2088SUBROUTINE volgrid6d_v7d_transform(this, volgrid6d_in, vol7d_out, v7d, &
2089 maskgrid, maskbounds, networkname, noconvert, find_index, categoryappend)
2090TYPE(transform_def),INTENT(in) :: this
2091TYPE(volgrid6d),INTENT(inout) :: volgrid6d_in
2092TYPE(vol7d),INTENT(out) :: vol7d_out
2093TYPE(vol7d),INTENT(in),OPTIONAL :: v7d
2094REAL,INTENT(in),OPTIONAL :: maskgrid(:,:)
2095REAL,INTENT(in),OPTIONAL :: maskbounds(:)
2096CHARACTER(len=*),OPTIONAL,INTENT(in) :: networkname
2097LOGICAL,OPTIONAL,INTENT(in) :: noconvert
2098PROCEDURE(basic_find_index),POINTER,OPTIONAL :: find_index
2099CHARACTER(len=*),INTENT(in),OPTIONAL :: categoryappend
2100
2101type(grid_transform) :: grid_trans
2102INTEGER :: ntime, ntimerange, nlevel, nvar, nana, time_definition, nnetwork, stallo
2103INTEGER :: itime, itimerange, inetwork
2104TYPE(datetime),ALLOCATABLE :: validitytime(:,:)
2105INTEGER,ALLOCATABLE :: point_index(:)
2106TYPE(vol7d) :: v7d_locana
2107
2108#ifdef DEBUG
2109call l4f_category_log(volgrid6d_in%category,l4f_debug,"start volgrid6d_v7d_transform")
2110#endif
2111
2112call vg6d_wind_unrot(volgrid6d_in)
2113

Generated with Doxygen.