source: palm/trunk/SOURCE/check_open.f90 @ 667

Last change on this file since 667 was 667, checked in by suehring, 14 years ago

summary:


Gryschka:

  • Coupling with different resolution and different numbers of PEs in ocean and atmosphere is available
  • Exchange of u and v from ocean surface to atmosphere surface
  • Mirror boundary condition for u and v at the bottom are replaced by dirichlet boundary conditions
  • Inflow turbulence is now defined by flucuations around spanwise mean
  • Bugfixes for cyclic_fill and constant_volume_flow

Suehring:

  • New advection added ( Wicker and Skamarock 5th order ), therefore:
    • New module advec_ws.f90
    • Modified exchange of ghost boundaries.
    • Modified evaluation of turbulent fluxes
    • New index bounds nxlg, nxrg, nysg, nyng

advec_ws.f90


Advection scheme for scalars and momentum using the flux formulation of
Wicker and Skamarock 5th order.
Additionally the module contains of a routine using for initialisation and
steering of the statical evaluation. The computation of turbulent fluxes takes
place inside the advection routines.
In case of vector architectures Dirichlet and Radiation boundary conditions are
outstanding and not available. Furthermore simulations within topography are
not possible so far. A further routine local_diss_ij is available and is used
if a control of dissipative fluxes is desired.

check_parameters.f90


Exchange of parameters between ocean and atmosphere via PE0
Check for illegal combination of ws-scheme and timestep scheme.
Check for topography and ws-scheme.
Check for not cyclic boundary conditions in combination with ws-scheme and
loop_optimization = 'vector'.
Check for call_psolver_at_all_substeps and ws-scheme for momentum_advec.

Different processor/grid topology in atmosphere and ocean is now allowed!
Bugfixes in checking for conserve_volume_flow_mode.

exchange_horiz.f90


Dynamic exchange of ghost points with nbgp_local to ensure that no useless
ghost points exchanged in case of multigrid. type_yz(0) and type_xz(0) used for
normal grid, the remaining types used for the several grid levels.
Exchange is done via MPI-Vectors with a dynamic value of ghost points which
depend on the advection scheme. Exchange of left and right PEs is 10% faster
with MPI-Vectors than without.

flow_statistics.f90


When advection is computed with ws-scheme, turbulent fluxes are already
computed in the respective advection routines and buffered in arrays
sums_xxxx_ws_l(). This is due to a consistent treatment of statistics
with the numerics and to avoid unphysical kinks near the surface. So some if-
requests has to be done to dicern between fluxes from ws-scheme other advection
schemes. Furthermore the computation of z_i is only done if the heat flux
exceeds a minimum value. This affects only simulations of a neutral boundary
layer and is due to reasons of computations in the advection scheme.

inflow_turbulence.f90


Using nbgp recycling planes for a better resolution of the turbulent flow near
the inflow.

init_grid.f90


Definition of new array bounds nxlg, nxrg, nysg, nyng on each PE.
Furthermore the allocation of arrays and steering of loops is done with these
parameters. Call of exchange_horiz are modified.
In case of dirichlet bounday condition at the bottom zu(0)=0.0
dzu_mg has to be set explicitly for a equally spaced grid near bottom.
ddzu_pres added to use a equally spaced grid near bottom.

init_pegrid.f90


Moved determination of target_id's from init_coupling
Determination of parameters needed for coupling (coupling_topology, ngp_a, ngp_o)
with different grid/processor-topology in ocean and atmosphere

Adaption of ngp_xy, ngp_y to a dynamic number of ghost points.
The maximum_grid_level changed from 1 to 0. 0 is the normal grid, 1 to
maximum_grid_level the grids for multigrid, in which 0 and 1 are normal grids.
This distinction is due to reasons of data exchange and performance for the
normal grid and grids in poismg.
The definition of MPI-Vectors adapted to a dynamic numer of ghost points.
New MPI-Vectors for data exchange between left and right boundaries added.
This is due to reasons of performance (10% faster).

ATTENTION: nnz_x undefined problem still has to be solved!!!!!!!!
TEST OUTPUT (TO BE REMOVED) logging mpi2 ierr values

parin.f90


Steering parameter dissipation_control added in inipar.

Makefile


Module advec_ws added.

Modules


Removed u_nzb_p1_for_vfc and v_nzb_p1_for_vfc

For coupling with different resolution in ocean and atmophere:
+nx_a, +nx_o, ny_a, +ny_o, ngp_a, ngp_o, +total_2d_o, +total_2d_a,
+coupling_topology

Buffer arrays for the left sided advective fluxes added in arrays_3d.
+flux_s_u, +flux_s_v, +flux_s_w, +diss_s_u, +diss_s_v, +diss_s_w,
+flux_s_pt, +diss_s_pt, +flux_s_e, +diss_s_e, +flux_s_q, +diss_s_q,
+flux_s_sa, +diss_s_sa
3d arrays for dissipation control added. (only necessary for vector arch.)
+var_x, +var_y, +var_z, +gamma_x, +gamma_y, +gamma_z
Default of momentum_advec and scalar_advec changed to 'ws-scheme' .
+exchange_mg added in control_parameters to steer the data exchange.
Parameters +nbgp, +nxlg, +nxrg, +nysg, +nyng added in indices.
flag array +boundary_flags added in indices to steer the degradation of order
of the advective fluxes when non-cyclic boundaries are used.
MPI-datatypes +type_y, +type_y_int and +type_yz for data_exchange added in
pegrid.
+sums_wsus_ws_l, +sums_wsvs_ws_l, +sums_us2_ws_l, +sums_vs2_ws_l,
+sums_ws2_ws_l, +sums_wspts_ws_l, +sums_wssas_ws_l, +sums_wsqs_ws_l
and +weight_substep added in statistics to steer the statistical evaluation
of turbulent fluxes in the advection routines.
LOGICALS +ws_scheme_sca and +ws_scheme_mom added to get a better performance
in prognostic_equations.
LOGICAL +dissipation_control control added to steer numerical dissipation
in ws-scheme.

Changed length of string run_description_header

pres.f90


New allocation of tend when ws-scheme and multigrid is used. This is due to
reasons of perforance of the data_exchange. The same is done with p after
poismg is called.
nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng when no
multigrid is used. Calls of exchange_horiz are modified.

bugfix: After pressure correction no volume flow correction in case of
non-cyclic boundary conditions
(has to be done only before pressure correction)

Call of SOR routine is referenced with ddzu_pres.

prognostic_equations.f90


Calls of the advection routines with WS5 added.
Calls of ws_statistics added to set the statistical arrays to zero after each
time step.

advec_particles.f90


Declaration of de_dx, de_dy, de_dz adapted to additional ghost points.
Furthermore the calls of exchange_horiz were modified.

asselin_filter.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

average_3d_data.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

boundary_conds.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng
Removed mirror boundary conditions for u and v at the bottom in case of
ibc_uv_b == 0. Instead, dirichelt boundary conditions (u=v=0) are set
in init_3d_model

calc_liquid_water_content.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

calc_spectra.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng for
allocation of tend.

check_open.f90


Output of total array size was adapted to nbgp.

data_output_2d.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng in loops and
allocation of arrays local_2d and total_2d.
Calls of exchange_horiz are modified.

data_output_2d.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng in loops and
allocation of arrays. Calls of exchange_horiz are modified.
Skip-value skip_do_avs changed to a dynamic adaption of ghost points.

data_output_mask.f90


Calls of exchange_horiz are modified.

diffusion_e.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

diffusion_s.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

diffusion_u.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

diffusion_v.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

diffusion_w.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

diffusivities.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

diffusivities.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.
Calls of exchange_horiz are modified.

exchange_horiz_2d.f90


Dynamic exchange of ghost points with nbgp, which depends on the advection
scheme. Exchange between left and right PEs is now done with MPI-vectors.

global_min_max.f90


Adapting of the index arrays, because MINLOC assumes lowerbound
at 1 and not at nbgp.

init_3d_model.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng in loops and
allocation of arrays. Calls of exchange_horiz are modified.
Call ws_init to initialize arrays needed for statistical evaluation and
optimization when ws-scheme is used.
Initial volume flow is now calculated by using the variable hom_sum.
Therefore the correction of initial volume flow for non-flat topography
removed (removed u_nzb_p1_for_vfc and v_nzb_p1_for_vfc)
Changed surface boundary conditions for u and v in case of ibc_uv_b == 0 from
mirror bc to dirichlet boundary conditions (u=v=0), so that k=nzb is
representative for the height z0

Bugfix: type conversion of '1' to 64bit for the MAX function (ngp_3d_inner)

init_coupling.f90


determination of target_id's moved to init_pegrid

init_pt_anomaly.f90


Call of exchange_horiz are modified.

init_rankine.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.
Calls of exchange_horiz are modified.

init_slope.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.

header.f90


Output of advection scheme.

poismg.f90


Calls of exchange_horiz are modified.

prandtl_fluxes.f90


Changed surface boundary conditions for u and v from mirror bc to dirichelt bc,
therefore u(uzb,:,:) and v(nzb,:,:) is now representative for the height z0
nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

