source: flexpart.git/src/makefile @ 9669e1e

10.4.1_peseiGFS_025bugfixes+enhancementsdevrelease-10release-10.4.1scaling-bugunivie
Last change on this file since 9669e1e was 9669e1e, checked in by Sabine <sabine.eckhardt@…>, 8 years ago

makefile with routine advance_rec.f90 added

  • Property mode set to 100644
File size: 15.3 KB
Line 
1SHELL = /bin/bash
2################################################################################
3#  DESCRIPTION
4#    Makefile for FLEXPART. Standard (serial) and parallel (MPI) version
5#
6#    Dependencies are resolved in this makefile, so parallel make is
7#    possible ("make -j")
8#
9#    At NILU we have installed gcc-4.9.1 and libraries under user /homevip/flexpart
10#    ("ROOT_DIR")
11#    To use gfortran version 4.9, add "gcc=4.9" to the make command, e.g.
12#       'make -j ecmwf gcc=4.9',
13#    also set environment variable LD_LIBRARY_PATH to point to compiler libraries
14#
15#  USAGE
16#    Compile serial FLEXPART (ECMWF)
17#      make [-j] ecmwf
18#
19#    Compile parallel FLEXPART (ECMWF)
20#      make [-j] ecmwf-mpi
21#     
22#    Compile for debugging parallel FLEXPART (ECMWF)
23#      make [-j] ecmwf-mpi-dbg
24#
25#    Compile serial FLEXPART (GFS)
26#      make [-j] gfs
27#
28#    Compile parallel FLEXPART (GFS)
29#      make [-j] gfs-mpi
30#
31################################################################################
32
33## PROGRAMS
34FLEXPART-ECMWF-MPI      = FP_ecmwf_MPI
35FLEXPART-ECMWF-MPI-DBG  = DBG_FP_ecmwf_MPI
36FLEXPART-ECMWF          = FP_ecmwf_gfortran
37FLEXPART-GFS            = FP_gfs_gfortran
38FLEXPART-GFS-MPI        = FP_gfs_MPI
39
40ifeq ($(gcc), 4.9)
41# Compiled libraries under users ~flexpart, gfortran v4.9
42        ROOT_DIR = /homevip/flexpart/
43#       ROOT_DIR = /homevip/espen/
44
45        F90       = ${ROOT_DIR}/gcc-4.9.1/bin/gfortran
46        MPIF90    = ${ROOT_DIR}/bin/mpifort
47
48        INCPATH1  = ${ROOT_DIR}/gcc-4.9.1/include       
49        INCPATH2  = ${ROOT_DIR}/include
50        LIBPATH1 = ${ROOT_DIR}/lib
51
52else
53# Default: System libraries at NILU, gfortran v4.6
54        F90       = /usr/bin/gfortran
55        MPIF90    = /usr/bin/mpif90.openmpi
56
57        INCPATH1 = /xnilu_wrk/flex_wrk/bin64/grib_api/include
58        INCPATH2 = /usr/include
59        LIBPATH1 = /xnilu_wrk/flex_wrk/bin64/grib_api/lib
60endif
61
62
63## OPTIMIZATION LEVEL
64O_LEV = 2 # [0,1,2,3,g,s,fast]
65O_LEV_DBG = g # [0,g]
66
67## LIBRARIES
68LIBS = -lgrib_api_f90 -lgrib_api -lm -ljasper -lnetcdff # -fopenmp
69
70FFLAGS   = -I$(INCPATH1) -I$(INCPATH2) -O$(O_LEV) -g -m64 -mcmodel=medium -fconvert=little-endian -frecord-marker=4 -fmessage-length=0 -flto=jobserver -O$(O_LEV) $(FUSER)  #-Warray-bounds -fcheck=all # -march=native
71
72DBGFLAGS = -I$(INCPATH1) -I$(INCPATH2) -O$(O_LEV_DBG) -g3 -ggdb3 -m64 -mcmodel=medium -fconvert=little-endian -frecord-marker=4 -fmessage-length=0 -flto=jobserver -O$(O_LEV_DBG) -fbacktrace   -Wall  -fdump-core $(FUSER)  #  -ffpe-trap=invalid,overflow,denormal,underflow,zero  -Warray-bounds -fcheck=all
73
74LDFLAGS  = $(FFLAGS) -L$(LIBPATH1) $(LIBS) #-L$(LIBPATH2)
75LDDEBUG  = $(DBGFLAGS) -L$(LIBPATH1) $(LIBS) #-L$(LIBPATH2)
76
77MODOBJS = \
78par_mod.o               com_mod.o \
79conv_mod.o              hanna_mod.o \
80interpol_mod.o          cmapf_mod.o \
81unc_mod.o               oh_mod.o \
82xmass_mod.o             flux_mod.o \
83point_mod.o             outg_mod.o \
84mean_mod.o              random_mod.o
85
86MPI_MODOBJS = \
87mpi_mod.o
88
89## Serial versions (MPI version with same functionality and name '_mpi.f90' exists)
90OBJECTS_SERIAL = \
91        releaseparticles.o      partoutput.o \
92        conccalc.o \
93        init_domainfill.o       concoutput.o  \
94        timemanager.o FLEXPART.o        \
95        readpartpositions.o \
96        partoutput_short.o              \
97        concoutput_nest.o       \
98        boundcond_domainfill.o  \
99        redist.o                \
100        concoutput_surf.o       concoutput_surf_nest.o  \
101        getfields.o
102
103## For MPI version
104OBJECTS_MPI = releaseparticles_mpi.o partoutput_mpi.o \
105        conccalc_mpi.o \
106        init_domainfill_mpi.o concoutput_mpi.o  \
107        timemanager_mpi.o FLEXPART_MPI.o        \
108        readpartpositions_mpi.o         \
109        partoutput_short_mpi.o          \
110        concoutput_nest_mpi.o           \
111        boundcond_domainfill_mpi.o      \
112        redist_mpi.o            \
113        concoutput_surf_mpi.o   concoutput_surf_nest_mpi.o      \
114        getfields_mpi.o
115
116### WINDFIELDS
117## For ECMWF (serial) version:
118OBJECTS_ECMWF = \
119        calcpar.o          readwind.o \
120        richardson.o       verttransform.o \
121        obukhov.o          gridcheck.o  \
122        convmix.o          calcmatrix.o \
123        ecmwf_mod.o
124
125
126## For ECMWF MPI version:
127OBJECTS_ECMWF_MPI = \
128        gridcheck.o        readwind_mpi.o \
129        calcpar.o          \
130        richardson.o       verttransform.o \
131        obukhov.o          \
132        convmix.o          calcmatrix.o \
133        ecmwf_mod.o
134
135## For GFS (serial) version:
136OBJECTS_GFS = \
137        calcpar_gfs.o          readwind_gfs.o \
138        richardson_gfs.o       verttransform_gfs.o \
139        obukhov_gfs.o          gridcheck_gfs.o  \
140        convmix_gfs.o          calcmatrix_gfs.o \
141        gfs_mod.o
142
143OBJECTS = \
144advance.o               initialize.o            \
145writeheader.o           writeheader_txt.o       \
146writeheader_surf.o      assignland.o\
147part0.o                 gethourlyOH.o\
148caldate.o               partdep.o \
149coordtrafo.o            psih.o \
150raerod.o                readcommand.o   \
151drydepokernel.o         readreceptors.o \
152erf.o                   readavailable.o \
153ew.o                    readreleases.o  \
154readdepo.o              advance_rec.o   \
155psim.o                  outgrid_init.o  \
156outgrid_init_nest.o     \
157photo_O1D.o             readlanduse.o \
158interpol_wind.o         readoutgrid.o \
159interpol_all.o          readpaths.o \
160getrb.o                 \
161getrc.o                 \
162getvdep.o               readspecies.o \
163interpol_misslev.o      \
164scalev.o \
165pbl_profile.o           readOHfield.o\
166juldate.o               \
167interpol_vdep.o         interpol_rain.o \
168hanna.o                 wetdepokernel.o \
169                  wetdepo.o \
170hanna_short.o           windalign.o \
171hanna1.o                        \
172                        gridcheck_nests.o \
173readwind_nests.o        calcpar_nests.o \
174verttransform_nests.o   interpol_all_nests.o \
175interpol_wind_nests.o   interpol_misslev_nests.o \
176interpol_vdep_nests.o   interpol_rain_nests.o \
177readageclasses.o         \
178calcfluxes.o            fluxoutput.o \
179qvsat.o                 skplin.o \
180convect43c.o            \
181sort2.o                 distance.o \
182centerofmass.o          plumetraj.o \
183openouttraj.o           calcpv.o \
184calcpv_nests.o          distance2.o \
185clustering.o            interpol_wind_short.o \
186interpol_wind_short_nests.o shift_field_0.o \
187shift_field.o             \
188openreceptors.o         \
189readoutgrid_nest.o \
190writeheader_nest.o writeheader_nest_surf.o \
191wetdepokernel_nest.o \
192drydepokernel_nest.o    zenithangle.o \
193ohreaction.o            getvdep_nests.o \
194initial_cond_calc.o     initial_cond_output.o \
195dynamic_viscosity.o     get_settling.o  \
196initialize_cbl_vel.o    re_initialize_particle.o \
197cbl.o                   netcdf_output_mod.o
198
199%.o: %.mod
200
201ecmwf: $(FLEXPART-ECMWF)
202ecmwf: FC := $(F90)
203
204ecmwf-mpi: $(FLEXPART-ECMWF-MPI)
205ecmwf-mpi: FC := $(MPIF90)
206
207ecmwf-mpi-dbg: $(FLEXPART-ECMWF-MPI-DBG)
208ecmwf-mpi-dbg: FFLAGS := $(DBGFLAGS) 
209ecmwf-mpi-dbg: LDFLAGS:= $(LDDEBUG) 
210ecmwf-mpi-dbg: FC := $(MPIF90)
211
212gfs: $(FLEXPART-GFS)
213gfs: FC := $(F90)
214
215gfs-mpi: $(FLEXPART-GFS-MPI)
216gfs-mpi: FC := $(MPIF90)
217
218#all: $(FLEXPART-ECMWF)
219#all: $(FLEXPART-ECMWF-MPI)
220
221## This allows for switching between ECMWF/GFS without editing source code.
222wind_mod = ecmwf_mod.o # default wind
223# ifeq ($(MAKECMDGOALS),ecmwf)
224# wind_mod = ecmwf_mod.o
225# endif
226# ifeq ($(MAKECMDGOALS),ecmwf-mpi)
227# wind_mod = ecmwf_mod.o
228# endif
229# ifeq ($(MAKECMDGOALS),ecmwf-mpi-dbg)
230# wind_mod = ecmwf_mod.o
231# endif
232
233ifeq ($(MAKECMDGOALS),gfs)
234wind_mod = gfs_mod.o
235endif
236ifeq ($(MAKECMDGOALS),gfs-mpi)
237wind_mod = gfs_mod.o
238endif
239
240$(FLEXPART-ECMWF): $(MODOBJS) $(OBJECTS) $(OBJECTS_SERIAL) $(OBJECTS_ECMWF)
241        +$(FC) -o $@ $(MODOBJS) $(OBJECTS) $(OBJECTS_SERIAL) $(OBJECTS_ECMWF) $(LDFLAGS)
242
243$(FLEXPART-ECMWF-MPI): $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) $(OBJECTS_ECMWF_MPI)
244        +$(FC) -o $@ $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) \
245        $(OBJECTS_ECMWF_MPI) $(LDFLAGS)
246#       +$(FC) -o $@ *.o $(LDFLAGS)
247
248$(FLEXPART-ECMWF-MPI-DBG): $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) \
249        $(OBJECTS_ECMWF_MPI)
250        +$(FC) -o $@ $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) \
251        $(OBJECTS_ECMWF_MPI) $(LDFLAGS)
252
253$(FLEXPART-GFS): $(MODOBJS) $(OBJECTS) $(OBJECTS_SERIAL) $(OBJECTS_GFS)
254        +$(FC) -o $@ $(MODOBJS) $(OBJECTS) $(OBJECTS_SERIAL) $(OBJECTS_GFS) $(LDFLAGS)
255
256$(FLEXPART-GFS-MPI): $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) $(OBJECTS_GFS)
257        +$(FC) -o $@ $(MODOBJS) $(MPI_MODOBJS) $(OBJECTS) $(OBJECTS_MPI) \
258        $(OBJECTS_GFS) $(LDFLAGS)
259
260%.o: %.f90
261        +$(FC) -c $(FFLAGS) $<
262
263clean:
264        \rm -f *.o *.mod
265
266cleanall:
267        \rm -f *.o *.mod $(FLEXPART-ECMWF-MPI) $(FLEXPART-ECMWF-MPI-DBG) $(FLEXPART-ECMWF) \
268        $(FLEXPART-GFS-MPI) $(FLEXPART-GFS)
269
270.SUFFIXES = $(SUFFIXES) .f90
271
272## DEPENDENCIES
273advance_rec.o: cmapf_mod.o com_mod.o hanna_mod.o interpol_mod.o par_mod.o \
274        point_mod.o random_mod.o
275advance.o: cmapf_mod.o com_mod.o hanna_mod.o interpol_mod.o par_mod.o \
276        point_mod.o random_mod.o
277assignland.o: com_mod.o par_mod.o
278boundcond_domainfill.o: com_mod.o par_mod.o point_mod.o random_mod.o
279boundcond_domainfill_mpi.o: com_mod.o mpi_mod.o par_mod.o point_mod.o \
280        random_mod.o
281calcfluxes.o: com_mod.o flux_mod.o outg_mod.o par_mod.o
282calcmatrix.o: com_mod.o conv_mod.o par_mod.o
283calcmatrix_gfs.o: com_mod.o conv_mod.o par_mod.o
284calcpar.o: com_mod.o par_mod.o
285calcpar_gfs.o: com_mod.o par_mod.o
286calcpar_nests.o: com_mod.o par_mod.o
287calcpv.o: com_mod.o par_mod.o
288calcpv_nests.o: com_mod.o par_mod.o
289caldate.o: par_mod.o
290cbl.o: com_mod.o par_mod.o
291centerofmass.o: par_mod.o
292clustering.o: par_mod.o
293cmapf_mod.o: par_mod.o
294com_mod.o: par_mod.o
295conccalc.o: com_mod.o outg_mod.o par_mod.o unc_mod.o
296conccalc_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o unc_mod.o
297concoutput.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
298concoutput_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o point_mod.o \
299        unc_mod.o mean_mod.o
300concoutput_nest.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
301concoutput_nest_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o point_mod.o \
302        unc_mod.o mean_mod.o
303concoutput_surf.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
304concoutput_surf_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o point_mod.o \
305        unc_mod.o mean_mod.o
306concoutput_surf_nest.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
307concoutput_surf_nest_mpi.o: com_mod.o mpi_mod.o outg_mod.o par_mod.o \
308        point_mod.o unc_mod.o mean_mod.o
309conv_mod.o: par_mod.o
310convect43c.o: conv_mod.o par_mod.o
311convmix.o: com_mod.o conv_mod.o flux_mod.o par_mod.o
312convmix_gfs.o: com_mod.o conv_mod.o par_mod.o
313coordtrafo.o: com_mod.o par_mod.o point_mod.o
314distance.o: par_mod.o
315distance2.o: par_mod.o
316drydepokernel.o: com_mod.o par_mod.o unc_mod.o
317drydepokernel_nest.o: com_mod.o par_mod.o unc_mod.o
318erf.o: par_mod.o
319FLEXPART.o: com_mod.o conv_mod.o par_mod.o point_mod.o random_mod.o netcdf_output_mod.o
320FLEXPART_MPI.o: com_mod.o conv_mod.o mpi_mod.o par_mod.o point_mod.o \
321        random_mod.o netcdf_output_mod.o
322fluxoutput.o: com_mod.o flux_mod.o outg_mod.o par_mod.o
323get_settling.o: com_mod.o par_mod.o
324getfields.o: com_mod.o par_mod.o
325getfields_mpi.o: com_mod.o par_mod.o mpi_mod.o
326gethourlyOH.o: com_mod.o oh_mod.o par_mod.o
327getrb.o: par_mod.o
328getrc.o: com_mod.o par_mod.o
329getvdep.o: com_mod.o par_mod.o
330getvdep_nests.o: com_mod.o par_mod.o
331gridcheck.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
332gridcheck_emos.o: com_mod.o conv_mod.o par_mod.o
333gridcheck_fnl.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
334gridcheck_gfs.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
335gridcheck_gfs_emos.o: com_mod.o conv_mod.o par_mod.o
336gridcheck_nests.o: com_mod.o par_mod.o
337gridcheck_nests_emos.o: com_mod.o par_mod.o
338gridcheck_orig_ecmwf.o: cmapf_mod.o com_mod.o conv_mod.o par_mod.o
339hanna.o: com_mod.o hanna_mod.o par_mod.o
340hanna1.o: com_mod.o hanna_mod.o par_mod.o
341hanna_short.o: com_mod.o hanna_mod.o par_mod.o
342init_domainfill.o: com_mod.o par_mod.o point_mod.o random_mod.o
343init_domainfill_mpi.o: com_mod.o mpi_mod.o par_mod.o point_mod.o \
344        random_mod.o
345initial_cond_calc.o: com_mod.o outg_mod.o par_mod.o unc_mod.o
346initial_cond_output.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o
347initialize.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o random_mod.o
348initialize_cbl_vel.o: com_mod.o par_mod.o random_mod.o
349interpol_all.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
350interpol_all_nests.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
351interpol_misslev.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
352interpol_misslev_nests.o: com_mod.o hanna_mod.o interpol_mod.o par_mod.o
353interpol_mod.o: par_mod.o
354interpol_rain.o: par_mod.o
355interpol_rain_nests.o: par_mod.o
356interpol_vdep.o: com_mod.o interpol_mod.o par_mod.o
357interpol_vdep_nests.o: com_mod.o interpol_mod.o par_mod.o
358interpol_wind.o: com_mod.o interpol_mod.o par_mod.o
359interpol_wind_nests.o: com_mod.o interpol_mod.o par_mod.o
360interpol_wind_short.o: com_mod.o interpol_mod.o par_mod.o
361interpol_wind_short_nests.o: com_mod.o interpol_mod.o par_mod.o
362juldate.o: par_mod.o
363mean_mod.o: par_mod.o
364mpi_mod.o: com_mod.o par_mod.o unc_mod.o
365netcdf_output_mod.o: com_mod.o outg_mod.o par_mod.o point_mod.o unc_mod.o mean_mod.o
366obukhov.o: par_mod.o
367obukhov_gfs.o: par_mod.o
368ohreaction.o: com_mod.o oh_mod.o par_mod.o
369openouttraj.o: com_mod.o par_mod.o point_mod.o
370openreceptors.o: com_mod.o par_mod.o
371outg_mod.o: par_mod.o
372outgrid_init.o: com_mod.o flux_mod.o oh_mod.o outg_mod.o par_mod.o unc_mod.o
373outgrid_init_nest.o: com_mod.o outg_mod.o par_mod.o unc_mod.o
374par_mod.o : $(wind_mod)
375part0.o: par_mod.o
376partdep.o: par_mod.o
377partoutput.o: com_mod.o par_mod.o
378partoutput_mpi.o: com_mod.o mpi_mod.o par_mod.o
379partoutput_short.o: com_mod.o par_mod.o
380partoutput_short_mpi.o: com_mod.o mpi_mod.o par_mod.o
381pbl_profile.o: par_mod.o
382plumetraj.o: com_mod.o par_mod.o point_mod.o mean_mod.o
383psih.o: par_mod.o
384psim.o: par_mod.o
385raerod.o: par_mod.o
386re_initialize_particle.o: com_mod.o par_mod.o
387readageclasses.o: com_mod.o par_mod.o
388readavailable.o: com_mod.o par_mod.o
389readcommand.o: com_mod.o par_mod.o
390readdepo.o: com_mod.o par_mod.o
391readlanduse.o: com_mod.o par_mod.o
392#readlanduse_int1.o: com_mod.o par_mod.o
393readOHfield.o: com_mod.o oh_mod.o par_mod.o
394readoutgrid.o: com_mod.o outg_mod.o par_mod.o
395readoutgrid_nest.o: com_mod.o outg_mod.o par_mod.o
396readpartpositions.o: com_mod.o par_mod.o random_mod.o
397readpartpositions_mpi.o: com_mod.o mpi_mod.o par_mod.o random_mod.o
398readpaths.o: com_mod.o par_mod.o
399readreceptors.o: com_mod.o par_mod.o
400readreleases.o: com_mod.o par_mod.o point_mod.o xmass_mod.o
401readspecies.o: com_mod.o par_mod.o
402readwind.o: com_mod.o par_mod.o
403readwind_emos.o: com_mod.o par_mod.o
404readwind_gfs.o: com_mod.o par_mod.o
405readwind_gfs_emos.o: com_mod.o par_mod.o
406readwind_mpi.o: com_mod.o mpi_mod.o par_mod.o
407readwind_nests.o: com_mod.o par_mod.o
408readwind_nests_emos.o: com_mod.o par_mod.o
409redist.o: com_mod.o conv_mod.o par_mod.o random_mod.o
410redist_mpi.o: com_mod.o conv_mod.o mpi_mod.o par_mod.o random_mod.o
411releaseparticles.o: com_mod.o par_mod.o point_mod.o random_mod.o \
412        xmass_mod.o
413releaseparticles_mpi.o: com_mod.o mpi_mod.o par_mod.o point_mod.o \
414        random_mod.o xmass_mod.o
415richardson.o: par_mod.o
416richardson_gfs.o: par_mod.o
417scalev.o: par_mod.o
418shift_field.o: par_mod.o
419shift_field_0.o: par_mod.o
420timemanager.o: com_mod.o flux_mod.o netcdf_output_mod.o oh_mod.o outg_mod.o \
421        par_mod.o point_mod.o unc_mod.o xmass_mod.o
422timemanager_mpi.o: com_mod.o flux_mod.o mpi_mod.o oh_mod.o outg_mod.o \
423        par_mod.o point_mod.o unc_mod.o xmass_mod.o
424unc_mod.o: par_mod.o
425verttransform.o: cmapf_mod.o com_mod.o par_mod.o
426verttransform_gfs.o: cmapf_mod.o com_mod.o par_mod.o
427verttransform_nests.o: com_mod.o par_mod.o
428wetdepo.o: com_mod.o par_mod.o point_mod.o
429wetdepokernel.o: com_mod.o par_mod.o unc_mod.o
430wetdepokernel_nest.o: com_mod.o par_mod.o unc_mod.o
431writeheader.o: com_mod.o outg_mod.o par_mod.o point_mod.o
432writeheader_nest.o: com_mod.o outg_mod.o par_mod.o point_mod.o
433writeheader_nest_surf.o: com_mod.o outg_mod.o par_mod.o point_mod.o
434writeheader_surf.o: com_mod.o outg_mod.o par_mod.o point_mod.o
435writeheader_txt.o: com_mod.o outg_mod.o par_mod.o point_mod.o
436zenithangle.o: par_mod.o
Note: See TracBrowser for help on using the repository browser.
hosted by ZAMG