X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?a=blobdiff_plain;f=Makefile;h=b41c543b25f800691cda9c7b3c198b39a76faea8;hb=62eac09041f09319ed3abf08ea78c1695003f5a5;hp=dd4b218ed001f0eb33ec5f901a29e70c2679efef;hpb=75293637fe7efbce3f2e873cc792da3bff577fef;p=moebius2.git diff --git a/Makefile b/Makefile index dd4b218..b41c543 100644 --- a/Makefile +++ b/Makefile @@ -1,9 +1,11 @@ -VIEWDIMS=33 64 125 -TARGETS= minimise primer lumpy.cfm sgtatham.cfm ring.cfm \ - interpolate-64 \ - $(addprefix view-, $(VIEWDIMS)) +ALLDIMS=33 64 125 246 487 968 +TARGETS= primer lumpy.cfm sgtatham.cfm ring.cfm \ + minimise-33 minimise-64 \ + $(addprefix interpolate-, $(ALLDIMS)) \ + $(addprefix view-, $(ALLDIMS)) \ + $(addprefix output-, $(ALLDIMS)) SGTATHAM=sgtatham CWARNS= -Wall -Wwrite-strings -Wpointer-arith -Werror -Wshadow @@ -19,7 +21,9 @@ o= >$@.new && mv -f $@.new $@ all: $(TARGETS) -compute: best.CFM +compute: all + $(MAKE) best-33.CFM + $(MAKE) best-968.CFM minimise: energy.o graph.o common.o mgraph.o minimise.o half.o $(CXX) $(CXXFLAGS) -o $@ $^ $(LIBGSL) @@ -40,27 +44,65 @@ lumpy.cfm: oldmoebius-converter prime.data ../moebius/ins-new ../moebius/a.out ring.cfm: oldmoebius-converter prime.data /dev/null ../moebius/a.out ./$^ -o$@ -best.CFM: minimise sgtatham.cfm - ./$^ -iwip.cfm -o$@ + +best-33.CFM: + ./minimise-33 sgtatham.cfm -iwip-33.cfm -o$@ + +start-64.cfm: best-33.CFM + ./interpolate-64 -a4 $< -o$@ + +best-64.CFM: + ./minimise-64 start-64.cfm -iwip-64.CFM -o$@ + +define interpolate_aa +best-$1.cfm: interpolate-$1 $2 + ./$$< -aa $2 -o$$@ +endef + +$(eval $(call interpolate_aa,968, best-487.cfm)) +$(eval $(call interpolate_aa,487, best-246.cfm)) +$(eval $(call interpolate_aa,246, best-125.cfm)) +$(eval $(call interpolate_aa,125, best-64.CFM)) view-%: view+%.o mgraph+%.o common.o $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL) -L/usr/X11R6/lib -lX11 +output-%: output+%.o mgraph+%.o common.o + $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL) -L/usr/X11R6/lib -lX11 + interpolate-%: interpolate+%.o mgraph+%.o common.o $(CC) $(CFLAGS) -o $@ $^ $(LIBGSL) +minimise-%: energy+%.o graph+%.o mgraph+%.o minimise+%.o half+%.o common.o + $(CXX) $(CXXFLAGS) -o $@ $^ $(LIBGSL) + # this ridiculous repetition is due to make being too lame view+%.o: view.c $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ +output+%.o: output.c + $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ + mgraph+%.o: mgraph.c $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ +minimise+%.o: minimise.c + $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ + +graph+%.o: graph.c + $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ + +energy+%.o: energy.c + $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ + +half+%.o: half.c + $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ + interpolate+%.o: interpolate.c $(CC) -c $(CPPFLAGS) $(CFLAGS) -DDEFSZ=$* $< -o $@ -.PRECIOUS: view+%.o mgraph+%.o interpolate+%.o +.PRECIOUS: view+%.o output+%.o mgraph+%.o interpolate+%.o clean: rm -f prime.data $(TARGETS)