production_e.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng

read_3d_binary.f90


+/- 1 replaced with +/- nbgp when swapping and allocating variables.

sor.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.
Call of exchange_horiz are modified.
bug removed in declaration of ddzw(), nz replaced by nzt+1

subsidence.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.

sum_up_3d_data.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.

surface_coupler.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng in
MPI_SEND() and MPI_RECV.
additional case for nonequivalent processor and grid topopolgy in ocean and
atmosphere added (coupling_topology = 1)

Added exchange of u and v from Ocean to Atmosphere

time_integration.f90


Calls of exchange_horiz are modified.
Adaption to slooping surface.

timestep.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.

user_3d_data_averaging.f90, user_data_output_2d.f90, user_data_output_3d.f90,
user_actions.f90, user_init.f90, user_init_plant_canopy.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.

user_read_restart_data.f90


Allocation with nbgp.

wall_fluxes.f90


nxl-1, nxr+1, nys-1, nyn+1 replaced by nxlg, nxrg, nysg, nyng.

write_compressed.f90


Array bounds and nx, ny adapted with nbgp.

sor.f90


bug removed in declaration of ddzw(), nz replaced by nzt+1

  • Property svn:keywords set to Id
File size: 55.7 KB
Line 
1SUBROUTINE check_open( file_id )
2
3!------------------------------------------------------------------------------!
4! Current revisions:
5! -----------------
6! Output of total array size was adapted to nbgp.
7!
8! Former revisions:
9! -----------------
10! $Id: check_open.f90 667 2010-12-23 12:06:00Z suehring $
11!
12! 600 2010-11-24 16:10:51Z raasch
13! bugfix in opening of cross section netcdf-files (parallel opening with
14! netcdf4 only works for netcdf_data_format > 2)
15!
16! 564 2010-09-30 13:18:59Z helmke
17! start number of mask output files changed to 201, netcdf message identifiers
18! of masked output changed
19!
20! 519 2010-03-19 05:30:02Z raasch
21! NetCDF4 support for particle data
22!
23! 493 2010-03-01 08:30:24Z raasch
24! NetCDF4 support (parallel output)
25!
26! 410 2009-12-04 17:05:40Z letzel
27! masked data output
28!
29! 277 2009-03-31 09:13:47Z heinze
30! Output of NetCDF messages with aid of message handling routine.
31! Output of messages replaced by message handling routine
32!
33! 146 2008-01-17 13:08:34Z raasch
34! First opening of unit 13 openes file _0000 on all PEs (parallel version)
35! because only this file contains the global variables,
36! myid_char_14 removed
37!
38! 120 2007-10-17 11:54:43Z raasch
39! Status of 3D-volume NetCDF data file only depends on switch netcdf_64bit_3d
40!
41! 105 2007-08-08 07:12:55Z raasch
42! Different filenames are used in case of a coupled simulation,
43! coupling_char added to all relevant filenames
44!
45! 82 2007-04-16 15:40:52Z raasch
46! Call of local_getenv removed, preprocessor directives for old systems removed
47!
48! 46 2007-03-05 06:00:47Z raasch
49! +netcdf_64bit_3d to switch on 64bit offset only for 3D files
50!
51! RCS Log replace by Id keyword, revision history cleaned up
52!
53! Revision 1.44  2006/08/22 13:48:34  raasch
54! xz and yz cross sections now up to nzt+1
55!
56! Revision 1.1  1997/08/11 06:10:55  raasch
57! Initial revision
58!
59!
60! Description:
61! ------------
62! Check if file unit is open. If not, open file and, if necessary, write a
63! header or start other initializing actions, respectively.
64!------------------------------------------------------------------------------!
65
66    USE array_kind
67    USE arrays_3d
68    USE control_parameters
69    USE grid_variables
70    USE indices
71    USE netcdf_control
72    USE particle_attributes
73    USE pegrid
74    USE profil_parameter
75    USE statistics
76
77    IMPLICIT NONE
78
79    CHARACTER (LEN=2)   ::  mask_char, suffix
80    CHARACTER (LEN=20)  ::  xtext = 'time in s'
81    CHARACTER (LEN=30)  ::  filename
82    CHARACTER (LEN=40)  ::  avs_coor_file, avs_coor_file_localname, &
83                            avs_data_file_localname
84    CHARACTER (LEN=80)  ::  rtext
85    CHARACTER (LEN=100) ::  avs_coor_file_catalog, avs_data_file_catalog, &
86                            batch_scp, zeile
87    CHARACTER (LEN=400) ::  command
88
89    INTEGER ::  av, anzzeile = 1, cranz, file_id, i, iaddres, ierr1, iusern, &
90                j, k, legpos = 1, timodex = 1
91    INTEGER, DIMENSION(10) ::  cucol, klist, lstyle
92
93    LOGICAL ::  avs_coor_file_found = .FALSE., avs_data_file_found = .FALSE., &
94                datleg = .TRUE., get_filenames, grid = .TRUE., netcdf_extend, &
95                rand = .TRUE., swap = .TRUE., twoxa = .TRUE., twoya = .TRUE.
96
97    REAL ::  ansx = -999.999, ansy = -999.999, gwid = 0.1, rlegfak = 1.5, &
98             sizex = 250.0, sizey = 40.0, texfac = 1.5
99
100    REAL, DIMENSION(:), ALLOCATABLE      ::  eta, ho, hu
101    REAL(spk), DIMENSION(:), ALLOCATABLE ::  xkoor, ykoor, zkoor 
102
103
104    NAMELIST /RAHMEN/  anzzeile, cranz, datleg, rtext, swap
105    NAMELIST /CROSS/   ansx, ansy, cucol, grid, gwid, klist, legpos, lstyle, &
106                       rand, rlegfak, sizex, sizey, texfac, &
107                       timodex, twoxa, twoya, xtext
108                       
109
110!
111!-- Immediate return if file already open
112    IF ( openfile(file_id)%opened )  RETURN
113
114!
115!-- Only certain files are allowed to be re-opened
116!-- NOTE: some of the other files perhaps also could be re-opened, but it
117!--       has not been checked so far, if it works!
118    IF ( openfile(file_id)%opened_before )  THEN
119       SELECT CASE ( file_id )
120          CASE ( 13, 14, 21, 22, 23, 80:85 )
121             IF ( file_id == 14 .AND. openfile(file_id)%opened_before )  THEN
122                message_string = 're-open of unit ' // &
123                                 '14 is not verified. Please check results!'
124                CALL message( 'check_open', 'PA0165', 0, 1, 0, 6, 0 )       
125             ENDIF
126
127          CASE DEFAULT
128             WRITE( message_string, * ) 're-opening of file-id ', file_id, &
129                                        ' is not allowed'
130             CALL message( 'check_open', 'PA0166', 0, 1, 0, 6, 0 )   
131               
132             RETURN
133
134       END SELECT
135    ENDIF
136
137!
138!-- Check if file may be opened on the relevant PE
139    SELECT CASE ( file_id )
140
141       CASE ( 15, 16, 17, 18, 19, 40:49, 50:59, 81:84, 104:105, 107, 109 )
142             
143          IF ( myid /= 0 )  THEN
144             WRITE( message_string, * ) 'opening file-id ',file_id, &
145                                        ' not allowed for PE ',myid
146             CALL message( 'check_open', 'PA0167', 2, 2, -1, 6, 1 )
147          ENDIF
148
149       CASE ( 101:103, 106, 111:113, 116, 201:200+2*max_masks )
150
151          IF ( netcdf_data_format < 3 )  THEN
152         
153             IF ( myid /= 0 )  THEN
154                WRITE( message_string, * ) 'opening file-id ',file_id, &
155                                           ' not allowed for PE ',myid
156                CALL message( 'check_open', 'PA0167', 2, 2, -1, 6, 1 )
157             ENDIF
158             
159          ENDIF
160
161       CASE ( 21, 22, 23 )
162
163          IF ( .NOT.  data_output_2d_on_each_pe )  THEN
164             IF ( myid /= 0 )  THEN
165                WRITE( message_string, * ) 'opening file-id ',file_id, &
166                                           ' not allowed for PE ',myid
167                CALL message( 'check_open', 'PA0167', 2, 2, -1, 6, 1 )
168             END IF
169          ENDIF
170
171       CASE ( 27, 28, 29, 31, 32, 33, 71:73, 90:99 )
172
173!
174!--       File-ids that are used temporarily in other routines
175          WRITE( message_string, * ) 'opening file-id ',file_id, &
176                                    ' is not allowed since it is used otherwise'
177          CALL message( 'check_open', 'PA0168', 0, 1, 0, 6, 0 ) 
178         
179    END SELECT
180
181!
182!-- Open relevant files
183    SELECT CASE ( file_id )
184
185       CASE ( 11 )
186
187          OPEN ( 11, FILE='PARIN'//coupling_char, FORM='FORMATTED', &
188                     STATUS='OLD' )
189
190       CASE ( 13 )
191
192          IF ( myid_char == '' )  THEN
193             OPEN ( 13, FILE='BININ'//coupling_char//myid_char, &
194                        FORM='UNFORMATTED', STATUS='OLD' )
195          ELSE
196!
197!--          First opening of unit 13 openes file _0000 on all PEs because only
198!--          this file contains the global variables
199             IF ( .NOT. openfile(file_id)%opened_before )  THEN
200                OPEN ( 13, FILE='BININ'//TRIM( coupling_char )//'/_0000',&
201                           FORM='UNFORMATTED', STATUS='OLD' )
202             ELSE
203                OPEN ( 13, FILE='BININ'//TRIM( coupling_char )//'/'//myid_char,&
204                           FORM='UNFORMATTED', STATUS='OLD' )
205             ENDIF
206          ENDIF
207
208       CASE ( 14 )
209
210          IF ( myid_char == '' )  THEN
211             OPEN ( 14, FILE='BINOUT'//coupling_char//myid_char, &
212                        FORM='UNFORMATTED', POSITION='APPEND' )
213          ELSE
214             IF ( myid == 0  .AND. .NOT. openfile(file_id)%opened_before )  THEN
215                CALL local_system( 'mkdir  BINOUT' // coupling_char )
216             ENDIF
217#if defined( __parallel )
218!
219!--          Set a barrier in order to allow that all other processors in the
220!--          directory created by PE0 can open their file
221             CALL MPI_BARRIER( comm2d, ierr )
222#endif
223             OPEN ( 14, FILE='BINOUT'//TRIM(coupling_char)//'/'//myid_char, &
224                        FORM='UNFORMATTED', POSITION='APPEND' )
225          ENDIF
226
227       CASE ( 15 )
228
229          OPEN ( 15, FILE='RUN_CONTROL'//coupling_char, FORM='FORMATTED' )
230
231       CASE ( 16 )
232
233          OPEN ( 16, FILE='LIST_PROFIL'//coupling_char, FORM='FORMATTED' )
234
235       CASE ( 17 )
236
237          OPEN ( 17, FILE='LIST_PROFIL_1D'//coupling_char, FORM='FORMATTED' )
238
239       CASE ( 18 )
240
241          OPEN ( 18, FILE='CPU_MEASURES'//coupling_char, FORM='FORMATTED' )
242
243       CASE ( 19 )
244
245          OPEN ( 19, FILE='HEADER'//coupling_char, FORM='FORMATTED' )
246
247       CASE ( 20 )
248
249          IF ( myid == 0  .AND. .NOT. openfile(file_id)%opened_before )  THEN
250             CALL local_system( 'mkdir  DATA_LOG' // coupling_char )
251          ENDIF
252          IF ( myid_char == '' )  THEN
253             OPEN ( 20, FILE='DATA_LOG'//TRIM( coupling_char )//'/_0000', &
254                        FORM='UNFORMATTED', POSITION='APPEND' )
255          ELSE
256#if defined( __parallel )
257!
258!--          Set a barrier in order to allow that all other processors in the
259!--          directory created by PE0 can open their file
260             CALL MPI_BARRIER( comm2d, ierr )
261#endif
262             OPEN ( 20, FILE='DATA_LOG'//TRIM( coupling_char )//'/'//myid_char,&
263                        FORM='UNFORMATTED', POSITION='APPEND' )
264          ENDIF
265
266       CASE ( 21 )
267
268          IF ( data_output_2d_on_each_pe )  THEN
269             OPEN ( 21, FILE='PLOT2D_XY'//TRIM( coupling_char )//myid_char, &
270                        FORM='UNFORMATTED', POSITION='APPEND' )
271          ELSE
272             OPEN ( 21, FILE='PLOT2D_XY'//coupling_char, &
273                        FORM='UNFORMATTED', POSITION='APPEND' )
274          ENDIF
275
276          IF ( myid == 0  .AND.  .NOT. openfile(file_id)%opened_before )  THEN
277!
278!--          Output for combine_plot_fields
279             IF ( data_output_2d_on_each_pe  .AND.  myid_char /= '' )  THEN
280                WRITE (21)  -nbgp, nx+nbgp, -nbgp, ny+nbgp    ! total array size
281                WRITE (21)   0, nx+1,  0, ny+1    ! output part
282             ENDIF
283!
284!--          Determine and write ISO2D coordiante header
285             ALLOCATE( eta(0:ny+1), ho(0:nx+1), hu(0:nx+1) )
286             hu = 0.0
287             ho = (ny+1) * dy
288             DO  i = 1, ny
289                eta(i) = REAL( i ) / ( ny + 1.0 )
290             ENDDO
291             eta(0)    = 0.0
292             eta(ny+1) = 1.0
293
294             WRITE (21)  dx,eta,hu,ho
295             DEALLOCATE( eta, ho, hu )
296
297!
298!--          Create output file for local parameters
299             IF ( iso2d_output )  THEN
300                OPEN ( 27, FILE='PLOT2D_XY_LOCAL'//coupling_char, &
301                           FORM='FORMATTED', DELIM='APOSTROPHE' )
302                openfile(27)%opened = .TRUE.
303             ENDIF
304
305          ENDIF
306
307       CASE ( 22 )
308
309          IF ( data_output_2d_on_each_pe )  THEN
310             OPEN ( 22, FILE='PLOT2D_XZ'//TRIM( coupling_char )//myid_char, &
311                        FORM='UNFORMATTED', POSITION='APPEND' )
312          ELSE
313             OPEN ( 22, FILE='PLOT2D_XZ'//coupling_char, FORM='UNFORMATTED', &
314                        POSITION='APPEND' )
315          ENDIF
316
317          IF ( myid == 0  .AND.  .NOT. openfile(file_id)%opened_before )  THEN
318!
319!--          Output for combine_plot_fields
320             IF ( data_output_2d_on_each_pe  .AND.  myid_char /= '' )  THEN
321                WRITE (22)  -nbgp, nx+nbgp, 0, nz+1    ! total array size
322                WRITE (22)   0, nx+1, 0, nz+1    ! output part
323             ENDIF
324!
325!--          Determine and write ISO2D coordiante header
326             ALLOCATE( eta(0:nz+1), ho(0:nx+1), hu(0:nx+1) )
327             hu = 0.0
328             ho = zu(nz+1)
329             DO  i = 1, nz
330                eta(i) = REAL( zu(i) ) / zu(nz+1)
331             ENDDO
332             eta(0)    = 0.0
333             eta(nz+1) = 1.0
334
335             WRITE (22)  dx,eta,hu,ho
336             DEALLOCATE( eta, ho, hu )
337!
338!--          Create output file for local parameters
339             OPEN ( 28, FILE='PLOT2D_XZ_LOCAL'//coupling_char, &
340                        FORM='FORMATTED', DELIM='APOSTROPHE' )
341             openfile(28)%opened = .TRUE.
342
343          ENDIF
344
345       CASE ( 23 )
346
347          IF ( data_output_2d_on_each_pe )  THEN
348             OPEN ( 23, FILE='PLOT2D_YZ'//TRIM( coupling_char )//myid_char, &
349                        FORM='UNFORMATTED', POSITION='APPEND' )
350          ELSE
351             OPEN ( 23, FILE='PLOT2D_YZ'//coupling_char, FORM='UNFORMATTED', &
352                        POSITION='APPEND' )
353          ENDIF
354
355          IF ( myid == 0  .AND.  .NOT. openfile(file_id)%opened_before )  THEN
356!
357!--          Output for combine_plot_fields
358             IF ( data_output_2d_on_each_pe  .AND.  myid_char /= '' )  THEN
359                WRITE (23)  -nbgp, ny+nbgp, 0, nz+1    ! total array size
360                WRITE (23)   0, ny+1, 0, nz+1    ! output part
361             ENDIF
362!
363!--          Determine and write ISO2D coordiante header
364             ALLOCATE( eta(0:nz+1), ho(0:ny+1), hu(0:ny+1) )
365             hu = 0.0
366             ho = zu(nz+1)
367             DO  i = 1, nz
368                eta(i) = REAL( zu(i) ) / zu(nz+1)
369             ENDDO
370             eta(0)    = 0.0
371             eta(nz+1) = 1.0
372
373             WRITE (23)  dx,eta,hu,ho
374             DEALLOCATE( eta, ho, hu )
375!
376!--          Create output file for local parameters
377             OPEN ( 29, FILE='PLOT2D_YZ_LOCAL'//coupling_char, &
378                        FORM='FORMATTED', DELIM='APOSTROPHE' )
379             openfile(29)%opened = .TRUE.
380
381          ENDIF
382
383       CASE ( 30 )
384
385          OPEN ( 30, FILE='PLOT3D_DATA'//TRIM( coupling_char )//myid_char, &
386                     FORM='UNFORMATTED' )
387!
388!--       Write coordinate file for AVS
389          IF ( myid == 0 )  THEN
390#if defined( __parallel )
391!
392!--          Specifications for combine_plot_fields
393             IF ( .NOT. do3d_compress )  THEN
394                WRITE ( 30 )  -nbgp,nx+nbgp,-nbgp,ny+nbgp, 0 ,nz_do3d
395                WRITE ( 30 )  0,nx+1,0,ny+1,0,nz_do3d
396             ENDIF
397#endif
398!
399!--          Write coordinate file for AVS:
400!--          First determine file names (including cyle numbers) of AVS files on
401!--          target machine (to which the files are to be transferred).
402!--          Therefore path information has to be obtained first.
403             IF ( avs_output )  THEN
404                iaddres = LEN_TRIM( return_addres )
405                iusern  = LEN_TRIM( return_username )
406
407                OPEN ( 3, FILE='OUTPUT_FILE_CONNECTIONS', FORM='FORMATTED' )
408                DO  WHILE ( .NOT. avs_coor_file_found  .OR. &
409                            .NOT. avs_data_file_found )
410
411                   READ ( 3, '(A)', END=1 )  zeile
412
413                   SELECT CASE ( zeile(1:11) )
414
415                      CASE ( 'PLOT3D_COOR' )
416                         READ ( 3, '(A/A)' )  avs_coor_file_catalog, &
417                                              avs_coor_file_localname
418                         avs_coor_file_found = .TRUE.
419
420                      CASE ( 'PLOT3D_DATA' )
421                         READ ( 3, '(A/A)' )  avs_data_file_catalog, &
422                                              avs_data_file_localname
423                         avs_data_file_found = .TRUE.
424
425                      CASE DEFAULT
426                         READ ( 3, '(A/A)' )  zeile, zeile
427
428                   END SELECT
429
430                ENDDO
431!
432!--             Now the cycle numbers on the remote machine must be obtained
433!--             using batch_scp
434       1        CLOSE ( 3 )
435                IF ( .NOT. avs_coor_file_found  .OR. &
436                     .NOT. avs_data_file_found )  THEN
437                   message_string= 'no filename for AVS-data-file ' //       &
438                                   'found in MRUN-config-file' //            &
439                                   ' &filename in FLD-file set to "unknown"'
440                   CALL message( 'check_open', 'PA0169', 0, 1, 0, 6, 0 )
441
442                   avs_coor_file = 'unknown'
443                   avs_data_file = 'unknown'
444                ELSE
445                   get_filenames = .TRUE.
446                   IF ( TRIM( host ) == 'hpmuk'  .OR.  &
447                        TRIM( host ) == 'lcmuk' )  THEN
448                      batch_scp = '/home/raasch/pub/batch_scp'
449                   ELSEIF ( TRIM( host ) == 'nech' )  THEN
450                      batch_scp = '/ipf/b/b323011/pub/batch_scp'
451                   ELSEIF ( TRIM( host ) == 'ibmh'  .OR.  &
452                            TRIM( host ) == 'ibmb' )  THEN
453                      batch_scp = '/home/h/niksiraa/pub/batch_scp'
454                   ELSEIF ( TRIM( host ) == 't3eb' )  THEN
455                      batch_scp = '/home/nhbksira/pub/batch_scp'
456                   ELSE
457                      message_string= 'no path for batch_scp on host "' // &
458                                       TRIM( host ) // '"'
459                      CALL message( 'check_open', 'PA0170', 0, 1, 0, 6, 0 )
460                      get_filenames = .FALSE.
461                   ENDIF
462
463                   IF ( get_filenames )  THEN
464!
465!--                   Determine the coordinate file name.
466!--                   /etc/passwd serves as Dummy-Datei, because it is not
467!--                   really transferred.
468                      command = TRIM( batch_scp ) // ' -n -u ' // &
469                         return_username(1:iusern) // ' ' // &
470                         return_addres(1:iaddres) // ' /etc/passwd "' // &
471                         TRIM( avs_coor_file_catalog ) // '" ' // &
472                         TRIM( avs_coor_file_localname ) // ' > REMOTE_FILENAME'
473
474                      CALL local_system( command )
475                      OPEN ( 3, FILE='REMOTE_FILENAME', FORM='FORMATTED' )
476                      READ ( 3, '(A)' )  avs_coor_file
477                      CLOSE ( 3 )
478!
479!--                   Determine the data file name
480                      command = TRIM( batch_scp ) // ' -n -u ' // &
481                         return_username(1:iusern) // ' ' // &
482                         return_addres(1:iaddres) // ' /etc/passwd "' // &
483                         TRIM( avs_data_file_catalog ) // '" ' // &
484                         TRIM( avs_data_file_localname ) // ' > REMOTE_FILENAME'
485
486                      CALL local_system( command )
487                      OPEN ( 3, FILE='REMOTE_FILENAME', FORM='FORMATTED' )
488                      READ ( 3, '(A)' )  avs_data_file
489                      CLOSE ( 3 )
490
491                   ELSE
492
493                      avs_coor_file = 'unknown'
494                      avs_data_file = 'unknown'
495
496                   ENDIF
497
498                ENDIF
499
500!
501!--             Output of the coordinate file description for FLD-file
502                OPEN ( 33, FILE='PLOT3D_FLD_COOR', FORM='FORMATTED' )
503                openfile(33)%opened = .TRUE.
504                WRITE ( 33, 3300 )  TRIM( avs_coor_file ), &
505                                    TRIM( avs_coor_file ), (nx+2*nbgp)*4, &
506                                    TRIM( avs_coor_file ), (nx+2*nbgp)*4+(ny+2*nbgp)*4
507           
508
509                ALLOCATE( xkoor(0:nx+1), ykoor(0:ny+1), zkoor(0:nz_do3d) )
510                DO  i = 0, nx+1
511                   xkoor(i) = i * dx
512                ENDDO
513                DO  j = 0, ny+1
514                   ykoor(j) = j * dy
515                ENDDO
516                DO  k = 0, nz_do3d
517                   zkoor(k) = zu(k)
518                ENDDO
519
520!
521!--             Create and write on AVS coordinate file
522                OPEN ( 31, FILE='PLOT3D_COOR', FORM='UNFORMATTED' )
523                openfile(31)%opened = .TRUE.
524
525                WRITE (31)  xkoor, ykoor, zkoor
526                DEALLOCATE( xkoor, ykoor, zkoor )
527
528!
529!--             Create FLD file (being written on in close_file)
530                OPEN ( 32, FILE='PLOT3D_FLD', FORM='FORMATTED' )
531                openfile(32)%opened = .TRUE.
532
533!
534!--             Create flag file for compressed 3D output,
535!--             influences output commands in mrun
536                IF ( do3d_compress )  THEN
537                   OPEN ( 3, FILE='PLOT3D_COMPRESSED', FORM='FORMATTED' )
538                   WRITE ( 3, '(1X)' )
539                   CLOSE ( 3 )
540                ENDIF
541
542             ENDIF
543
544          ENDIF
545
546!
547!--       In case of data compression output of the coordinates of the
548!--       corresponding partial array of a PE only once at the top of the file
549          IF ( avs_output  .AND.  do3d_compress )  THEN
550             WRITE ( 30 )  nxlg, nxrg, nysg, nyng, nzb, nz_do3d
551          ENDIF
552
553       CASE ( 40:49 )
554
555          IF ( statistic_regions == 0  .AND.  file_id == 40 )  THEN
556             suffix = ''
557          ELSE
558             WRITE ( suffix, '(''_'',I1)' )  file_id - 40
559          ENDIF
560          OPEN ( file_id, FILE='PLOT1D_DATA'//TRIM( coupling_char )// &
561                               TRIM( suffix ),                        &
562                          FORM='FORMATTED' )
563!
564!--       Write contents comments at the top of the file
565          WRITE ( file_id, 4000 )  TRIM( run_description_header ) // '    ' // &
566                                   TRIM( region( file_id - 40 ) )
567
568       CASE ( 50:59 )
569
570          IF ( statistic_regions == 0  .AND.  file_id == 50 )  THEN
571             suffix = ''
572          ELSE
573             WRITE ( suffix, '(''_'',I1)' )  file_id - 50
574          ENDIF
575          OPEN ( file_id, FILE='PLOTTS_DATA'//TRIM( coupling_char )// &
576                               TRIM( suffix ),                        &
577                          FORM='FORMATTED', RECL=496 )
578!
579!--       Write PROFIL parameter file for output of time series
580!--       NOTE: To be on the safe side, this output is done at the beginning of
581!--             the model run (in case of collapse) and it is repeated in
582!--             close_file, then, however, with value ranges for the coordinate
583!--             systems
584!
585!--       Firstly determine the number of the coordinate systems to be drawn
586          cranz = 0
587          DO  j = 1, 10
588             IF ( cross_ts_number_count(j) /= 0 )  cranz = cranz+1
589          ENDDO
590          rtext = '\1.0 ' // TRIM( run_description_header ) // '    ' // &
591                  TRIM( region( file_id - 50 ) )
592!
593!--       Write RAHMEN parameter
594          OPEN ( 90, FILE='PLOTTS_PAR'//TRIM( coupling_char )// &
595                           TRIM( suffix ),                      &
596                     FORM='FORMATTED', DELIM='APOSTROPHE' )
597          WRITE ( 90, RAHMEN )
598!
599!--       Determine and write CROSS parameters for the individual coordinate
600!--       systems
601          DO  j = 1, 10
602             k = cross_ts_number_count(j)
603             IF ( k /= 0 )  THEN
604!
605!--             Store curve numbers, colours and line style
606                klist(1:k) = cross_ts_numbers(1:k,j)
607                klist(k+1:10) = 999999
608                cucol(1:k) = linecolors(1:k)
609                lstyle(1:k) = linestyles(1:k)
610!
611!--             Write CROSS parameter
612                WRITE ( 90, CROSS )
613
614             ENDIF
615          ENDDO
616
617          CLOSE ( 90 )
618!
619!--       Write all labels at the top of the data file, but only during the
620!--       first run of a sequence of jobs. The following jobs copy the time
621!--       series data to the bottom of that file.
622          IF ( runnr == 0 )  THEN
623             WRITE ( file_id, 5000 )  TRIM( run_description_header ) // &
624                                      '    ' // TRIM( region( file_id - 50 ) )
625          ENDIF
626
627
628       CASE ( 80 )
629
630          IF ( myid_char == '' )  THEN
631             OPEN ( 80, FILE='PARTICLE_INFOS'//TRIM(coupling_char)//myid_char, &
632                        FORM='FORMATTED', POSITION='APPEND' )
633          ELSE
634             IF ( myid == 0  .AND.  .NOT. openfile(80)%opened_before )  THEN
635                CALL local_system( 'mkdir  PARTICLE_INFOS' // coupling_char )
636             ENDIF
637#if defined( __parallel )
638!
639!--          Set a barrier in order to allow that thereafter all other
640!--          processors in the directory created by PE0 can open their file.
641!--          WARNING: The following barrier will lead to hanging jobs, if
642!--                   check_open is first called from routine
643!--                   allocate_prt_memory!
644             IF ( .NOT. openfile(80)%opened_before )  THEN
645                CALL MPI_BARRIER( comm2d, ierr )
646             ENDIF
647#endif
648             OPEN ( 80, FILE='PARTICLE_INFOS'//TRIM( coupling_char )//'/'// &
649                             myid_char,                                     &
650                        FORM='FORMATTED', POSITION='APPEND' )
651          ENDIF
652
653          IF ( .NOT. openfile(80)%opened_before )  THEN
654             WRITE ( 80, 8000 )  TRIM( run_description_header )
655          ENDIF
656
657       CASE ( 81 )
658
659             OPEN ( 81, FILE='PLOTSP_X_PAR'//coupling_char, FORM='FORMATTED', &
660                        DELIM='APOSTROPHE', RECL=1500, POSITION='APPEND' )
661
662       CASE ( 82 )
663
664             OPEN ( 82, FILE='PLOTSP_X_DATA'//coupling_char, FORM='FORMATTED', &
665                        POSITION = 'APPEND' )
666
667       CASE ( 83 )
668
669             OPEN ( 83, FILE='PLOTSP_Y_PAR'//coupling_char, FORM='FORMATTED', &
670                        DELIM='APOSTROPHE', RECL=1500, POSITION='APPEND' )
671
672       CASE ( 84 )
673
674             OPEN ( 84, FILE='PLOTSP_Y_DATA'//coupling_char, FORM='FORMATTED', &
675                        POSITION='APPEND' )
676
677       CASE ( 85 )
678
679          IF ( myid_char == '' )  THEN
680             OPEN ( 85, FILE='PARTICLE_DATA'//TRIM(coupling_char)//myid_char, &
681                        FORM='UNFORMATTED', POSITION='APPEND' )
682          ELSE
683             IF ( myid == 0  .AND.  .NOT. openfile(85)%opened_before )  THEN
684                CALL local_system( 'mkdir  PARTICLE_DATA' // coupling_char )
685             ENDIF
686#if defined( __parallel )
687!
688!--          Set a barrier in order to allow that thereafter all other
689!--          processors in the directory created by PE0 can open their file
690             CALL MPI_BARRIER( comm2d, ierr )
691#endif
692             OPEN ( 85, FILE='PARTICLE_DATA'//TRIM( coupling_char )//'/'// &
693                        myid_char,                                         &
694                        FORM='UNFORMATTED', POSITION='APPEND' )
695          ENDIF
696
697          IF ( .NOT. openfile(85)%opened_before )  THEN
698             WRITE ( 85 )  run_description_header
699!
700!--          Attention: change version number whenever the output format on
701!--                     unit 85 is changed (see also in routine advec_particles)
702             rtext = 'data format version 3.0'
703             WRITE ( 85 )  rtext
704             WRITE ( 85 )  number_of_particle_groups, &
705                           max_number_of_particle_groups
706             WRITE ( 85 )  particle_groups
707          ENDIF
708
709#if defined( __netcdf )
710       CASE ( 101, 111 )
711!
712!--       Set filename depending on unit number
713          IF ( file_id == 101 )  THEN
714             filename = 'DATA_2D_XY_NETCDF' // coupling_char
715             av = 0
716          ELSE
717             filename = 'DATA_2D_XY_AV_NETCDF' // coupling_char
718             av = 1
719          ENDIF
720!
721!--       Inquire, if there is a NetCDF file from a previuos run. This should
722!--       be opened for extension, if its dimensions and variables match the
723!--       actual run.
724          INQUIRE( FILE=filename, EXIST=netcdf_extend )
725
726          IF ( netcdf_extend )  THEN
727!
728!--          Open an existing NetCDF file for output
729             IF ( netcdf_data_format < 3 )  THEN
730                nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_xy(av) )
731             ELSE
732#if defined( __netcdf4 )
733                nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_xy(av), &
734                                     COMM = comm2d, INFO = MPI_INFO_NULL )
735#endif
736             ENDIF
737
738             CALL handle_netcdf_error( 'check_open', 20 )
739!
740!--          Read header information and set all ids. If there is a mismatch
741!--          between the previuos and the actual run, netcdf_extend is returned
742!--          as .FALSE.
743             CALL define_netcdf_header( 'xy', netcdf_extend, av )
744
745!
746!--          Remove the local file, if it can not be extended
747             IF ( .NOT. netcdf_extend )  THEN
748                nc_stat = NF90_CLOSE( id_set_xy(av) )
749                CALL handle_netcdf_error( 'check_open', 21 )
750                IF ( myid == 0 )  CALL local_system( 'rm ' // TRIM( filename ) )
751             ENDIF
752
753          ENDIF         
754
755          IF ( .NOT. netcdf_extend )  THEN
756!
757!--          Create a new NetCDF output file with requested NetCDF format
758             IF ( netcdf_data_format == 1 )  THEN
759!
760!--             Classic NetCDF format
761                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_xy(av) )
762
763             ELSEIF ( netcdf_data_format == 2 )  THEN
764!
765!--             64bit-offset format
766                nc_stat = NF90_CREATE( filename,                               &
767                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
768                                       id_set_xy(av) )
769
770#if defined( __netcdf4 )
771             ELSEIF ( netcdf_data_format == 3 )  THEN
772!
773!--             NetCDF4/HDF5 format
774                nc_stat = NF90_CREATE( filename,                               &
775                                       OR( NF90_NOCLOBBER, NF90_NETCDF4 ),     &
776                                       id_set_xy(av), COMM = comm2d,           &
777                                       INFO = MPI_INFO_NULL )
778
779             ELSEIF ( netcdf_data_format == 4 )  THEN
780!
781!--             NetCDF4/HDF5 format with classic model flag
782                nc_stat = NF90_CREATE( filename,                               &
783                                       OR( NF90_NOCLOBBER,                     &
784                                        OR( NF90_CLASSIC_MODEL, NF90_HDF5 ) ), &
785                                       id_set_xy(av), COMM = comm2d,           &
786                                       INFO = MPI_INFO_NULL )
787#endif
788             ENDIF
789
790             CALL handle_netcdf_error( 'check_open', 22 )
791
792!
793!--          Define the header
794             CALL define_netcdf_header( 'xy', netcdf_extend, av )
795
796!
797!--          In case of parallel NetCDF output, create flag file which tells
798!--          combine_plot_fields that nothing is to do.
799             IF ( myid == 0  .AND.  netcdf_data_format > 2 )  THEN
800                OPEN( 99, FILE='NO_COMBINE_PLOT_FIELDS_XY' )
801                WRITE ( 99, '(A)' )  'no combine_plot_fields.x neccessary'
802                CLOSE( 99 )
803             ENDIF
804
805          ENDIF
806
807       CASE ( 102, 112 )
808!
809!--       Set filename depending on unit number
810          IF ( file_id == 102 )  THEN
811             filename = 'DATA_2D_XZ_NETCDF' // coupling_char
812             av = 0
813          ELSE
814             filename = 'DATA_2D_XZ_AV_NETCDF' // coupling_char
815             av = 1
816          ENDIF
817!
818!--       Inquire, if there is a NetCDF file from a previuos run. This should
819!--       be opened for extension, if its dimensions and variables match the
820!--       actual run.
821          INQUIRE( FILE=filename, EXIST=netcdf_extend )
822
823          IF ( netcdf_extend )  THEN
824!
825!--          Open an existing NetCDF file for output
826             IF ( netcdf_data_format < 3 )  THEN
827                nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_xz(av) )
828             ELSE
829#if defined( __netcdf4 )
830                nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_xz(av), &
831                                     COMM = comm2d, INFO = MPI_INFO_NULL )
832#endif
833             ENDIF
834
835             CALL handle_netcdf_error( 'check_open', 23 )
836!
837!--          Read header information and set all ids. If there is a mismatch
838!--          between the previuos and the actual run, netcdf_extend is returned
839!--          as .FALSE.
840             CALL define_netcdf_header( 'xz', netcdf_extend, av )
841
842!
843!--          Remove the local file, if it can not be extended
844             IF ( .NOT. netcdf_extend )  THEN
845                nc_stat = NF90_CLOSE( id_set_xz(av) )
846                CALL handle_netcdf_error( 'check_open', 24 )
847                IF ( myid == 0 )  CALL local_system( 'rm ' // TRIM( filename ) )
848             ENDIF
849
850          ENDIF         
851
852          IF ( .NOT. netcdf_extend )  THEN
853!
854!--          Create a new NetCDF output file with requested NetCDF format
855             IF ( netcdf_data_format == 1 )  THEN
856!
857!--             Classic NetCDF format
858                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_xz(av) )
859
860             ELSEIF ( netcdf_data_format == 2 )  THEN
861!
862!--             64bit-offset format
863                nc_stat = NF90_CREATE( filename,                               &
864                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
865                                       id_set_xz(av) )
866
867#if defined( __netcdf4 )
868             ELSEIF ( netcdf_data_format == 3 )  THEN
869!
870!--             NetCDF4/HDF5 format
871                nc_stat = NF90_CREATE( filename,                               &
872                                       OR( NF90_NOCLOBBER, NF90_NETCDF4 ),     &
873                                       id_set_xz(av), COMM = comm2d,           &
874                                       INFO = MPI_INFO_NULL )
875
876             ELSEIF ( netcdf_data_format == 4 )  THEN
877!
878!--             NetCDF4/HDF5 format with classic model flag
879                nc_stat = NF90_CREATE( filename,                               &
880                                       OR( NF90_NOCLOBBER,                     &
881                                        OR( NF90_CLASSIC_MODEL, NF90_HDF5 ) ), &
882                                       id_set_xz(av), COMM = comm2d,           &
883                                       INFO = MPI_INFO_NULL )
884#endif
885             ENDIF
886
887             CALL handle_netcdf_error( 'check_open', 25 )
888
889!
890!--          Define the header
891             CALL define_netcdf_header( 'xz', netcdf_extend, av )
892
893!
894!--          In case of parallel NetCDF output, create flag file which tells
895!--          combine_plot_fields that nothing is to do.
896             IF ( myid == 0  .AND.  netcdf_data_format > 2 )  THEN
897                OPEN( 99, FILE='NO_COMBINE_PLOT_FIELDS_XZ' )
898                WRITE ( 99, '(A)' )  'no combine_plot_fields.x neccessary'
899                CLOSE( 99 )
900             ENDIF
901
902          ENDIF
903
904       CASE ( 103, 113 )
905!
906!--       Set filename depending on unit number
907          IF ( file_id == 103 )  THEN
908             filename = 'DATA_2D_YZ_NETCDF' // coupling_char
909             av = 0
910          ELSE
911             filename = 'DATA_2D_YZ_AV_NETCDF' // coupling_char
912             av = 1
913          ENDIF
914!
915!--       Inquire, if there is a NetCDF file from a previuos run. This should
916!--       be opened for extension, if its dimensions and variables match the
917!--       actual run.
918          INQUIRE( FILE=filename, EXIST=netcdf_extend )
919
920          IF ( netcdf_extend )  THEN
921!
922!--          Open an existing NetCDF file for output
923             IF ( netcdf_data_format < 3 )  THEN
924                nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_yz(av) )
925             ELSE
926#if defined( __netcdf4 )
927                nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_yz(av), &
928                                     COMM = comm2d, INFO = MPI_INFO_NULL )
929#endif
930             ENDIF
931             
932             CALL handle_netcdf_error( 'check_open', 26 )
933!
934!--          Read header information and set all ids. If there is a mismatch
935!--          between the previuos and the actual run, netcdf_extend is returned
936!--          as .FALSE.
937             CALL define_netcdf_header( 'yz', netcdf_extend, av )
938
939!
940!--          Remove the local file, if it can not be extended
941             IF ( .NOT. netcdf_extend )  THEN
942                nc_stat = NF90_CLOSE( id_set_yz(av) )
943                CALL handle_netcdf_error( 'check_open', 27 )
944                IF ( myid == 0 )  CALL local_system( 'rm ' // TRIM( filename ) )
945             ENDIF
946
947          ENDIF         
948
949          IF ( .NOT. netcdf_extend )  THEN
950!
951!--          Create a new NetCDF output file with requested NetCDF format
952             IF ( netcdf_data_format == 1 )  THEN
953!
954!--             Classic NetCDF format
955                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_yz(av) )
956
957             ELSEIF ( netcdf_data_format == 2 )  THEN
958!
959!--             64bit-offset format
960                nc_stat = NF90_CREATE( filename,                               &
961                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
962                                       id_set_yz(av) )
963
964#if defined( __netcdf4 )
965             ELSEIF ( netcdf_data_format == 3 )  THEN
966!
967!--             NetCDF4/HDF5 format
968                nc_stat = NF90_CREATE( filename,                               &
969                                       OR( NF90_NOCLOBBER, NF90_NETCDF4 ),     &
970                                       id_set_yz(av), COMM = comm2d,           &
971                                       INFO = MPI_INFO_NULL )
972
973             ELSEIF ( netcdf_data_format == 4 )  THEN
974!
975!--             NetCDF4/HDF5 format with classic model flag
976                nc_stat = NF90_CREATE( filename,                               &
977                                       OR( NF90_NOCLOBBER,                     &
978                                        OR( NF90_CLASSIC_MODEL, NF90_HDF5 ) ), &
979                                       id_set_yz(av), COMM = comm2d,           &
980                                       INFO = MPI_INFO_NULL )
981#endif
982             ENDIF
983
984             CALL handle_netcdf_error( 'check_open', 28 )
985
986!
987!--          Define the header
988             CALL define_netcdf_header( 'yz', netcdf_extend, av )
989
990!
991!--          In case of parallel NetCDF output, create flag file which tells
992!--          combine_plot_fields that nothing is to do.
993             IF ( myid == 0  .AND.  netcdf_data_format > 2 )  THEN
994                OPEN( 99, FILE='NO_COMBINE_PLOT_FIELDS_YZ' )
995                WRITE ( 99, '(A)' )  'no combine_plot_fields.x neccessary'
996                CLOSE( 99 )
997             ENDIF
998
999          ENDIF
1000
1001       CASE ( 104 )
1002!
1003!--       Set filename
1004          filename = 'DATA_1D_PR_NETCDF' // coupling_char
1005
1006!
1007!--       Inquire, if there is a NetCDF file from a previuos run. This should
1008!--       be opened for extension, if its variables match the actual run.
1009          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1010
1011          IF ( netcdf_extend )  THEN
1012!
1013!--          Open an existing NetCDF file for output
1014             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_pr )
1015             CALL handle_netcdf_error( 'check_open', 29 )
1016!
1017!--          Read header information and set all ids. If there is a mismatch
1018!--          between the previuos and the actual run, netcdf_extend is returned
1019!--          as .FALSE.
1020             CALL define_netcdf_header( 'pr', netcdf_extend, 0 )
1021
1022!
1023!--          Remove the local file, if it can not be extended
1024             IF ( .NOT. netcdf_extend )  THEN
1025                nc_stat = NF90_CLOSE( id_set_pr )
1026                CALL handle_netcdf_error( 'check_open', 30 )
1027                CALL local_system( 'rm ' // TRIM( filename ) )
1028             ENDIF
1029
1030          ENDIF         
1031
1032          IF ( .NOT. netcdf_extend )  THEN
1033!
1034!--          Create a new NetCDF output file
1035             IF ( netcdf_data_format > 1 )  THEN
1036                nc_stat = NF90_CREATE( filename,                               &
1037                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1038                                       id_set_pr )
1039             ELSE
1040                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_pr )
1041             ENDIF
1042             CALL handle_netcdf_error( 'check_open', 31 )
1043!
1044!--          Define the header
1045             CALL define_netcdf_header( 'pr', netcdf_extend, 0 )
1046
1047          ENDIF
1048
1049       CASE ( 105 )
1050!
1051!--       Set filename
1052          filename = 'DATA_1D_TS_NETCDF' // coupling_char
1053
1054!
1055!--       Inquire, if there is a NetCDF file from a previuos run. This should
1056!--       be opened for extension, if its variables match the actual run.
1057          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1058
1059          IF ( netcdf_extend )  THEN
1060!
1061!--          Open an existing NetCDF file for output
1062             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_ts )
1063             CALL handle_netcdf_error( 'check_open', 32 )
1064!
1065!--          Read header information and set all ids. If there is a mismatch
1066!--          between the previuos and the actual run, netcdf_extend is returned
1067!--          as .FALSE.
1068             CALL define_netcdf_header( 'ts', netcdf_extend, 0 )
1069
1070!
1071!--          Remove the local file, if it can not be extended
1072             IF ( .NOT. netcdf_extend )  THEN
1073                nc_stat = NF90_CLOSE( id_set_ts )
1074                CALL handle_netcdf_error( 'check_open', 33 )
1075                CALL local_system( 'rm ' // TRIM( filename ) )
1076             ENDIF
1077
1078          ENDIF         
1079
1080          IF ( .NOT. netcdf_extend )  THEN
1081!
1082!--          Create a new NetCDF output file
1083             IF ( netcdf_data_format > 1 )  THEN
1084                nc_stat = NF90_CREATE( filename,                               &
1085                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1086                                       id_set_ts )
1087             ELSE
1088                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_ts )
1089             ENDIF
1090             CALL handle_netcdf_error( 'check_open', 34 )
1091!
1092!--          Define the header
1093             CALL define_netcdf_header( 'ts', netcdf_extend, 0 )
1094
1095          ENDIF
1096
1097
1098       CASE ( 106, 116 )
1099!
1100!--       Set filename depending on unit number
1101          IF ( file_id == 106 )  THEN
1102             filename = 'DATA_3D_NETCDF' // coupling_char
1103             av = 0
1104          ELSE
1105             filename = 'DATA_3D_AV_NETCDF' // coupling_char
1106             av = 1
1107          ENDIF
1108!
1109!--       Inquire, if there is a NetCDF file from a previous run. This should
1110!--       be opened for extension, if its dimensions and variables match the
1111!--       actual run.
1112          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1113
1114          IF ( netcdf_extend )  THEN
1115!
1116!--          Open an existing NetCDF file for output
1117#if defined( __netcdf4 )
1118             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_3d(av), &
1119                                  COMM = comm2d, INFO = MPI_INFO_NULL )
1120#else
1121             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_3d(av) )
1122#endif
1123             CALL handle_netcdf_error( 'check_open', 35 )
1124!
1125!--          Read header information and set all ids. If there is a mismatch
1126!--          between the previuos and the actual run, netcdf_extend is returned
1127!--          as .FALSE.
1128             CALL define_netcdf_header( '3d', netcdf_extend, av )
1129
1130!
1131!--          Remove the local file, if it can not be extended
1132             IF ( .NOT. netcdf_extend )  THEN
1133                nc_stat = NF90_CLOSE( id_set_3d(av) )
1134                CALL handle_netcdf_error( 'check_open', 36 )
1135                CALL local_system('rm ' // TRIM( filename ) )
1136             ENDIF
1137
1138          ENDIF         
1139
1140          IF ( .NOT. netcdf_extend )  THEN
1141!
1142!--          Create a new NetCDF output file with requested NetCDF format
1143             IF ( netcdf_data_format == 1 )  THEN
1144!
1145!--             Classic NetCDF format
1146                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_3d(av) )
1147
1148             ELSEIF ( netcdf_data_format == 2 )  THEN
1149!
1150!--             64bit-offset format
1151                nc_stat = NF90_CREATE( filename,                               &
1152                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1153                                       id_set_3d(av) )
1154
1155#if defined( __netcdf4 )
1156             ELSEIF ( netcdf_data_format == 3 )  THEN
1157!
1158!--             NetCDF4/HDF5 format
1159                nc_stat = NF90_CREATE( filename,                               &
1160                                       OR( NF90_NOCLOBBER, NF90_NETCDF4 ),     &
1161                                       id_set_3d(av), COMM = comm2d,           &
1162                                       INFO = MPI_INFO_NULL )
1163
1164             ELSEIF ( netcdf_data_format == 4 )  THEN
1165!
1166!--             NetCDF4/HDF5 format with classic model flag
1167                nc_stat = NF90_CREATE( filename,                               &
1168                                       OR( NF90_NOCLOBBER,                     &
1169                                        OR( NF90_CLASSIC_MODEL, NF90_HDF5 ) ), &
1170                                       id_set_3d(av), COMM = comm2d,           &
1171                                       INFO = MPI_INFO_NULL )
1172#endif
1173             ENDIF
1174
1175             CALL handle_netcdf_error( 'check_open', 37 )
1176
1177!
1178!--          Define the header
1179             CALL define_netcdf_header( '3d', netcdf_extend, av )
1180
1181!
1182!--          In case of parallel NetCDF output, create flag file which tells
1183!--          combine_plot_fields that nothing is to do.
1184             IF ( myid == 0  .AND.  netcdf_data_format > 2 )  THEN
1185                OPEN( 99, FILE='NO_COMBINE_PLOT_FIELDS_3D' )
1186                WRITE ( 99, '(A)' )  'no combine_plot_fields.x neccessary'
1187                CLOSE( 99 )
1188             ENDIF
1189
1190          ENDIF
1191
1192
1193       CASE ( 107 )
1194!
1195!--       Set filename
1196          filename = 'DATA_1D_SP_NETCDF' // coupling_char
1197
1198!
1199!--       Inquire, if there is a NetCDF file from a previuos run. This should
1200!--       be opened for extension, if its variables match the actual run.
1201          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1202
1203          IF ( netcdf_extend )  THEN
1204!
1205!--          Open an existing NetCDF file for output
1206             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_sp )
1207             CALL handle_netcdf_error( 'check_open', 38 )
1208
1209!
1210!--          Read header information and set all ids. If there is a mismatch
1211!--          between the previuos and the actual run, netcdf_extend is returned
1212!--          as .FALSE.
1213             CALL define_netcdf_header( 'sp', netcdf_extend, 0 )
1214
1215!
1216!--          Remove the local file, if it can not be extended
1217             IF ( .NOT. netcdf_extend )  THEN
1218                nc_stat = NF90_CLOSE( id_set_sp )
1219                CALL handle_netcdf_error( 'check_open', 39 )
1220                CALL local_system( 'rm ' // TRIM( filename ) )
1221             ENDIF
1222
1223          ENDIF         
1224
1225          IF ( .NOT. netcdf_extend )  THEN
1226!
1227!--          Create a new NetCDF output file
1228             IF ( netcdf_data_format > 1 )  THEN
1229                nc_stat = NF90_CREATE( filename,                               &
1230                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1231                                       id_set_sp )
1232             ELSE
1233                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_sp )
1234             ENDIF
1235             CALL handle_netcdf_error( 'check_open', 40 )
1236!
1237!--          Define the header
1238             CALL define_netcdf_header( 'sp', netcdf_extend, 0 )
1239
1240          ENDIF
1241
1242
1243       CASE ( 108 )
1244
1245          IF ( myid_char == '' )  THEN
1246             filename = 'DATA_PRT_NETCDF' // coupling_char
1247          ELSE
1248             filename = 'DATA_PRT_NETCDF' // TRIM( coupling_char ) // '/' // &
1249                        myid_char
1250          ENDIF
1251!
1252!--       Inquire, if there is a NetCDF file from a previuos run. This should
1253!--       be opened for extension, if its variables match the actual run.
1254          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1255
1256          IF ( netcdf_extend )  THEN
1257!
1258!--          Open an existing NetCDF file for output
1259             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_prt )
1260             CALL handle_netcdf_error( 'check_open', 41 )
1261!
1262!--          Read header information and set all ids. If there is a mismatch
1263!--          between the previuos and the actual run, netcdf_extend is returned
1264!--          as .FALSE.
1265             CALL define_netcdf_header( 'pt', netcdf_extend, 0 )
1266
1267!
1268!--          Remove the local file, if it can not be extended
1269             IF ( .NOT. netcdf_extend )  THEN
1270                nc_stat = NF90_CLOSE( id_set_prt )
1271                CALL handle_netcdf_error( 'check_open', 42 )
1272                CALL local_system( 'rm ' // filename )
1273             ENDIF
1274
1275          ENDIF         
1276
1277          IF ( .NOT. netcdf_extend )  THEN
1278
1279!
1280!--          For runs on multiple processors create the subdirectory
1281             IF ( myid_char /= '' )  THEN
1282                IF ( myid == 0  .AND. .NOT. openfile(file_id)%opened_before ) &
1283                THEN    ! needs modification in case of non-extendable sets
1284                   CALL local_system( 'mkdir  DATA_PRT_NETCDF' // &
1285                                       TRIM( coupling_char ) // '/' )
1286                ENDIF
1287#if defined( __parallel )
1288!
1289!--             Set a barrier in order to allow that all other processors in the
1290!--             directory created by PE0 can open their file
1291                CALL MPI_BARRIER( comm2d, ierr )
1292#endif
1293             ENDIF
1294
1295!
1296!--          Create a new NetCDF output file with requested NetCDF format
1297             IF ( netcdf_data_format == 1 )  THEN
1298!
1299!--             Classic NetCDF format
1300                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_prt )
1301
1302             ELSEIF ( netcdf_data_format == 2 )  THEN
1303!
1304!--             64bit-offset format
1305                nc_stat = NF90_CREATE( filename,                               &
1306                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1307                                       id_set_prt )
1308
1309#if defined( __netcdf4 )
1310             ELSEIF ( netcdf_data_format == 3 )  THEN
1311!
1312!--             NetCDF4/HDF5 format, but no parallel output into a single file!
1313                nc_stat = NF90_CREATE( filename,                               &
1314                                       OR( NF90_NOCLOBBER, NF90_NETCDF4 ),     &
1315                                       id_set_prt )
1316
1317             ELSEIF ( netcdf_data_format == 4 )  THEN
1318!
1319!--             NetCDF4/HDF5 format with classic model flag, but no parallel
1320!--             output into a single file!
1321                nc_stat = NF90_CREATE( filename,                               &
1322                                       OR( NF90_NOCLOBBER,                     &
1323                                        OR( NF90_CLASSIC_MODEL, NF90_HDF5 ) ), &
1324                                       id_set_prt )
1325#endif
1326             ENDIF
1327             
1328             CALL handle_netcdf_error( 'check_open', 43 ) 
1329
1330!
1331!--          Define the header
1332             CALL define_netcdf_header( 'pt', netcdf_extend, 0 )
1333
1334          ENDIF
1335
1336       CASE ( 109 )
1337!
1338!--       Set filename
1339          filename = 'DATA_1D_PTS_NETCDF' // coupling_char
1340
1341!
1342!--       Inquire, if there is a NetCDF file from a previuos run. This should
1343!--       be opened for extension, if its variables match the actual run.
1344          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1345
1346          IF ( netcdf_extend )  THEN
1347!
1348!--          Open an existing NetCDF file for output
1349             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_pts )
1350             CALL handle_netcdf_error( 'check_open', 393 )
1351!
1352!--          Read header information and set all ids. If there is a mismatch
1353!--          between the previuos and the actual run, netcdf_extend is returned
1354!--          as .FALSE.
1355             CALL define_netcdf_header( 'ps', netcdf_extend, 0 )
1356
1357!
1358!--          Remove the local file, if it can not be extended
1359             IF ( .NOT. netcdf_extend )  THEN
1360                nc_stat = NF90_CLOSE( id_set_pts )
1361                CALL handle_netcdf_error( 'check_open', 394 )
1362                CALL local_system( 'rm ' // TRIM( filename ) )
1363             ENDIF
1364
1365          ENDIF         
1366
1367          IF ( .NOT. netcdf_extend )  THEN
1368!
1369!--          Create a new NetCDF output file
1370             IF ( netcdf_data_format > 1 )  THEN
1371                nc_stat = NF90_CREATE( filename,                               &
1372                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1373                                       id_set_pts )
1374             ELSE
1375                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, id_set_pts )
1376             ENDIF
1377             CALL handle_netcdf_error( 'check_open', 395 )
1378!
1379!--          Define the header
1380             CALL define_netcdf_header( 'ps', netcdf_extend, 0 )
1381
1382          ENDIF
1383
1384       CASE ( 201:200+2*max_masks )
1385!
1386!--       Set filename depending on unit number
1387          IF ( file_id <= 200+max_masks )  THEN
1388             mid = file_id - 200
1389             WRITE ( mask_char,'(I2.2)')  mid
1390             filename = 'DATA_MASK_' // mask_char // '_NETCDF' // coupling_char
1391             av = 0
1392          ELSE
1393             mid = file_id - (200+max_masks)
1394             WRITE ( mask_char,'(I2.2)')  mid
1395             filename = 'DATA_MASK_' // mask_char // '_AV_NETCDF' // &
1396                  coupling_char
1397             av = 1
1398          ENDIF
1399!
1400!--       Inquire, if there is a NetCDF file from a previuos run. This should
1401!--       be opened for extension, if its dimensions and variables match the
1402!--       actual run.
1403          INQUIRE( FILE=filename, EXIST=netcdf_extend )
1404
1405          IF ( netcdf_extend )  THEN
1406!
1407!--          Open an existing NetCDF file for output
1408#if defined( __netcdf4 )
1409             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_mask(mid,av), &
1410                                  COMM = comm2d, INFO = MPI_INFO_NULL )
1411#else
1412             nc_stat = NF90_OPEN( filename, NF90_WRITE, id_set_mask(mid,av) )
1413#endif
1414             CALL handle_netcdf_error( 'check_open', 456 )
1415!
1416!--          Read header information and set all ids. If there is a mismatch
1417!--          between the previuos and the actual run, netcdf_extend is returned
1418!--          as .FALSE.
1419             CALL define_netcdf_header( 'ma', netcdf_extend, file_id )
1420
1421!
1422!--          Remove the local file, if it can not be extended
1423             IF ( .NOT. netcdf_extend )  THEN
1424                nc_stat = NF90_CLOSE( id_set_mask(mid,av) )
1425                CALL handle_netcdf_error( 'check_open', 457 )
1426                CALL local_system('rm ' // TRIM( filename ) )
1427             ENDIF
1428
1429          ENDIF         
1430
1431          IF ( .NOT. netcdf_extend )  THEN
1432!
1433!--          Create a new NetCDF output file with requested NetCDF format
1434             IF ( netcdf_data_format == 1 )  THEN
1435!
1436!--             Classic NetCDF format
1437                nc_stat = NF90_CREATE( filename, NF90_NOCLOBBER, &
1438                                       id_set_mask(mid,av) )
1439
1440             ELSEIF ( netcdf_data_format == 2 )  THEN
1441!
1442!--             64bit-offset format
1443                nc_stat = NF90_CREATE( filename,                               &
1444                                       OR( NF90_NOCLOBBER, NF90_64BIT_OFFSET ),&
1445                                       id_set_mask(mid,av) )
1446
1447
1448#if defined( __netcdf4 )
1449             ELSEIF ( netcdf_data_format == 3 )  THEN
1450!
1451!--             NetCDF4/HDF5 format
1452                nc_stat = NF90_CREATE( filename,                               &
1453                                       OR( NF90_NOCLOBBER, NF90_NETCDF4 ),     &
1454                                       id_set_mask(mid,av), COMM = comm2d,     &
1455                                       INFO = MPI_INFO_NULL )
1456
1457             ELSEIF ( netcdf_data_format == 4 )  THEN
1458!
1459!--             NetCDF4/HDF5 format with classic model flag
1460                nc_stat = NF90_CREATE( filename,                               &
1461                                       OR( NF90_NOCLOBBER,                     &
1462                                        OR( NF90_CLASSIC_MODEL, NF90_HDF5 ) ), &
1463                                       id_set_mask(mid,av), COMM = comm2d,     &
1464                                       INFO = MPI_INFO_NULL )
1465#endif
1466             ENDIF
1467
1468             CALL handle_netcdf_error( 'check_open', 458 )
1469!
1470!--          Define the header
1471             CALL define_netcdf_header( 'ma', netcdf_extend, file_id )
1472
1473          ENDIF
1474
1475
1476#else
1477
1478       CASE ( 101:109, 111:113, 116, 201:200+2*max_masks )
1479
1480!
1481!--       Nothing is done in case of missing netcdf support
1482          RETURN
1483
1484#endif
1485
1486       CASE DEFAULT
1487
1488          WRITE( message_string, * ) 'no OPEN-statement for file-id ',file_id
1489          CALL message( 'check_open', 'PA0172', 2, 2, -1, 6, 1 )
1490
1491    END SELECT
1492
1493!
1494!-- Set open flag
1495    openfile(file_id)%opened = .TRUE.
1496
1497!
1498!-- Formats
14993300 FORMAT ('#'/                                                   &
1500             'coord 1  file=',A,'  filetype=unformatted'/           &
1501             'coord 2  file=',A,'  filetype=unformatted  skip=',I6/ &
1502             'coord 3  file=',A,'  filetype=unformatted  skip=',I6/ &
1503             '#')
15044000 FORMAT ('# ',A)
15055000 FORMAT ('# ',A/                                                          &
1506             '#1 E'/'#2 E*'/'#3 dt'/'#4 u*'/'#5 th*'/'#6 umax'/'#7 vmax'/     &
1507             '#8 wmax'/'#9 div_new'/'#10 div_old'/'#11 z_i_wpt'/'#12 z_i_pt'/ &
1508             '#13 w*'/'#14 w''pt''0'/'#15 w''pt'''/'#16 wpt'/'#17 pt(0)'/     &
1509             '#18 pt(zp)'/'#19 splptx'/'#20 splpty'/'#21 splptz')
15108000 FORMAT (A/                                                            &
1511             '  step    time  # of parts   lPE sent/recv  rPE sent/recv  ',&
1512             'sPE sent/recv  nPE sent/recv  max # of parts'/               &
1513             103('-'))
1514
1515 END SUBROUTINE check_open
Note: See TracBrowser for help on using the repository browser.