MCS = mcs -optimize+ -platform:arm MONO = mono -O=all #-O=all,-shared #--optimize=unsafe,loop,inline #--gc=sgen --llvm --optimize=all comma:=, empty:= space:=$(empty) $(empty) commalist = $(subst $(space),$(comma),$(1)) all: Out.classic.txt Out.times.svg Out.classic.txt: main.exe $(MONO) $< 7 | tee $@ Out.times.svg: out.times.txt Makefile echo '\ set term svg;\ set out "$@";\ set key left;\ set title "matrix diagonalization times (`$(MCS) --version` `uname -m`)";\ set xlabel "matrix size n";\ set ylabel "diagonalization time t, sec";\ f(x)=b+(x/a)**c;\ b=0.7; a=20; c=3;\ fit f(x) "$<" via b,a;\ plot \ "$<" title "measurement" \ ,f(x) title sprintf("cyclic: fit: (n/%.f)^{%.2f}+%.2f",a,c,b) \ '| gnuplot out.times.txt: main.exe Makefile cat /dev/null > $@ for N in `seq 45 5 95`; do \ echo "N=$$N";\time -ao $@ -f "$$N %U" $(MONO) main.exe $$N ; \ done main.exe: main.cs matrix.dll $(MCS) $< -o:$@ -r:$(call commalist,$(filter-out $<,$^)) matrix.dll: jacobi.cs ../matrix/matrix.cs ../matrix/vector.cs $(MCS) $^ /t:library /out:$$(pwd)/$@ clean: $(RM) *.dll *.exe [Oo]ut.* *.log