Changes between Version 1 and Version 2 of doc/app/userint/subd


Ignore:
Timestamp:
Sep 15, 2010 8:39:54 AM (14 years ago)
Author:
suehring
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • doc/app/userint/subd

    v1 v2  
    11== Definition of user-defined subdomains ==
    22
    3 By default, the values of the timeseries quantities and the horizontally averaged vertical profiles (saved in local files PLOT1D_DATA and LIST_PROFIL) always refer to the total model domain. Independently, up to 9 time series or profiles for different user-defined subdomains can be computed and plotted additionally. Steering in principle is done via the initialization parameter statistic_regions.
    4 
    5 The exact definition of these subdomains has to be made by the user within the user-defined subroutine {{{user_init}}}. The subdomains are defined with a mask array named rmask, which has to be given the value 1.0 for all horizontal grid points belonging to the user-defined subdomain and the value ''0.0'', where grid points do not belong to the user-defined subdomain. In the model {{{rmask}}} is declared as:
     3By default, the values of the timeseries quantities and the horizontally averaged vertical profiles (saved in local files [../../iofiles#PLOT1D_DATA PLOT1D_DATA]  and [../../iofiles#LIST_PROFIL LIST_PROFIL]) always refer to the total model domain. Independently, up to 9 time series or profiles for different user-defined subdomains can be computed and plotted additionally. Steering in principle is done via the initialization parameter [../../inipar#statistic_regions statistic_regions].\\\\
     4The exact definition of these subdomains has to be made by the user within the user-defined subroutine {{{user_init}}}. The subdomains are defined with a mask array named {{{rmask}}}, which has to be given the value ''1.0'' for all horizontal grid points belonging to the user-defined subdomain and the value ''0.0'', where grid points do not belong to the user-defined subdomain. In the model {{{rmask}}} is declared as:
    65{{{
    7    REAL :: rmask (nys-1:nyn+1,nxl-1:nxr+1,0:9) .
     6REAL :: rmask(nys-1:nyn+1,nxl-1:nxr+1,0:9) .
    87}}}
    9 The first two indices are the grid point indices in y and x-direction. With parallel model runs {{{nxl}}}, {{{nxr}}}, {{{nys}}} and {{{nyn}}} are the array bounds of the respective subdomain (don't confuse this with the user-defined subdomain!) on the respective processor. With runs on one processor {{{nys}}} = {{{nxl}}} = ''0'' and {{{nxr}}} = [../../inipar#nx nx] and {{{nyn}}} = [../../inipar#ny ny]. The third index determines the user-defined subdomain. The total model domain carries the index ''0'', the user-defined subdomains have the values ''1'' to ''9''.
    10 
     8The first two indices are the grid point indices in y and x-direction. With parallel model runs {{{nxl}}}, {{{nxr}}}, {{{nys}}} and {{{nyn}}} are the array bounds of the respective subdomain (don't confuse this with the user-defined subdomain!) on the respective processor. With runs on one processor {{{nys}}} = {{{nxl}}} = ''0'' and {{{nxr}}} = [../../inipar#nx nx] and {{{nyn}}} = [../../inipar#ny ny]. The third index determines the user-defined subdomain. The total model domain carries the index ''0'', the user-defined subdomains have the values ''1'' to ''9''.\\\\
    119The following example should illustrate this. Two subdomains are defined by the user. The first is determined by all grid points which lie within a circle whose center is equal to the (horizontal) center of the model domain and whose diameter is equal to half of the total horizontal domain size (square total domain assumed). The second subdomain should be defined by all points outside of this domain. This may be obtained by the following lines of code in [..\int#user_init user_init]:
    1210{{{
    13    USE grid_variables
    14    USE indices
    15    USE statistics
    16       .
    17       .
    18       .
    19    disc_center_x = dx * (nx + 1)/2
    20    disc_center_y = dy * (ny + 1)/2
    21    disc_radius = 0.5 * disc_center_x
    22    DO  i = nxl-1, nxr+1
    23       x = i * dx
    24       DO  j = nys-1, nyn+1
    25          y = j * dy
    26          radial_distance = SQRT( ( x - disc_center_x )**2 + &
    27                ( y - disc_center_y )**2 )
    28          IF ( radial_distance > disc_radius )  THEN
    29             rmask(j,i,1) = 0.0
    30             rmask(j,i,2) = 1.0
    31          ELSE
    32             rmask(j,i,1) = 1.0
    33             rmask(j,i,2) = 0.0
    34          ENDIF
    35       ENDDO
     11USE grid_variables
     12USE indices
     13USE statistics
     14   .
     15   .
     16   .
     17disc_center_x = dx * (nx + 1)/2
     18disc_center_y = dy * (ny + 1)/2
     19disc_radius = 0.5 * disc_center_x
     20DO  i = nxl-1, nxr+1
     21   x = i * dx
     22   DO  j = nys-1, nyn+1
     23      y = j * dy
     24      radial_distance = SQRT( ( x - disc_center_x )**2 + &
     25           ( y - disc_center_y )**2 )
     26      IF ( radial_distance > disc_radius )  THEN
     27         rmask(j,i,1) = 0.0
     28         rmask(j,i,2) = 1.0
     29      ELSE
     30         rmask(j,i,1) = 1.0
     31         rmask(j,i,2) = 0.0
     32      ENDIF
    3633   ENDDO
     34ENDDO
    3735}}}
    38 The module statistics must be used, because it contains {{{rmask}}} and the modules {{{grid_variables}}} and {{{indices}}} are necessary in this example, because grid spacing and indices are used. All array elements of rmask ({{{rmask(:,:,:)}}}) are preset by the model with ''1.0''. In no case this assignment must be changed for the total domain (rmask(:,:,0))! Computations and output for the user-defined subdomains only take place if the user sets [../../inipar#statistic_regions statistic_regions] ≥ ''1''. Beyond that, names for the user-defined subdomains can be assigned via the initialization parameter [../../userpar#region region]. Output of the names of the selected user-defined subdomains happens in the local files [../../iofiles#HEADER HEADER] and [../../iofiles#RUN_CONTROL RUN_CONTROL] within the user-defined subroutine [../int#user_header user_header].
     36The module {{{statistics}}} must be used, because it contains {{{rmask}}} and the modules {{{grid_variables}}} and {{{indices}}} are necessary in this example, because grid spacing and indices are used. All array elements of {{{rmask}}} ({{{rmask(:,:,:)}}} are preset by the model with ''1.0''. In no case this assignment must be changed for the total domain ({{{rmask(:,:,0)}}})! Computations and output for the user-defined subdomains only take place if the user sets [../../inipar#statistic_regions statistic_regions] ≥ ''1''. Beyond that, names for the user-defined subdomains can be assigned via the initialization parameter [../../userpar#region region]. Output of the names of the selected user-defined subdomains happens in the local files [../../iofiles#HEADER HEADER] and [../../iofiles#RUN_CONTROL RUN_CONTROL] within the user-defined subroutine [../int#user_header user_header].