blob: a0d7d51e1dbbe6f3eaa4dd628e2ce2c77801ce0b (
about) (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
ifneq ($(FC), ifort)
ifneq ($(FC), gfortran)
ifneq ($(shell which ifort 2>/dev/null),)
FC = ifort
endif
ifneq ($(shell which gfortran 2>/dev/null),)
FC = gfortran
endif
endif
endif
ifndef FFLAGS
ifeq ($(FC), gfortran)
FFLAGS = -std=f2008 -Wall -pedantic -fbounds-check -fimplicit-none \
-ffree-form -O2 -I/usr/include -lfftw3 -lm
endif
ifeq ($(FC), ifort)
FFLAGS = -std08 -module . -implicitnone -pedantic -check bounds \
-O2 -I/usr/include -lfftw3 -lm
endif
endif
all : fourier
fourier : src/fourier.f90
$(FC) $(FFLAGS) $^ -o $@
res/f1_original.txt : fourier
./fourier f1 > res/f1_original.txt
res/f1_dft.txt : fourier
./fourier f1 dft > res/f1_dft.txt
res/f2_original.txt : fourier
./fourier f2 > res/f2_original.txt
res/f2_dft.txt : fourier
./fourier f2 dft > res/f2_dft.txt
res/f2_filtered.txt : fourier
./fourier f2 filtered > res/f2_filtered.txt
res/%.png : src/%.gnuplot res/%.txt
gnuplot -c $<
clean :
-rm fourier res/*.txt
.PHONY : all clean
|