source: flexpart.git/src/makefile @ c0884a8

univie
Last change on this file since c0884a8 was c0884a8, checked in by pesei <petra seibert at univie ac at>, 6 years ago

replace CTBTO code for checking type of GRIB

  • Property mode set to 100644
File size: 16.0 KB
Line 
1SHELL = /bin/bash
2################################################################################
3#   
4#  LICENSE
5#   Valid-License-Identifier:   GPL-3.0-or-later
6#   License text: https://spdx.org/licenses/GPL-3.0-or-later.html#licenseText
7#
8#  DESCRIPTION
9#    Makefile for FLEXPART. Standard (serial) and parallel (MPI) version
10#
11#    Dependencies are resolved in this makefile, so parallel make is
12#    possible ("make -j")
13#
14#   
15#    The makefile is prepared for the environment at NILU.
16#    There, gcc-4.9.1 and libraries are installed under user /homevip/flexpart
17#    NILU users can compile with gfortran version 4.9 by addin "gcc=4.9" to the make command, e.g.
18#       'make -j ecmwf gcc=4.9',
19#    You also set environment variable LD_LIBRARY_PATH to point to compiler libraries
20#
21#    Other users will have to edit the
22#
23#    Makefile was modified to produce unified executable for both ECMWF and GFS meteo data formats
24#
25#    Cpp directives USE_MPIINPLACE were added to three source files. The effect of these directives
26#    are to enable the MPI_IN_PLACE option only if compiled with a -DUSE_MPIINPLACE directive.
27#    Otherwise, a safer option (which requires the allocation of another array) is used by default.
28#    In makefile added the -x f95-cpp-input flag for compiling of cpp directives.
29#
30#  USAGE
31#    Compile serial FLEXPART
32#      make [-j] [serial] [ncf=yes}
33#
34#    Compile parallel FLEXPART
35#      make [-j] mpi [ncf=yes}
36#     
37#    Compile for debugging parallel FLEXPART
38#      make [-j] mpi-dbg [ncf=yes}
39#
40#    ncf=yes adds support for output in netCDF format. Requires netCDF libs to be installed.
41#
42#  AUTHORS
43#    NILU people, Petra Seibert (PS), 2018
44#
45#  VERSION and CHANGES
46#    v1.0 as found in git branch dev on flexpart.eu, 2018-06-08
47#    v1.1 PS, make the file more useful for non-NILU users
48#
49################################################################################
50
51## PROGRAMS
52# Unified executable names
53# The same executable is used for both ECMWF and GFS metdata
54
55# Parallel processing executable
56FLEXPART-MPI = FLEXPART_MPI
57
58# Parallel processing executable with debugging info
59FLEXPART-MPI-DBG = DBG_FLEXPART_MPI
60
61# Serial processing executable
62FLEXPART-SERIAL = FLEXPART
63
64ifneq ($(gcc), 4.9)
65# make sure that all paths correspond to your system
66        F90       = gfortran
67        MPIF90    = mpifort
68
69        INCPATH1  = /usr/include       
70        INCPATH2  = /usr/include
71        LIBPATH1  = /usr/lib
72else
73# NILU: Compiled libraries under user ~flexpart, gfortran v4.9
74        ROOT_DIR = /homevip/flexpart/
75        ROOT_DIR = /homevip/flexpart/
76
77        F90       = ${ROOT_DIR}/gcc-4.9.1/bin/gfortran
78        MPIF90    = ${ROOT_DIR}/bin/mpifort
79
80        INCPATH1  = ${ROOT_DIR}/gcc-4.9.1/include       
81        INCPATH2  = ${ROOT_DIR}/include
82        LIBPATH1 = ${ROOT_DIR}/lib
83endif
84
85
86### Enable netCDF output?
87ifeq ($(ncf), yes)
88        NCOPT = -DUSE_NCF -lnetcdff     
89else
90        NCOPT = -UUSE_NCF
91endif
92
93
94
95#add path to gributils to default searchpath of make
96VPATH = gributils/
97
98
99## OPTIMIZATION LEVEL
100O_LEV = 2 # [0,1,2,3,g,s,fast]
101O_LEV_DBG = g # [0,g]
102
103## LIBRARIES
104LIBS = -lgrib_api_f90 -lgrib_api -lm -ljasper $(NCOPT)
105
106#FFLAGS   = -I$(INCPATH1) -I$(INCPATH2) -O$(O_LEV) -cpp -m64 -mcmodel=medium -fconvert=little-endian -frecord-marker=4 -fmessage-length=0 -flto=jobserver -O$(O_LEV) $(NCOPT) $(FUSER)  #-Warray-bounds -fcheck=all # -march=native
107#FFLAGS   = -I$(INCPATH1) -I$(INCPATH2) -O$(O_LEV) -cpp -mcmodel=medium -fconvert=little-endian -frecord-marker=4 -fmessage-length=0 -flto=jobserver -O$(O_LEV) $(NCOPT) $(FUSER)  # -fcheck=all -fbacktrace -march=native
108FFLAGS   = -I$(INCPATH1) -I$(INCPATH2) -O$(O_LEV) -cpp -mcmodel=medium -fconvert=little-endian -frecord-marker=4 -fmessage-length=0 -flto=jobserver -O$(O_LEV) $(NCOPT) $(FUSER)  -fcheck=all -fbacktrace -march=native
109
110# Explanation of unusual gfortran options
111# -fmessage-length=0: do not wrap around compiler messages at col 72
112# -flto=jobserver: use GNU make's job server mode to determine the number of parallel jobs. This is useful when the Makefile calling GCC is already executing in parallel. (+ in front of $(FC) further down also needed for parallel compiling).
113
114DBGFLAGS = -I$(INCPATH1) -I$(INCPATH2) -O$(O_LEV_DBG) -g3 -ggdb3 -cpp -m64 -mcmodel=medium -fconvert=little-endian -frecord-marker=4 -fmessage-length=0 -flto=jobserver -O$(O_LEV_DBG) $(NCOPT) -fbacktrace   -Wall  -fdump-core $(FUSER)  #  -ffpe-trap=invalid,overflow,denormal,underflow,zero   -fcheck=all
115
116LDFLAGS  = $(FFLAGS) -L$(LIBPATH1) -Wl,-rpath,$(LIBPATH1) $(LIBS) #-L$(LIBPATH2)
117LDDEBUG  = $(DBGFLAGS) -L$(LIBPATH1) $(LIBS) #-L$(LIBPATH2)
118
119MODOBJS = \
120par_mod.o               com_mod.o \
121conv_mod.o              hanna_mod.o \
122interpol_mod.o          cmapf_mod.o \
123unc_mod.o               oh_mod.o \
124xmass_mod.o             flux_mod.o \
125point_mod.o             outg_mod.o \
126mean_mod.o              random_mod.o \
127check_gribfile_mod.o   
128
129
130MPI_MODOBJS = \
131mpi_mod.o
132
133## Serial versions (MPI version with same functionality and name '_mpi.f90' exists)
134OBJECTS_SERIAL = \
135        releaseparticles.o      partoutput.o \
136        conccalc.o \
137        init_domainfill.o       concoutput.o  \
138        timemanager.o FLEXPART.o        \
139        readpartpositions.o \
140        partoutput_short.o              \
141        concoutput_nest.o       \
142        boundcond_domainfill.o  \
143        redist.o                \
144        concoutput_surf.o       concoutput_surf_nest.o  \
145        getfields.o \
146        readwind_ecmwf.o
147
148## For MPI version
149OBJECTS_MPI = releaseparticles_mpi.o partoutput_mpi.o \
150        conccalc_mpi.o \
151        init_domainfill_mpi.o concoutput_mpi.o  \
152        timemanager_mpi.o FLEXPART_MPI.o        \
153        readpartpositions_mpi.o         \
154        partoutput_short_mpi.o          \
155        concoutput_nest_mpi.o           \
156        boundcond_domainfill_mpi.o      \
157        redist_mpi.o            \
158        concoutput_surf_mpi.o   concoutput_surf_nest_mpi.o      \
159        getfields_mpi.o \
160        readwind_ecmwf_mpi.o
161
162OBJECTS_NCF = netcdf_output_mod.o
163
164OBJECTS = \
165advance.o               initialize.o            \
166writeheader.o           writeheader_txt.o       \
167writeprecip.o \
168writeheader_surf.o      assignland.o\
169part0.o                 gethourlyOH.o\
170caldate.o               partdep.o \
171coordtrafo.o            psih.o \
172raerod.o                readcommand.o   \
173drydepokernel.o         readreceptors.o \
174erf.o                   readavailable.o \
175ew.o                    readreleases.o  \
176readdepo.o              get_vdep_prob.o   \
177get_wetscav.o           readwind_gfs.o \
178psim.o                  outgrid_init.o  \
179outgrid_init_nest.o     calcmatrix.o \
180photo_O1D.o             readlanduse.o \
181interpol_wind.o         readoutgrid.o \
182interpol_all.o          readpaths.o \
183getrb.o                 obukhov.o \
184getrc.o                 convmix.o \
185getvdep.o               readspecies.o \
186interpol_misslev.o      richardson.o \
187scalev.o                verttransform_ecmwf.o \
188pbl_profile.o           readOHfield.o \
189juldate.o               verttransform_gfs.o \
190interpol_vdep.o         interpol_rain.o \
191hanna.o                 wetdepokernel.o \
192calcpar.o               wetdepo.o \
193hanna_short.o           windalign.o \
194hanna1.o                gridcheck_ecmwf.o \
195gridcheck_gfs.o         gridcheck_nests.o \
196readwind_nests.o        calcpar_nests.o \
197verttransform_nests.o   interpol_all_nests.o \
198interpol_wind_nests.o   interpol_misslev_nests.o \
199interpol_vdep_nests.o   interpol_rain_nests.o \
200readageclasses.o        \
201calcfluxes.o            fluxoutput.o \
202qvsat.o                 skplin.o \
203convect43c.o            \
204sort2.o                 distance.o \
205centerofmass.o          plumetraj.o \
206openouttraj.o           calcpv.o \
207calcpv_nests.o          distance2.o \
208clustering.o            interpol_wind_short.o \
209interpol_wind_short_nests.o shift_field_0.o \
210shift_field.o             \
211openreceptors.o         \
212readoutgrid_nest.o \
213writeheader_nest.o writeheader_nest_surf.o \
214wetdepokernel_nest.o \
215drydepokernel_nest.o    zenithangle.o \
216ohreaction.o            getvdep_nests.o \
217initial_cond_calc.o     initial_cond_output.o \
218dynamic_viscosity.o     get_settling.o  \
219initialize_cbl_vel.o    re_initialize_particle.o \
220cbl.o
221
222ifeq ($(ncf), yes)
223        OBJECTS := $(OBJECTS) $(OBJECTS_NCF)
224endif
225
226%.o: %.mod
227
228# serial executable
229serial: $(FLEXPART-SERIAL)
230serial: FC := $(F90)
231
232# parallel processing executable
233mpi: $(FLEXPART-MPI)
234mpi: FC := $(MPIF90)
235
236# parallel processing with debugging info
237mpi-dbg: $(FLEXPART-MPI-DBG)
238mpi-dbg: FFLAGS := $(DBGFLAGS)
239mpi-dbg: LDFLAGS:= $(LDDEBUG)
240mpi-dbg: FC := $(MPIF90)
241
242$(FLEXPART-SERIAL): $(MODOBJS) $(OBJECTS) $(OBJECTS_SERIAL)
243        +$(FC) -o $@ $(MODOBJS) $(OBJECTS) $(OBJECTS_SERIAL) $(LDFLAGS)
244
245$(FLEXPART-MPI): $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI)
246        +$(FC) -o $@ $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) \
247        $(LDFLAGS)
248
249$(FLEXPART-MPI-DBG): $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI)
250        +$(FC) -o $@ $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) \
251        $(LDFLAGS)
252
253%.o: %.f90
254        +$(FC) -c $(FFLAGS) $<
255
256clean:
257        \rm -f *.o *.mod
258
259cleanall:
260        \rm -f *.o *.mod $(FLEXPART-MPI) $(FLEXPART-MPI-DBG) $(FLEXPART-SERIAL)
261
262
263.SUFFIXES = $(SUFFIXES) .f90
264
265## DEPENDENCIES
266get_vdep_prob.o: cmapf_mod.o com_mod.o hanna_mod.o interpol_mod.o par_mod.o \
267        point_mod.o random_mod.o
268advance.o: cmapf_mod.o com_mod.o hanna_mod.o interpol_mod.o par_mod.o \
269        point_mod.o random_mod.o
270assignland.o: com_mod.o par_mod.o
271boundcond_domainfill.o: com_mod.o par_mod.o point_mod.o random_mod.o
272boundcond_domainfill_mpi.o: com_mod.o mpi_mod.o par_mod.o point_mod.o \
273        random_mod.o
274calcfluxes.o: com_mod.o flux_mod.o outg_mod.o par_mod.o
275calcmatrix.o: check_gribfile_mod.o conv_mod.o com_mod.o par_mod.o
276calcpar.o: com_mod.o par_mod.o check_gribfile_mod.o
277calcpar_nests.o: com_mod.o par_mod.o
278calcpv.o: com_mod.o par_mod.o
279calcpv_nests.o: com_mod.o par_mod.o
280caldate.o: par_mod.o
281cbl.o: com_mod.o par_mod.o
282centerofmass.o: par_mod.o
283clustering.o: par_mod.o
284cmapf_mod.o: par_mod.o
285com_mod.o: par_mod.o
286conccalc.o: com_mod.o outg_mod.o par_mod.o unc_mod.o
287conccalc_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o unc_mod.o
288concoutput.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
289concoutput_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o point_mod.o \
290        unc_mod.o mean_mod.o
291concoutput_nest.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
292concoutput_nest_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o point_mod.o \
293        unc_mod.o mean_mod.o
294concoutput_surf.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
295concoutput_surf_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o point_mod.o \
296        unc_mod.o mean_mod.o
297concoutput_surf_nest.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
298concoutput_surf_nest_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o \
299        point_mod.o unc_mod.o mean_mod.o
300conv_mod.o: par_mod.o
301convect43c.o: conv_mod.o par_mod.o
302convmix.o: com_mod.o conv_mod.o flux_mod.o par_mod.o check_gribfile_mod.o
303coordtrafo.o: com_mod.o par_mod.o point_mod.o
304distance.o: par_mod.o
305distance2.o: par_mod.o
306drydepokernel.o: com_mod.o par_mod.o unc_mod.o
307drydepokernel_nest.o: com_mod.o par_mod.o unc_mod.o
308erf.o: par_mod.o
309FLEXPART.o: com_mod.o conv_mod.o par_mod.o point_mod.o random_mod.o netcdf_output_mod.o check_gribfile_mod.o
310FLEXPART.o: check_gribfile_mod.o random_mod.o conv_mod.o com_mod.o par_mod.o point_mod.o
311FLEXPART_MPI.o: com_mod.o conv_mod.o mpi_mod.o par_mod.o point_mod.o \
312        random_mod.o netcdf_output_mod.o check_gribfile_mod.o
313fluxoutput.o: com_mod.o flux_mod.o outg_mod.o par_mod.o
314get_settling.o: com_mod.o par_mod.o
315getfields.o: com_mod.o par_mod.o check_gribfile_mod.o
316getfields_mpi.o: com_mod.o par_mod.o mpi_mod.o check_gribfile_mod.o
317gethourlyOH.o: com_mod.o oh_mod.o par_mod.o
318getrb.o: par_mod.o
319getrc.o: com_mod.o par_mod.o
320getvdep.o: com_mod.o par_mod.o
321getvdep_nests.o: com_mod.o par_mod.o
322gridcheck_ecmwf.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
323gridcheck_emos.o: com_mod.o conv_mod.o par_mod.o
324gridcheck_fnl.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
325gridcheck_gfs.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
326gridcheck_gfs_emos.o: com_mod.o conv_mod.o par_mod.o
327gridcheck_nests.o: com_mod.o par_mod.o
328gridcheck_nests_emos.o: com_mod.o par_mod.o
329gridcheck_orig_ecmwf.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
330hanna.o: com_mod.o hanna_mod.o par_mod.o
331hanna1.o: com_mod.o hanna_mod.o par_mod.o
332hanna_short.o: com_mod.o hanna_mod.o par_mod.o
333init_domainfill.o: com_mod.o par_mod.o point_mod.o random_mod.o
334init_domainfill_mpi.o: com_mod.o mpi_mod.o par_mod.o point_mod.o \
335        random_mod.o
336initial_cond_calc.o: com_mod.o outg_mod.o par_mod.o unc_mod.o
337initial_cond_output.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o
338initialize.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o random_mod.o
339initialize_cbl_vel.o: com_mod.o par_mod.o random_mod.o
340interpol_all.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
341interpol_all_nests.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
342interpol_misslev.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
343interpol_misslev_nests.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
344interpol_mod.o: par_mod.o
345interpol_rain.o: par_mod.o
346interpol_rain_nests.o: par_mod.o
347interpol_vdep.o: com_mod.o interpol_mod.o par_mod.o
348interpol_vdep_nests.o: com_mod.o interpol_mod.o par_mod.o
349interpol_wind.o: com_mod.o interpol_mod.o par_mod.o
350interpol_wind_nests.o: com_mod.o interpol_mod.o par_mod.o
351interpol_wind_short.o: com_mod.o interpol_mod.o par_mod.o
352interpol_wind_short_nests.o: com_mod.o interpol_mod.o par_mod.o
353juldate.o: par_mod.o
354mean_mod.o: par_mod.o
355mpi_mod.o: com_mod.o par_mod.o unc_mod.o
356netcdf_output_mod.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
357obukhov.o: par_mod.o check_gribfile_mod.o
358ohreaction.o: com_mod.o oh_mod.o par_mod.o
359openouttraj.o: com_mod.o par_mod.o point_mod.o
360openreceptors.o: com_mod.o par_mod.o
361outg_mod.o: par_mod.o
362outgrid_init.o: com_mod.o flux_mod.o oh_mod.o outg_mod.o par_mod.o unc_mod.o
363outgrid_init_nest.o: com_mod.o outg_mod.o par_mod.o unc_mod.o
364part0.o: par_mod.o
365partdep.o: par_mod.o
366partoutput.o: com_mod.o par_mod.o
367partoutput_mpi.o: com_mod.o mpi_mod.o par_mod.o
368partoutput_short.o: com_mod.o par_mod.o
369partoutput_short_mpi.o: com_mod.o mpi_mod.o par_mod.o
370pbl_profile.o: par_mod.o
371plumetraj.o: com_mod.o par_mod.o point_mod.o mean_mod.o
372psih.o: par_mod.o
373psim.o: par_mod.o
374raerod.o: par_mod.o
375re_initialize_particle.o: com_mod.o par_mod.o
376readageclasses.o: com_mod.o par_mod.o
377readavailable.o: com_mod.o par_mod.o
378readcommand.o: com_mod.o par_mod.o
379readdepo.o: com_mod.o par_mod.o
380readlanduse.o: com_mod.o par_mod.o
381#readlanduse_int1.o: com_mod.o par_mod.o
382readOHfield.o: com_mod.o oh_mod.o par_mod.o
383readoutgrid.o: com_mod.o outg_mod.o par_mod.o
384readoutgrid_nest.o: com_mod.o outg_mod.o par_mod.o
385readpartpositions.o: com_mod.o par_mod.o random_mod.o
386readpartpositions_mpi.o: com_mod.o mpi_mod.o par_mod.o random_mod.o
387readpaths.o: com_mod.o par_mod.o
388readreceptors.o: com_mod.o par_mod.o
389readreleases.o: com_mod.o par_mod.o point_mod.o xmass_mod.o
390readspecies.o: com_mod.o par_mod.o
391readwind_ecmwf.o: com_mod.o par_mod.o
392readwind_emos.o: com_mod.o par_mod.o
393readwind_gfs.o: com_mod.o par_mod.o
394readwind_gfs_emos.o: com_mod.o par_mod.o
395readwind_ecmwf_mpi.o: com_mod.o mpi_mod.o par_mod.o
396readwind_nests.o: com_mod.o par_mod.o
397readwind_nests_emos.o: com_mod.o par_mod.o
398redist.o: com_mod.o conv_mod.o par_mod.o random_mod.o
399redist_mpi.o: com_mod.o conv_mod.o mpi_mod.o par_mod.o random_mod.o
400releaseparticles.o: com_mod.o par_mod.o point_mod.o random_mod.o \
401        xmass_mod.o
402releaseparticles_mpi.o: com_mod.o mpi_mod.o par_mod.o point_mod.o \
403        random_mod.o xmass_mod.o
404richardson.o: par_mod.o check_gribfile_mod.o
405scalev.o: par_mod.o
406shift_field.o: par_mod.o
407shift_field_0.o: par_mod.o
408timemanager.o: com_mod.o flux_mod.o netcdf_output_mod.o oh_mod.o outg_mod.o \
409        par_mod.o point_mod.o unc_mod.o xmass_mod.o
410timemanager_mpi.o: com_mod.o flux_mod.o mpi_mod.o oh_mod.o outg_mod.o \
411        par_mod.o point_mod.o unc_mod.o xmass_mod.o netcdf_output_mod.o
412unc_mod.o: par_mod.o
413verttransform_ecmwf.o: cmapf_mod.o com_mod.o par_mod.o
414verttransform_gfs.o: cmapf_mod.o com_mod.o par_mod.o
415verttransform_nests.o: com_mod.o par_mod.o
416get_wetscav.o: com_mod.o par_mod.o point_mod.o
417wetdepo.o: com_mod.o par_mod.o point_mod.o
418wetdepokernel.o: com_mod.o par_mod.o unc_mod.o
419wetdepokernel_nest.o: com_mod.o par_mod.o unc_mod.o
420writeheader.o: com_mod.o outg_mod.o par_mod.o point_mod.o
421writeprecip.o: com_mod.o par_mod.o point_mod.o
422writeheader_nest.o: com_mod.o outg_mod.o par_mod.o point_mod.o
423writeheader_nest_surf.o: com_mod.o outg_mod.o par_mod.o point_mod.o
424writeheader_surf.o: com_mod.o outg_mod.o par_mod.o point_mod.o
425writeheader_txt.o: com_mod.o outg_mod.o par_mod.o point_mod.o
426zenithangle.o: par_mod.o
Note: See TracBrowser for help on using the repository browser.
hosted by ZAMG