libsim  Versione 7.1.7

◆ 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 2090 del file volgrid6d_class.F90.

2092 TYPE(vol7d),INTENT(out) :: vol7d_out
2093 TYPE(vol7d),INTENT(in),OPTIONAL :: v7d
2094 REAL,INTENT(in),OPTIONAL :: maskgrid(:,:)
2095 REAL,INTENT(in),OPTIONAL :: maskbounds(:)
2096 CHARACTER(len=*),OPTIONAL,INTENT(in) :: networkname
2097 LOGICAL,OPTIONAL,INTENT(in) :: noconvert
2098 PROCEDURE(basic_find_index),POINTER,OPTIONAL :: find_index
2099 CHARACTER(len=*),INTENT(in),OPTIONAL :: categoryappend
2100 
2101 type(grid_transform) :: grid_trans
2102 INTEGER :: ntime, ntimerange, nlevel, nvar, nana, time_definition, nnetwork, stallo
2103 INTEGER :: itime, itimerange, inetwork
2104 TYPE(datetime),ALLOCATABLE :: validitytime(:,:)
2105 INTEGER,ALLOCATABLE :: point_index(:)
2106 TYPE(vol7d) :: v7d_locana
2107 
2108 #ifdef DEBUG
2109 call l4f_category_log(volgrid6d_in%category,l4f_debug,"start volgrid6d_v7d_transform")
2110 #endif
2111 
2112 call vg6d_wind_unrot(volgrid6d_in)
2113 
2114 ntime=0
2115 ntimerange=0
2116 nlevel=0
2117 nvar=0
2118 nnetwork=1
2119 

Generated with Doxygen.