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
