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
57
|
CC=g++
INCLUDE=-I. -I${MTT_LIB}/cr/hh
OPTIMISE=-O0
WARNINGS=-Wall -ansi -pedantic
all: $(MTT_SYS)_cxxsim.$(MTT_LANG)
# view rule copied from gnuplot_rep.make
# need it here to prevent MTT using the default route (via dae)
$(MTT_SYS)_cxxsim.view: $(MTT_SYS)_gnuplot.wish $(MTT_SYS)_cxxsim.exe
./$(MTT_SYS)_cxxsim.exe > $(MTT_SYS)_odes.dat2
sh $(MTT_SYS)_gnuplot.wish |\
tee gnuplot_in.log |\
gnuplot -geometry 400x300 \
> gnuplot_out.log 2> gnuplot_err.log &
$(MTT_SYS)_cxxsim.exe: $(MTT_SYS)_cxxsim.cc
echo Creating $(MTT_SYS)_cxxsim.exe
$(CC) -o $@ $^ $(OPTIMISE) $(WARNINGS) $(INCLUDE)
$(MTT_SYS)_cxxsim.cc: $(MTT_SYS)_cr.txt $(MTT_SYS)_ese.r $(MTT_SYS)_struc.txt $(MTT_SYS)_sympar.txt cxxsim
./cxxsim $(MTT_SYS)
cp $@ ..
cxxsim: ${MTT_LIB}/rep/cxxsim.cc
echo creating $@
echo Compiling $^
$(CC) -o $@ $^ $(OPTIMISE) $(WARNINGS) $(INCLUDE)
# list of constitutive relationships
$(MTT_SYS)_cr.txt:
mtt -q $(MTT_OPTS) $(MTT_SYS) cr txt
# elementary system equations
$(MTT_SYS)_ese.r:
mtt -q $(MTT_OPTS) $(MTT_SYS) ese r
# system structure
$(MTT_SYS)_struc.txt:
mtt -q $(MTT_OPTS) $(MTT_SYS) struc txt
|
>
>
>
>
>
|
|
|
<
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
>
|
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
|
CC=g++
INCLUDE=-I. -I${MTT_LIB}/cr/hh
OPTIMISE=-O0
WARNINGS=-Wall -ansi -pedantic
ifeq ("","$(MTT_ARG)")
TARGET=$(MTT_SYS)_cxxsim.$(MTT_LANG)
else
TARGET=$(MTT_SYS)_cxxsim-$(MTT_ARG).$(MTT_LANG)
endif
all: $(TARGET)
# rule copied from gnuplot_rep.make
# need it here to prevent MTT using the default route (via dae)
$(MTT_SYS)_cxxsim.gnuplot: $(MTT_SYS)_gnuplot.wish $(MTT_SYS)_odes.dat2
sh $(MTT_SYS)_gnuplot.wish |\
tee gnuplot_in.log |\
gnuplot -geometry 400x300 \
> gnuplot_out.log 2> gnuplot_err.log &
$(MTT_SYS)_cxxsim.view: $(MTT_SYS)_cxxsim-odes.ps $(MTT_SYS)_cxxsim-odeso.ps
${PSVIEW} $(MTT_SYS)_cxxsim-odes.ps
${PSVIEW} $(MTT_SYS)_cxxsim-odeso.ps
$(MTT_SYS)_cxxsim.ps: $(MTT_SYS)_cxxsim-odeso.ps
cp $< $@
$(MTT_SYS)_cxxsim-ode%.ps: $(MTT_SYS)_ode%.fig
fig2dev -Leps $(MTT_SYS)_ode$*.fig $@
$(MTT_SYS)_ode%.fig: $(MTT_SYS)_ode%.gdat
gdat2fig $(MTT_SYS)_ode$*
$(MTT_SYS)_ode%.gdat: $(MTT_SYS)_ode%.dat
dat2gdat $(MTT_SYS) ode$*
$(MTT_SYS)_ode%.dat: $(MTT_SYS)_def.r $(MTT_SYS)_odes.dat2
dat22dat $(MTT_SYS) ode $*
$(MTT_SYS)_odes.dat2: $(MTT_SYS)_cxxsim.exe
./$< > $@
$(MTT_SYS)_cxxsim.exe: $(MTT_SYS)_cxxsim.cc
echo Creating $(MTT_SYS)_cxxsim.exe
$(CC) -o $@ $^ $(OPTIMISE) $(WARNINGS) $(INCLUDE)
$(MTT_SYS)_cxxsim.cc: $(MTT_SYS)_cr.txt $(MTT_SYS)_ese.r $(MTT_SYS)_struc.txt $(MTT_SYS)_sympar.txt cxxsim
./cxxsim $(MTT_SYS)
cp $@ ..
cxxsim: ${MTT_LIB}/rep/cxxsim.cc
echo creating $@
echo Compiling $^
$(CC) -o $@ $^ $(OPTIMISE) $(WARNINGS) $(INCLUDE)
# list of constitutive relationships
$(MTT_SYS)_cr.txt:
mtt -q $(MTT_OPTS) $(MTT_SYS) cr txt
# array sizes
$(MTT_SYS)_def.r:
mtt -q $(MTT_OPTS) $(MTT_SYS) def r
# elementary system equations
$(MTT_SYS)_ese.r:
mtt -q $(MTT_OPTS) $(MTT_SYS) ese r
# system structure
$(MTT_SYS)_struc.txt:
mtt -q $(MTT_OPTS) $(MTT_SYS) struc txt
|