3 ALLDIMS=33 64 125 246 487 968
4 TARGETS= primer lumpy.cfm sgtatham.cfm ring.cfm \
5 minimise-33 minimise-64 minimise-125 minimise-246 \
6 $(addprefix interpolate-, $(ALLDIMS)) \
7 $(addprefix view-, $(ALLDIMS)) \
8 $(addprefix output-, $(ALLDIMS))
11 CWARNS= -Wall -Wwrite-strings -Wpointer-arith -Werror -Wshadow
12 CXXWARNS= $(CWARNS) -Wno-shadow -Wno-error
15 CFLAGS_UNIPROC= -MMD $(OPTIMISE) -g $(CWARNS) $(DIMCFLAGS)
16 CXXFLAGS= -MMD $(OPTIMISE) -g $(CXXWARNS)
17 CFLAGS= $(CFLAGS_UNIPROC) $(NPROCCFLAGS)
19 LIBGSL= -lgsl -lgslcblas
21 o= >$@.new && mv -f $@.new $@
28 # $(MAKE) best-968.CFM
30 minimise: energy.o graph.o common.o mgraph.o minimise.o half.o
31 $(CXX) $(CXXFLAGS) -o $@ $^ $(LIBGSL)
33 primer: primer.o common.o
34 $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL)
36 nprocessors: nprocessors.o common.o
37 $(CC) $(CFLAGS_UNIPROC) -o $@ $^ $(LIBGSL)
39 common.o nprocessors.o: %.o: %.c
40 $(CC) -c $(CPPFLAGS) $(CFLAGS_UNIPROC) $< -o $@
42 .nprocessors.make: ./nprocessors
43 set -e; n=`./nprocessors`; \
44 echo "NPROCCFLAGS := -DNPROCESSORS=$$n" $o
46 include .nprocessors.make
52 sgtatham.cfm: sgtatham-regenerator prime.data $(SGTATHAM)/z.typescript
55 lumpy.cfm: oldmoebius-converter prime.data ../moebius/ins-new ../moebius/a.out
58 ring.cfm: oldmoebius-converter prime.data /dev/null ../moebius/a.out
62 ./minimise-33 sgtatham.cfm -iwip-33.cfm -o$@
64 start-64.cfm: best-33.CFM
65 ./interpolate-64 -a4 $< -o$@
68 ./minimise-64 start-64.cfm -iwip-64.CFM -o$@
71 best-$1.cfm: interpolate-$1 $2
75 $(eval $(call interpolate_aa,968, best-487.cfm))
76 $(eval $(call interpolate_aa,487, best-246.cfm))
77 $(eval $(call interpolate_aa,246, best-125.cfm))
78 $(eval $(call interpolate_aa,125, best-64.CFM))
80 view-%: view+%.o mgraph+%.o common.o
81 $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL) -L/usr/X11R6/lib -lX11
83 output-%: output+%.o mgraph+%.o common.o
84 $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL) -L/usr/X11R6/lib -lX11
86 interpolate-%: interpolate+%.o mgraph+%.o common.o
87 $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL)
89 minimise-%: energy+%.o graph+%.o mgraph+%.o minimise+%.o \
90 half+%.o parallel.o common.o
91 $(CXX) $(CXXFLAGS) -o $@ $^ $(LIBGSL) -lpthread
93 # this ridiculous repetition is due to make being too lame
96 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
99 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
102 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
104 minimise+%.o: minimise.c
105 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
108 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
111 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
114 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
116 interpolate+%.o: interpolate.c
117 $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@
119 .PRECIOUS: view+%.o output+%.o mgraph+%.o interpolate+%.o
122 rm -f prime.data $(TARGETS)
123 rm -f *.o *.new *.tmp *.rej *.orig core vgcore.* *~
124 rm -f *.d .alternately_*