source: palm/trunk/SOURCE/close_file.f90 @ 1625

Last change on this file since 1625 was 1329, checked in by raasch, 11 years ago

last commit documented

  • Property svn:keywords set to Id
File size: 8.4 KB
RevLine 
[1]1 SUBROUTINE close_file( file_id )
2
[1036]3!--------------------------------------------------------------------------------!
4! This file is part of PALM.
5!
6! PALM is free software: you can redistribute it and/or modify it under the terms
7! of the GNU General Public License as published by the Free Software Foundation,
8! either version 3 of the License, or (at your option) any later version.
9!
10! PALM is distributed in the hope that it will be useful, but WITHOUT ANY
11! WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
12! A PARTICULAR PURPOSE.  See the GNU General Public License for more details.
13!
14! You should have received a copy of the GNU General Public License along with
15! PALM. If not, see <http://www.gnu.org/licenses/>.
16!
[1310]17! Copyright 1997-2014 Leibniz Universitaet Hannover
[1036]18!--------------------------------------------------------------------------------!
19!
[263]20! Current revisions:
[1]21! -----------------
[1329]22!
23!
[1321]24! Former revisions:
25! -----------------
26! $Id: close_file.f90 1329 2014-03-21 11:09:15Z heinze $
27!
[1329]28! 1327 2014-03-21 11:00:16Z raasch
29! parts concerning iso2d and avs output removed
30!
[1321]31! 1320 2014-03-20 08:40:49Z raasch
[1320]32! ONLY-attribute added to USE-statements,
33! kind-parameters added to all INTEGER and REAL declaration statements,
34! kinds are defined in new module kinds,
35! revision history before 2012 removed,
36! comment fields (!:) to be used for variable explanations added to
37! all variable declaration statements
[1]38!
[1093]39! 1092 2013-02-02 11:24:22Z raasch
40! unused variables removed
41!
[1037]42! 1036 2012-10-22 13:43:42Z raasch
43! code put under GPL (PALM 3.9)
44!
[1035]45! 1031 2012-10-19 14:35:30Z raasch
46! netCDF4 without parallel file support implemented
47!
[965]48! 964 2012-07-26 09:14:24Z raasch
49! old profil-units (40:49) and respective code removed
50!
[1]51! Revision 1.1 (close_files) 1997/08/11 06:11:18  raasch
52! Initial revision
53!
54!
55! Description:
56! ------------
57! Close specified file or all open files, if "0" has been given as the
58! calling argument. In that case, execute last actions for certain unit
59! numbers, if required.
60!------------------------------------------------------------------------------!
61
[1320]62    USE control_parameters,                                                    &
[1327]63        ONLY:  do2d_xz_n, do2d_xy_n, do2d_yz_n, do3d_avs_n,                    &
64               host, max_masks, mid, netcdf_data_format,                       &
65               nz_do3d, openfile, run_description_header,       &
[1320]66               z_max_do2d
67               
68    USE grid_variables,                                                        &
69        ONLY:  dy
70       
71    USE indices,                                                               &
72        ONLY:  nx, ny, nz
73       
74    USE kinds
75   
[1]76    USE netcdf_control
[1320]77               
78    USE pegrid                                           
[1]79
80    IMPLICIT NONE
81
[1320]82    CHARACTER (LEN=10)  ::  datform = 'lit_endian' !:
83    CHARACTER (LEN=80)  ::  title                  !:
[1]84
[1320]85    INTEGER(iwp) ::  av           !:
86    INTEGER(iwp) ::  dimx         !:
87    INTEGER(iwp) ::  dimy         !:
88    INTEGER(iwp) ::  fid          !:
89    INTEGER(iwp) ::  file_id      !:
90    INTEGER(iwp) ::  planz        !:
[1]91
[1320]92    LOGICAL ::  checkuf = .TRUE.  !:
93    LOGICAL ::  datleg = .TRUE.   !:
94    LOGICAL ::  dbp = .FALSE.     !:
[1]95
[1320]96    REAL(wp) ::  sizex            !:
97    REAL(wp) ::  sizey            !:
98    REAL(wp) ::  yright           !:
[1]99
[1320]100    NAMELIST /GLOBAL/  checkuf, datform, dimx, dimy, dbp, planz,               &
[964]101                       title
[1092]102    NAMELIST /RAHMEN/  datleg
[1]103
104!
105!-- Close specified unit number (if opened) and set a flag that it has
106!-- been opened one time at least
107    IF ( file_id /= 0 )  THEN
108       IF ( openfile(file_id)%opened )  THEN
109          CLOSE ( file_id )
110          openfile(file_id)%opened        = .FALSE.
111          openfile(file_id)%opened_before = .TRUE.
112       ENDIF
113       RETURN
114    ENDIF
115
116!
117!-- Close all open unit numbers
[564]118    DO  fid = 1, 200+2*max_masks
[1]119
120       IF ( openfile(fid)%opened .OR. openfile(fid)%opened_before )  THEN
121!
122!--       Last actions for certain unit numbers
123          SELECT CASE ( fid )
124
125#if defined( __netcdf )
126             CASE ( 101 )
127
[1327]128                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]129                   nc_stat = NF90_CLOSE( id_set_xy(0) )
[263]130                   CALL handle_netcdf_error( 'close_file', 44 )
[1]131                ENDIF
132
133             CASE ( 102 )
134
[1327]135                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]136                   nc_stat = NF90_CLOSE( id_set_xz(0) )
[263]137                   CALL handle_netcdf_error( 'close_file', 45 )
[1]138                ENDIF
139
140             CASE ( 103 )
141
[1327]142                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]143                   nc_stat = NF90_CLOSE( id_set_yz(0) )
[263]144                   CALL handle_netcdf_error( 'close_file', 46 )
[1]145                ENDIF
146
147             CASE ( 104 )
148
[1327]149                IF ( myid == 0 )  THEN
[1]150                   nc_stat = NF90_CLOSE( id_set_pr )
[263]151                   CALL handle_netcdf_error( 'close_file', 47 )
[1]152                ENDIF
153
154             CASE ( 105 )
155
[1327]156                IF ( myid == 0 )  THEN
[1]157                   nc_stat = NF90_CLOSE( id_set_ts )
[263]158                   CALL handle_netcdf_error( 'close_file', 48 )
[1]159                ENDIF
160
161             CASE ( 106 )
162
[1327]163                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]164                   nc_stat = NF90_CLOSE( id_set_3d(0) )
[263]165                   CALL handle_netcdf_error( 'close_file', 49 )
[1]166                ENDIF
167
168             CASE ( 107 )
169
[1327]170                IF ( myid == 0 )  THEN
[1]171                   nc_stat = NF90_CLOSE( id_set_sp )
[263]172                   CALL handle_netcdf_error( 'close_file', 50 )
[1]173                ENDIF
174
175             CASE ( 108 )
176
[1327]177                nc_stat = NF90_CLOSE( id_set_prt )
178                CALL handle_netcdf_error( 'close_file', 51 )
[1]179
180             CASE ( 109 ) 
181
[1327]182                nc_stat = NF90_CLOSE( id_set_pts )
183                CALL handle_netcdf_error( 'close_file', 412 )
[1]184
185             CASE ( 111 )
186
[1327]187                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]188                   nc_stat = NF90_CLOSE( id_set_xy(1) )
[263]189                   CALL handle_netcdf_error( 'close_file', 52 )
[1]190                ENDIF
191
192             CASE ( 112 )
193
[1327]194                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]195                   nc_stat = NF90_CLOSE( id_set_xz(1) )
[263]196                   CALL handle_netcdf_error( 'close_file', 352 )
[1]197                ENDIF
198
199             CASE ( 113 )
200
[1327]201                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]202                   nc_stat = NF90_CLOSE( id_set_yz(1) )
[263]203                   CALL handle_netcdf_error( 'close_file', 353 )
[1]204                ENDIF
205
206             CASE ( 116 )
207
[1327]208                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[1]209                   nc_stat = NF90_CLOSE( id_set_3d(1) )
[263]210                   CALL handle_netcdf_error( 'close_file', 353 )
[1]211                ENDIF
212
[564]213             CASE ( 201:200+2*max_masks )
[410]214             
[1327]215                IF ( myid == 0  .OR.  netcdf_data_format > 4 )  THEN
[410]216!
217!--                decompose fid into mid and av
[564]218                   IF ( fid <= 200+max_masks )  THEN
219                      mid = fid - 200
[410]220                      av = 0
221                   ELSE
[564]222                      mid = fid - (200+max_masks)
[410]223                      av = 1
224                   ENDIF
225                   nc_stat = NF90_CLOSE( id_set_mask(mid,av) )
[564]226                   CALL handle_netcdf_error( 'close_file', 459 )
[410]227               
228                ENDIF
229
[1]230#endif
231
232          END SELECT
233!
234!--       Close file
235          IF ( openfile(fid)%opened )  CLOSE ( fid )
236
237       ENDIF
238
239    ENDDO
240
241!
242!-- Formats
[1320]2433200 FORMAT ('# AVS',A,'field file'/                                           &
244             '#'/                                                              &
245             '# ',A/                                                           &
246             'ndim=3'/                                                         &
247             'dim1=',I5/                                                       &
248             'dim2=',I5/                                                       &
249             'dim3=',I5/                                                       &
250             'nspace=3'/                                                       &
251             'veclen=',I5/                                                     &
252             'data=xdr_float'/                                                 &
[1]253             'field=rectilinear')
2544000 FORMAT ('time averaged over',F7.1,' s')
255
256
257 END SUBROUTINE close_file
Note: See TracBrowser for help on using the repository browser.